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

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

新規登録して質問してみよう
ただいま回答率
85.50%
Ruby on Rails 5

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

Ruby

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

Q&A

解決済

1回答

3767閲覧

Railsでmigrate後のエラー「bin/rails db:migrate RAILS_ENV=test」について

SHUNSUKE_1990

総合スコア20

Ruby on Rails 5

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

Ruby

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

0グッド

0クリップ

投稿2019/03/08 15:53

前提・実現したいこと

最終的な目的:Railsでテーブルを作成し、テストの実施を成功させたい
開発環境:ローカル(Windows10)

Rails5.1チュートリアル挑戦中で、第6章のmigrateが上手く行かずに立ち往生しています。
手順としては下記の通り、モデル作成後、migrateには成功したものの、テストを実行した途端にエラーを吐くという状況です。

C:\Users\snish\environment\sample_app>rails generate model User name:string email:string invoke active_record create db/migrate/20190308140335_create_users.rb create app/models/user.rb invoke test_unit create test/models/user_test.rb create test/fixtures/users.yml C:\Users\snish\environment\sample_app>rails db:migrate == 20190308140335 CreateUsers: migrating ====================================== -- create_table(:users) -> 0.0035s == 20190308140335 CreateUsers: migrated (0.0042s) =============================

発生している問題・エラーメッセージ

C:\Users\snish\environment\sample_app>rails test Migrations are pending. To resolve this issue, run: bin/rails db:migrate RAILS_ENV=test C:\Users\snish\environment\sample_app>rails db:migrate RAILS_ENV=test == 20190308140335 CreateUsers: migrating ====================================== -- create_table(:users) rails aborted! StandardError: An error has occurred, this and all later migrations canceled: SQLite3::SQLException: table "users" already exists: CREATE TABLE "users" ("id" INTEGER PRIMARY KEY AUTOINCREMENT NOT NULL, "name" varchar, "email" varchar, "created_at" datetime NOT NULL, "updated_at" datetime NOT NULL) C:/Users/snish/environment/sample_app/db/migrate/20190308140335_create_users.rb:3:in `change' bin/rails:4:in `require' bin/rails:4:in `<main>' Caused by: ActiveRecord::StatementInvalid: SQLite3::SQLException: table "users" already exists: CREATE TABLE "users" ("id" INTEGER PRIMARY KEY AUTOINCREMENT NOT NULL, "name" varchar, "email" varchar, "created_at" datetime NOT NULL, "updated_at" datetime NOT NULL) C:/Users/snish/environment/sample_app/db/migrate/20190308140335_create_users.rb:3:in `change' bin/rails:4:in `require' bin/rails:4:in `<main>' Caused by: SQLite3::SQLException: table "users" already exists C:/Users/snish/environment/sample_app/db/migrate/20190308140335_create_users.rb:3:in `change' bin/rails:4:in `require' bin/rails:4:in `<main>' Tasks: TOP => db:migrate (See full trace by running task with --trace)

試したこと

