2

在我的 Rails 应用程序中,我有两个数据库,我能够通过以下设置启动并运行它

database.yml

development: &defaults
  adapter: mysql
  encoding: utf8
  database: <Database1>
  username: <user_name>
  password: <password>
  host: localhost

second_development: &defaults
  adapter: mysql
  encoding: utf8
  database: <Database2>
  username: <user_name>
  password: <password>
  host: localhost

test: &defaults
  adapter: mysql
  encoding: utf8
  database: <Database1_test>
  username: <user_name>
  password: <password>
  host: localhost

second_test: &defaults
  adapter: mysql
  encoding: utf8
  database: <Database2_test>
  username: <user_name>
  password: <password>
  host: localhost

但问题是在运行测试用例时,我使用的是“mocha”、“guard”和“notahat-machinist”,当我尝试运行测试用例时,它首先运行 schema.rb 文件。但问题是它只从第一个测试数据库创建模式

test: &defaults
      adapter: mysql
      encoding: utf8
      database: <Database1_test>
      username: <user_name>
      password: <password>
      host: localhost 

这将使与第二个测试数据库“Database2_test”相关的测试失败。解决方法是什么。

生成一个包含数据库模式的 schema.rb 文件。

提前致谢

4

1 回答 1

0

schema.rb 生成由连接定义。因此,您需要在测试中使用良好的连接来获得良好的架构。

于 2012-04-04T08:05:41.433 回答