加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

ruby-on-rails – Ruby:查找全局变量的更改位置

发布时间:2020-12-17 02:54:26 所属栏目:百科 来源:网络整理
导读:我的测试中的一些gem将$stdout设置为dev / null.每当$stdout发生变化时,有没有办法引发错误?或者是否有其他方法可以跟踪哪些变化呢? 更新:对于可能有类似问题的任何人 – 问题是安静地和ActiveSupport的silence_stream方法不是线程安全的.在这种情况下,ac
我的测试中的一些gem将$stdout设置为dev / null.每当$stdout发生变化时,有没有办法引发错误?或者是否有其他方法可以跟踪哪些变化呢?

更新:对于可能有类似问题的任何人 – 问题是安静地和ActiveSupport的silence_stream方法不是线程安全的.在这种情况下,activerecord-session_store是违规的gem,见https://github.com/rails/activerecord-session_store/pull/22

解决方法

set_trace_func proc { |event,file,line,id,binding,classname|
  if $stdout != STDOUT
    STDOUT.puts "$stdout changed at #{file}:#{line}"
    exit
  end
}

嗯.我想这实际上是改变之后的行,技术上……如果你关心,你可以记住每个跟踪步骤中的前一个文件/行,然后打印出来.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读