C:\Users\snish\environment\sample_app>bundle exec rake db:migrate RAILS_ENV=test == 20190308140335 CreateUsers: migrating ====================================== -- create_table(:users) rake aborted! StandardError: An error has occurred, this and all later migrations canceled: SQLite3::SQLException: table "users" already exists: CREATE TABLE "users" ("id" INTEGER PRIMARY KEY AUTOINCREMENT NOT NULL, "name" varchar, "email" varchar, "created_at" datetime NOT NULL, "updated_at" datetime NOT NULL) C:/Users/snish/environment/sample_app/db/migrate/20190308140335_create_users.rb:3:in `change' Caused by: ActiveRecord::StatementInvalid: SQLite3::SQLException: table "users" already exists: CREATE TABLE "users" ("id" INTEGER PRIMARY KEY AUTOINCREMENT NOT NULL, "name" varchar, "email" varchar, "created_at" datetime NOT NULL, "updated_at" datetime NOT NULL) C:/Users/snish/environment/sample_app/db/migrate/20190308140335_create_users.rb:3:in `change' Caused by: SQLite3::SQLException: table "users" already exists C:/Users/snish/environment/sample_app/db/migrate/20190308140335_create_users.rb:3:in `change' Tasks: TOP => db:migrate (See full trace by running task with --trace) C:\Users\snish\environment\sample_app>rails db:migrate:reset Permission denied @ unlink_internal - C:/Users/snish/environment/sample_app/db/development.sqlite3 Couldn't drop database 'db/development.sqlite3' rails aborted! Errno::EACCES: Permission denied @ unlink_internal - C:/Users/snish/environment/sample_app/db/development.sqlite3 bin/rails:4:in `require' bin/rails:4:in `<main>' Tasks: TOP => db:drop:_unsafe (See full trace by running task with --trace) C:\Users\snish\environment\sample_app>rails db:migrate C:\Users\snish\environment\sample_app>rails test Migrations are pending. To resolve this issue, run: bin/rails db:migrate RAILS_ENV=test

補足情報(FW/ツールのバージョンなど)

ruby  2.4.5
Rails  5.1.6
sqlite3 1.3.13

以上になります。
不足情報等あればすぐに追記しますので、よろしくお願いします。

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

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

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

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

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

guest

回答1

0

ベストアンサー

まずはconfig/database.ymlを確認して
test環境の接続先をリセットしても良さげかを確認

大丈夫そうなら、rails db:migrate:reset RAILS_ENV=testを実行

投稿2019/03/09 03:07

asm

総合スコア15147

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

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

SHUNSUKE_1990

2019/03/09 07:05

ご回答ありがとうございます! 教えて頂いたconfig/database.ymlを確認しました。 「# SQLite version 3.x # gem install sqlite3 # # Ensure the SQLite 3 gem is defined in your Gemfile # gem 'sqlite3' # default: &default adapter: sqlite3 pool: <%= ENV.fetch("RAILS_MAX_THREADS") { 5 } %> timeout: 5000 development: <<: *default database: db/development.sqlite3 # Warning: The database defined as "test" will be erased and # re-generated from your development database when you run "rake". # Do not set this db to the same as development or production. test: <<: *default database: db/test.sqlite3 production: <<: *default database: db/production.sqlite3」 そしてrails db:migrate:reset RAILS_ENV=testを実行しましたが、残念ながら再びエラーが出てきてしまいました。 「C:\Users\snish\environment\sample_app>rails db:migrate:reset RAILS_ENV=test Permission denied @ unlink_internal - C:/Users/snish/environment/sample_app/db/test.sqlite3 Couldn't drop database 'db/test.sqlite3' rails aborted! Errno::EACCES: Permission denied @ unlink_internal - C:/Users/snish/environment/sample_app/db/test.sqlite3 bin/rails:4:in `require' bin/rails:4:in `<main>' Tasks: TOP => db:drop:_unsafe (See full trace by running task with --trace)」 もしよろしければ、この点についても有効なアドバイスを頂けませんでしょうか。
asm

2019/03/09 07:13

なんとなく、裏でrailsを起動したままな気がします C:/Users/snish/environment/sample_app/db/test.sqlite3 を削除することで、 rails db:migrate RAILS_ENV=test ができると思いますよ
SHUNSUKE_1990

2019/03/09 07:44

即レスありがとうございます!! そしてアドバイス頂いた通り、C:/Users/snish/environment/sample_app/db/test.sqlite3の削除後に、rails db:migrate RAILS_ENV=testを実行することで解決しました! 「C:\Users\snish\environment\sample_app>rails db:migrate RAILS_ENV=test == 20190308140335 CreateUsers: migrating ====================================== -- create_table(:users) -> 0.0022s == 20190308140335 CreateUsers: migrated (0.0028s) =============================」 本当に助かりました! ありがとうございました!!
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.50%

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

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

質問する

関連した質問