質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.50%
docker-compose

docker-composeとは、複数のコンテナで構成されるサービスを提供する手順を自動的し管理を簡単にするツール。composeファイルを使用しコマンド1回で設定した全サービスを作成・起動することが可能です。

Ruby

Rubyはプログラミング言語のひとつで、オープンソース、オブジェクト指向のプログラミング開発に対応しています。

Ruby on Rails 6

Ruby on Rails 6は、オープンソースのWebアプリケーションフレームワークです。「同じことを繰り返さない」というRailsの基本理念のもと、他のフレームワークより少ないコードで簡単に開発できるよう設計されています。

MySQL

MySQL(マイエスキューエル)は、TCX DataKonsultAB社などが開発するRDBMS(リレーショナルデータベースの管理システム)です。世界で最も人気の高いシステムで、オープンソースで開発されています。MySQLデータベースサーバは、高速性と信頼性があり、Linux、UNIX、Windowsなどの複数のプラットフォームで動作することができます。

Docker

Dockerは、Docker社が開発したオープンソースのコンテナー管理ソフトウェアの1つです

Q&A

0回答

675閲覧

(Rails)test用のデータベースが作成できず、NoDatabaseErrorが発生する

keiino0425

総合スコア2

docker-compose

docker-composeとは、複数のコンテナで構成されるサービスを提供する手順を自動的し管理を簡単にするツール。composeファイルを使用しコマンド1回で設定した全サービスを作成・起動することが可能です。

Ruby

Rubyはプログラミング言語のひとつで、オープンソース、オブジェクト指向のプログラミング開発に対応しています。

Ruby on Rails 6

Ruby on Rails 6は、オープンソースのWebアプリケーションフレームワークです。「同じことを繰り返さない」というRailsの基本理念のもと、他のフレームワークより少ないコードで簡単に開発できるよう設計されています。

MySQL

MySQL(マイエスキューエル)は、TCX DataKonsultAB社などが開発するRDBMS(リレーショナルデータベースの管理システム)です。世界で最も人気の高いシステムで、オープンソースで開発されています。MySQLデータベースサーバは、高速性と信頼性があり、Linux、UNIX、Windowsなどの複数のプラットフォームで動作することができます。

Docker

Dockerは、Docker社が開発したオープンソースのコンテナー管理ソフトウェアの1つです

0グッド

2クリップ

投稿2023/01/25 00:24

編集2023/01/27 15:43

前提

ある程度完成した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'

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

yuma.inaura

2023/01/25 01:39

とりあえずメッセージ通りディレクトリを消してみるとどうなりますか
keiino0425

2023/01/26 02:03

メッセージ通りディレクトリを消してみるというのは >> 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 up -d $ docker-compose exec web bash $ ls -a で探してみましたがJSMCreserveapp_testにあたるファイルが見つかりませんでした。 見当違いなことを言っているかもしれませんがディレクトリを消すことができなかったためアドバイスをお願いしたいです。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだ回答がついていません

会員登録して回答してみよう

アカウントをお持ちの方は

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.50%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問