如何使用测试数据库加载Rails测试环境?

时间:2014-08-25 10:58:40

标签: ruby-on-rails ruby minitest

我想为Rails加载测试环境以运行我最小的测试。

将RAILS_ENV设置为'test'后,我需要config / environment.rb。

这似乎不是正确的方法,因为似乎没有创建测试数据库。

我知道这是一个相当愚蠢的问题,但我没有看到其他人真的在问它。

* test / test_helper.rb中的代码

require 'minitest/autorun'

ENV['RAILS_ENV'] = 'test'

require_relative '../config/environment'

* test / models / users_test.rb中的基本锅炉板和完整性测试

require_relative '../test_helper.rb'

class UserModelTest < MiniTest::Test

  def setup
    @user = User.new
    @user.email = 'me@example.com'
    @user.password = 'password'
    @user.save
  end

  def test_sanity
    assert true
  end

end

*我从上面的安装方法得到的错误让我觉得测试数据库没有被创建和迁移

Error:
UserModelTest#test_sanity:
ActiveRecord::StatementInvalid: PG::UndefinedTable: ERROR:  relation "users" does not exist
LINE 5:                WHERE a.attrelid = '"users"'::regclass
                                      ^
:               SELECT a.attname, format_type(a.atttypid, a.atttypmod),
                     pg_get_expr(d.adbin, d.adrelid), a.attnotnull, a.atttypid, a.atttypmod
                FROM pg_attribute a LEFT JOIN pg_attrdef d
                  ON a.attrelid = d.adrelid AND a.attnum = d.adnum
                WHERE a.attrelid = '"users"'::regclass
                  AND a.attnum > 0 AND NOT a.attisdropped
                ORDER BY a.attnum

    /home/john/.rvm/gems/ruby-2.1.1@mangam/gems/activerecord-4.1.0/lib/active_record/connection_adapters/postgresql_adapter.rb:815:in `async_exec'
.
.
.
/home/john/.rvm/gems/ruby-2.1.1@mangam/gems/activerecord-4.1.0/lib/active_record/inheritance.rb:23:in `new'
   test/models/users_test.rb:6:in `setup'

1 个答案:

答案 0 :(得分:1)

有时,测试数据库可能会失去同步。我不确定是什么导致它...但我通常可以通过在测试环境下运行与数据库相关的rake命令来解决问题。在您的情况下,看起来迁移只是不同步,所以请尝试:

RAILS_ENV=test bundle exec rake db:migrate

此外,在Rails 4.1中,这里的默认 test_helper.rb 文件应如下所示,因此您可能需要调整自己的文件:

ENV['RAILS_ENV'] ||= 'test'
require File.expand_path('../../config/environment', __FILE__)
require 'rails/test_help'

class ActiveSupport::TestCase
  # Setup all fixtures in test/fixtures/*.yml for all tests in alphabetical order.
  fixtures :all

  # Add more helper methods to be used by all tests here...
end

然后在您的测试文件中,您可以使用require "test_helper"代替require_relative '../test_helper.rb'