后挂钩错误,来自Rspec的PG :: InFailedSqlTransaction

时间:2014-01-21 16:25:10

标签: ruby-on-rails rspec gem

我试图从模型spec文件中运行rspec,但是我收到了这个错误:“挂钩后发生错误”

  

“挂钩PG :: InFailedSqlTransaction后发生错误:   错误:当前事务被中止,命令被忽略直到结束   交易。发生在C:/ Ruby193 / lib /.../ postgresql_adapter:294“

我搜索了这个问题,我发现了将'database_cleaner'降级为'1.0.1'的建议。我做了,但它不起作用。 有谁知道如何解决这个问题?提前谢谢!

1 个答案:

答案 0 :(得分:14)

如果您在事务范围内执行错误的SQL语句,从该语句中抢救异常,然后尝试在同一事务中执行另一个SQL语句,则会发生这种情况。

一旦事务中的一个语句失败,就不能再在该事务中执行语句。

以下是一个例子:

ActiveRecord::Base.transaction do
  begin
    ActiveRecord::Base.connection.execute "A bad query"
  rescue => ex 
    puts ex.message
  end
  puts User.count
end

User.count引发PG::InFailedSqlTransaction因为之前的SQL语句引发了ActiveRecord::StatementInvalid而被rescue吞没了。

所以我会寻找在事务范围内获救的代码,然后尝试运行其他SQL语句。