前提・実現したいこと
railsにてアプリを作成 github push時に circleciにて ciを実施したい
発生している問題・エラーメッセージ・エラー画面
mysqlにパスワードを渡せない
Mysql2::Error::ConnectionError: Access denied for user 'circleci'@'127.0.0.1' (using password: NO)
該当のソースコード①(.circleci\config.yml)
version: 2 jobs: test: docker: - image: circleci/ruby:2.4.5-node-browsers environment: RAILS_ENV: test BUNDLE_PATH: "vendor/bundle" BUNDLER_VERSION: 2.0.2 - image: circleci/mysql:5.7 environment: #MYSQL_ALLOW_EMPTY_PASSWORD: true yesで、rootユーザに空のパスワードを設定してコンテナを起動することを許可 MYSQL_ROOT_PASSWORD: 'sample' MYSQL_DATABASE: test_db working_directory: ~/repo steps: - checkout - run: name: bundle のセットアップ bundler2系に対応 command: | sudo gem update --system sudo gem uninstall bundler sudo rm /usr/local/bin/bundle #sudo rm /usr/local/bin/bundler sudo gem install bundler - restore_cache: keys: - v1-dependencies-{{ checksum "Gemfile.lock" }} # fallback to using the latest cache if no exact match is found - v1-dependencies- - run: name: install bundle command: | bundle install --jobs=4 --retry=3 --path vendor/bundle - save_cache: paths: - ./vendor/bundle key: v1-dependencies-{{ checksum "Gemfile.lock" }} - run: name: データベースの起動を待機 command: dockerize -wait tcp://127.0.0.1:3306 -timeout 1m - run: name: データベースのセットアップ command: bundle exec rake db:schema:load - run: name: gem install bundler command: gem install bundler - run: name: rspecを実行 command: bundle exec rspec workflows: version: 2 workflows: jobs: - test
該当のソースコード②(config\database.yml)
default: &default adapter: mysql2 encoding: utf8 pool: <%= ENV.fetch("RAILS_MAX_THREADS") { 5 } %> timeout: 5000 username: <%= ENV['DATEBASE_USER_NAME'] %> password: <%= ENV['DATEBASE_USER_PASS'] %> host: 127.0.0.1 development: <<: *default database: development_db test: <<: *default database: test_db
参考にしたサイト
【ruby×circleci】はじめてのCI環境の構築② / ruby on Rails × MySQLなWebアプリにCIを組み込む
的外れかもしれませんが、
上記サイトを確認して、database.yml と config.ymlのパスワードを合わせる必要があるのかと
考えています。しかし、database.ymlは環境変数で渡しており、config.ymlへの反映のさせ方が
分かりません
あなたの回答
tips
プレビュー