ruby-on-rails – 来自Rspec的后挂钩,PG :: InFailedSqlTransact
发布时间:2020-12-16 19:23:47 所属栏目:百科 来源:网络整理
导读:我试图从模型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/l
我试图从模型spec文件运行rspec,但我收到此错误:“挂钩后发生错误”
我搜索了这个问题,我发现了将’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语句. (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |