前提
ある程度完成したRailsアプリケーションにRspecテストを導入しようと思い、rspecをインストールしたのちに
$ docker-compose run web bundle exec rspec
を入力したが、
Running via Spring preloader in process 44 rake aborted! ActiveRecord::NoDatabaseError: Unknown database 'jsmcreserveapp_test' 以下略
というエラーが発生しました。
実現したいこと
testのデータベースを作成し、rspecを実行できるようにしたいです。
該当のソースコード
database.yml
1default: &default 2 adapter: mysql2 3 encoding: utf8mb4 4 pool: <%= ENV.fetch("RAILS_MAX_THREADS") { 5 } %> 5 username: root 6 password: password 7 host: db 8 9development: 10 <<: *default 11 database: JSMCreserveapp_development 12 13test: 14 <<: *default 15 database: JSMCreserveapp_test 16 host: <%= ENV.fetch("APP_DATABASE_HOST") { 'db' } %> 17 18production: 19 <<: *default 20 database: <%= ENV['APP_DATABASE'] %> 21 host: <%= ENV['APP_DATABASE_HOST'] %> 22 username: <%= ENV['APP_DATABASE_USERNAME'] %> 23 password: <%= ENV['APP_DATABASE_PASSWORD'] %> 24
Dockerfile
1FROM ruby:2.7.5 2 3ENV RAILS_ENV=production 4 5RUN curl -sS https://dl.yarnpkg.com/debian/pubkey.gpg | apt-key add - \ 6 && echo "deb https://dl.yarnpkg.com/debian/ stable main" | tee /etc/apt/sources.list.d/yarn.list \ 7 && apt-get update -qq \ 8 && apt-get install -y nodejs yarn 9WORKDIR /app 10COPY . /app 11RUN bundle config --local set path 'vendor/bundle' \ 12 && bundle install 13 14COPY start.sh /start.sh 15RUN chmod 744 /start.sh 16CMD ["sh", "/start.sh"]
dockercompose.yml
1version: '3' 2services: 3 db: 4 image: mysql:8.0 5 command: --default-authentication-plugin=mysql_native_password 6 volumes: 7 - ./db/mysql_data:/var/lib/mysql 8 environment: 9 MYSQL_ROOT_PASSWORD: password 10 web: 11 build: . 12 command: bundle exec rails s -p 3000 -b '0.0.0.0' 13 volumes: 14 - .:/app 15 ports: 16 - "3000:3000" 17 environment: 18 RAILS_ENV: development 19 depends_on: 20 - db
試したこと
$ docker-compose up -d $ docker exec -it jsmcreserveapp_db_1 bash $ mysql -u root -p
とコマンドを入力し、データベースを確認しましたがjsmcreserveapp_testはありませんでした。
(jsmcreserveapp_developmentはありました)
なのでデータベースを作成しようと思い、以下のコマンドを打ち込みました。
$ docker-compose run web bundle exec rails db:create Running via Spring preloader in process 29 Database 'JSMCreserveapp_development' already exists Created database 'JSMCreserveapp_test' $ docker-compose down $ docker-compose run web bundle exec rails db:migrate Running via Spring preloader in process 31
その後rspecを実行すると
$ docker-compose run web bundle exec rspec Running via Spring preloader in process 45 rake aborted! ActiveRecord::StatementInvalid: Mysql2::Error: Schema directory './JSMCreserveapp_test' already exists. This must be resolved manually (e.g. by moving the schema directory to another location). 以下略
のエラーが発生します。
一度docker-compose downをして再びrspecを実行すると、
$ docker-compose run web bundle exec rspec Running via Spring preloader in process 44 rake aborted! ActiveRecord::NoDatabaseError: Unknown database 'jsmcreserveapp_test'
という別のエラーが発生します。
解決策を色々調べましたが詰まってしまったため、アドバイスをいただければありがたいです。
補足情報(FW/ツールのバージョンなど)
ruby '2.7.5'
rails '6.1.6'

あなたの回答
tips
プレビュー