如何运行 db:migrate for test database in Rails 5?
How to run db:migrate for test database in Rails 5?
我用 postgresql 数据库创建了一个新的 rails 5 应用程序并修改了 database.yml 文件。我成功地创建了开发和测试数据库,但是当 运行 迁移时,只有开发数据库被更新而测试数据库保持不变。
这是我使用的命令列表:
rails db:create # Created both development and test
rails db:migrate # Migrated only to development
rails db:migrate RAILS_ENV=test # Does nothing (no error output)
rake db:migrate RAILS_ENV=test # Same result as above
我的 database.yml 文件:
default: &default
adapter: postgresql
encoding: unicode
pool: <%= ENV.fetch("RAILS_MAX_THREADS") { 5 } %>
development:
<<: *default
database: myapp_development
username: myapp_admin
password:
host: localhost
port: 5432
test:
<<: *default
database: myapp_test
username: myapp_admin
password:
host: localhost
port: 5432
我也试过将 ActiveRecord::Migration.maintain_test_schema!
添加到 test_helper.rb
,但这也没有用。
有什么建议吗?
我通过从 database.yml 中删除 host: localhost
来让它工作。现在 rails db:migrate RAILS_ENV=test
工作正常。
我用 postgresql 数据库创建了一个新的 rails 5 应用程序并修改了 database.yml 文件。我成功地创建了开发和测试数据库,但是当 运行 迁移时,只有开发数据库被更新而测试数据库保持不变。
这是我使用的命令列表:
rails db:create # Created both development and test
rails db:migrate # Migrated only to development
rails db:migrate RAILS_ENV=test # Does nothing (no error output)
rake db:migrate RAILS_ENV=test # Same result as above
我的 database.yml 文件:
default: &default
adapter: postgresql
encoding: unicode
pool: <%= ENV.fetch("RAILS_MAX_THREADS") { 5 } %>
development:
<<: *default
database: myapp_development
username: myapp_admin
password:
host: localhost
port: 5432
test:
<<: *default
database: myapp_test
username: myapp_admin
password:
host: localhost
port: 5432
我也试过将 ActiveRecord::Migration.maintain_test_schema!
添加到 test_helper.rb
,但这也没有用。
有什么建议吗?
我通过从 database.yml 中删除 host: localhost
来让它工作。现在 rails db:migrate RAILS_ENV=test
工作正常。