ruby-on-rails – 来自Rspec的后挂钩,PG :: InFailedSqlTransaction错误

前端之家收集整理的这篇文章主要介绍了ruby-on-rails – 来自Rspec的后挂钩,PG :: InFailedSqlTransaction错误前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我试图从模型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语句,则会发生这种情况.

一旦事务中的一个语句失败,就不能在该事务中执行更多语句.

这是一个例子:

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并且被救援吞下了.

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

猜你在找的Ruby相关文章