如何运行 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 工作正常。