关于rails上的ruby:来自Rspec的后挂钩,PG :: InFailedSqlTransaction中的错误

Error in an after hook, PG::InFailedSqlTransaction from Rspec

我试图从模型spec文件运行rspec,但我收到此错误:"挂钩后发生错误"

"An error occurred in to after hook PG :: InFailedSqlTransaction:
ERROR: current transaction is aborted, commands ignored until end of
transaction. occurred at C :/ Ruby193/lib/.../postgresql_adapter: 294"

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


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

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

这是一个例子:

1
2
3
4
5
6
7
8
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语句。