Rspec返回"PG :: Error:ERROR:关系“table_name”不存在"。

11

环境是REE(2011.12),使用rvm、rspec 2.8.0、rails 3.0.6和pg 0.13.2。在CentOS 5.6上使用PostgreSQL 8.3.17。db:migrate已经正确工作。但是rspec出现了以下错误。

1) ApiController articles OK
 Failure/Error: Unable to find matching line from backtrace
 ActiveRecord::StatementInvalid:
   PG::Error: ERROR:  relation "table_name" does not exist
   : DELETE FROM "table_name"

我正在将我的项目从Rails 2.3.5和Rspec 1.x系列更新到Rails 3.0和Rspec 2。拷贝了所有的Rspec测试,并且将旧的spec_helper.rb文件与新的文件进行了合并(它是使用rails g rspec:install命令生成的)。

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

Dir[Rails.root.join("spec/support/**/*.rb")].each {|f| require f}

RSpec.configure do |config|

  config.fixture_path = "#{::Rails.root}/spec/fixtures"
  config.use_transactional_fixtures = true

end

我看到了一个关于这个错误的类似问题。所以我尝试了 rake db:test:prepare 或者 rake db:test:load,但是都没有解决问题。你有什么想法吗? 看起来测试没有在测试数据库上运行... 我该怎么办? :(

4个回答

26

我在两个实例中遇到了这个问题(更新于2012年6月13日):

第一个实例:

我还没有迁移我的测试数据库...

rake db:migrate

...在执行db:test:preparedb:test:load之前,你需要先做这一步。

当你调用rspec时,它应该会自动为你prepareload数据库。你不需要手动进行此操作。

第二个实例:

我的迁移文件中有个错字。我在参数列表中错误地颠倒了表名和列名。

这是Rails 3.1项目中的一个迁移:

def change
  add_column :had_import_errors, :studies, :boolean, :default => false
  add_column :import_data_cache, :studies, :text
end

这是错误的,因为has_import_errorsimport_data_cache是我的列名称,因此它们应该出现在第二个位置,而不是第一个位置。

正确的迁移应该把表名放在第一位:

def change
  add_column :studies, :had_import_errors, :boolean, :default => false
  add_column :studies, :import_data_cache, :text
end

2
我显然忘记了 rake db:test:load。谢谢。 - nickcoxdotme

4
通常这种情况发生在您在迁移过程中运行rspec(通常通过guard)。一个简单的解决方案是退出guard,完成迁移后重新启动guard。

3

这通常表示有另一个PostgreSql连接处于打开状态。要正确显示错误,请尝试运行% rake db:test:prepare命令。

运行测试准备时,以下内容将显示出来,当打开的连接(在我的情况下是PGAdmin)关闭后,问题得到了解决。

rake aborted!
PG::Error: ERROR:  database "xyz_test" is being accessed by other users
DETAIL:  There are 1 other session(s) using the database.
: DROP DATABASE IF EXISTS "xyz_test"

Tasks: TOP => db:test:load => db:test:purge
(See full trace by running task with --trace)

1

我遇到了相同的错误,只有删除并重新创建数据库才能解决问题。

rake db:drop db:create db:migrate


网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接