n4d*_*n4d 8 gem rspec ruby-on-rails
我试图从模型规范文件运行rspec,但我收到此错误:"挂钩后发生错误"
"挂钩后发生错误PG :: InFailedSqlTransaction:错误:当前事务中止,命令被忽略,直到事务结束.发生在C:/ Ruby193/lib /.../ postgresql_adapter:294"
我搜索了这个问题,我发现了将'database_cleaner'降级为'1.0.1'的建议.我做了,但它不起作用.有谁知道如何解决这个问题?提前致谢!
Sco*_*sen 16
如果在事务范围内执行错误的SQL语句,从该语句中抢救异常,然后尝试在同一事务中执行另一个SQL语句,则会发生这种情况.
一旦事务中的一个语句失败,就不能再在该事务中执行语句.
这是一个例子:
ActiveRecord::Base.transaction do
begin
ActiveRecord::Base.connection.execute "A bad query"
rescue => ex
puts ex.message
end
puts User.count
end
Run Code Online (Sandbox Code Playgroud)
User.count
引发PG::InFailedSqlTransaction
因为先前的SQL语句引发ActiveRecord::StatementInvalid
而被吞噬了rescue
.
所以我会寻找在事务范围内挽救的代码,然后尝试运行其他SQL语句.
归档时间: |
|
查看次数: |
3386 次 |
最近记录: |