4

我正在使用带有 sqlite3 的 Rails 4.0.0.rc1 并尝试设置测试数据库进行测试。bundle exec rake db:test:prepare没有在测试数据库中创建表。在遵循这个问题之后,我设法通过运行bundle exec rake db:schema:load RAILS_ENV=test -tWhat can be the reason for task bundle exec rake db:test:prepareto not to setup the database 来设置测试数据库。

下面是 2 个 rake 任务的输出。

indika@indika-F3E:~/Documents/my_app$ bundle exec rake db:test:prepare -t
** Invoke db:test:prepare (first_time)
** Execute db:test:prepare
indika@indika-F3E:~/Documents/my_app$ 

indika@indika-F3E:~/Documents/my_app$ bundle exec rake db:schema:load RAILS_ENV=test -t
** Invoke db:schema:load (first_time)
** Invoke environment (first_time)
** Execute environment
** Invoke db:load_config (first_time)
** Execute db:load_config
** Execute db:schema:load
-- create_table("questions", {:force=>true})
   -> 0.2590s
-- initialize_schema_migrations_table()
   -> 0.0025s
-- assume_migrated_upto_version(20130518181153, ["/home/indika/Documents/my_app/db/migrate"])
   -> 0.0007s
indika@indika-F3E:~/Documents/my_app$ 

里面的数据库配置database.yaml是这样的。

development:
  adapter: sqlite3
  database: db/development.sqlite3
  pool: 5
  timeout: 5000
test: &test
  adapter: sqlite3
  database: db/test.sqlite3
  pool: 5
  timeout: 5000
cucumber:
  <<: *test

请注意,我的问题已解决。但我很想知道出了什么问题。

4

1 回答 1

2

rake db:migrate RAILS_ENV=test适用于 Ruby 2.0.0 和 Rails 4.0.0.rc1 rake db:test:prepare 由于某种原因不适用于新版本。

于 2013-05-25T22:21:05.637 回答