- xml - AJAX/Jquery XML 解析
- 具有多重继承的 XML 模式
- .net - 枚举序列化 Json 与 XML
- XML 简单类型、简单内容、复杂类型、复杂内容
我正在尝试调试一些不起作用的测试,但我遇到了一些问题。我在运行测试并将关键消息输出到日志时跟踪 test.log,但由于所有交织的回调和 Hook ,我不确定来自哪个模型的哪个方法正在调用哪个 SQL :)
我写了一些东西来记录一个方法名:
def log_mname
caller[0]=~/`(.*?)'/ # note the first quote is a backtick
Rails.logger.debug '=' * 80
Rails.logger.debug ">> #{Time.now} - #{$1}"
Rails.logger.debug '=' * 80
end
效果很好,但要求我将 log_mname
添加到模型中的每个方法,这是不现实的。我想要的是向我的 Rails 应用程序添加一个简单的行或 block ,让我基本上可以说“记录所有调用调试日志的方法。”
我尝试在模型的顶部使用 ruby 的 set_trace_func
但它没有用。我也宁愿不必向每个模型添加一些东西,而是向 test/debug.rb 环境文件等添加一些东西。
有什么想法吗?
最佳答案
您所询问的概念称为反射;如果您有兴趣阅读更多相关信息。
为了回答你的问题,__method__
在你想知道它的名称的方法中返回方法名称作为符号
即
$ irb
irb(main):001:0> def qwerty
irb(main):002:1> __method__
irb(main):003:1> end
=> nil
irb(main):004:0> qwerty
=> :qwerty
irb(main):005:0>
这适用于 Ruby 1.8.7
上面是打印方法名
为了动态显示方法调用,我会使用 ActiveSupport 的#constantize 风格与set_trace_func
显示调用跟踪。
# in your test environment initializer file
require 'active_support/inflector/inflections'
MODELS_TO_WATCH = Dir.entries("#{Rails.root}/app/models/").
gsub(".rb", ""). # strip all extensions from filenames
capitalize!. # no reason for the bang, just saving space
# constantize # make "User" string into User model, for e.g.
# if you constantize, remove `to_s` from `classname` in the proc below
# the version that worked for me was without constantizing but I figure both
# variations yield the same result
class_eval do |c| # Replace this with a "class DummyClass" for proper sandboxing
set_trace_func proc { |event, id, classname|
if event == "call" && MODELS_TO_WATCH.include?(classname.to_s)
puts "called #{classname}'s #{id}"
end
}
end
注意!set_trace_func
是一个leech 函数。它会锁定你的 Ruby 进程,直到进程被终止(许多 IRB 的死亡可以证明这一点)。我还没有找到撤消 set_trace_func
的方法。如果没有引入条件,它的打印结果很糟糕;这可能看起来像错误,但实际上不是。
这就是为什么我建议将其放入您的测试初始值设定项中的原因;并且很可能在一个虚拟类中!这样,当您在开发、生产或您设置的任何其他环境中重新启动 Rails 应用程序时,此 hack 不会影响它。
必须在类上下文中对 this 进行评估。我发现如果它是在实例上下文中计算的,因此 instance_eval
,它会打印 Ruby 程序执行过程中发生的每个事件,除了被调用的函数。
关于ruby-on-rails - 按名称记录调试日志中的每个方法调用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12901027/
昨晚我因为这个问题脑子崩溃了。在确保没有来 self 的 eclipse 错误检查的明显错误之后,我开始调试我的程序。顺便说一下,我正在使用 Jre7。无论如何,每次我进入我的类调用(我们称之为“a”
(前言:我对 C/C++ 还很陌生,我真的不知道 native 代码中的调试实际上是如何工作的。) 一些消息来源说 gdb 和 lldb 可以调试 any program compiled to ma
我正在尝试从 Visual Studio 2012 外部调试 T4Scaffolding.Core Nuget 包。我使用的是安装了 Powershell 3.0 的 Powershell ISE,并
如何调试汇编代码?我在 Linux 上使用 gdb。我知道我可以看寄存器。有哪些调试汇编代码的方法? 最佳答案 您当然可以使用 breakpoints就像 C 或任何其他编译语言一样。 This ar
如何在每次通话时打印列表或 haskell 中的内容,例如: funct a list = funct (a + 1) (a : list) print list her
让我用我对 Makefiles 或 make 知之甚少的评论作为这个问题的前缀。 有一个非常大的项目,每晚自动构建。它以 Debug 和 Release 模式构建,Debug 用于 Valgrind
我正在创建一个计算每周工资的程序,那么任何加类工资都是该周正常工资的 1.5 倍。我的代码如下: #include int main() { double payrate; double h
我使用的是 Visual Studio 2010 Express Developer 版本。开发网站。我在我的 .aspx 页面中使用 JavaScript。 如何在 Javascript 中放置断点
我最近开始修补 Project Euler 问题,并尝试用 Javascript 解决它们。这样做我往往会产生许多无限循环,现在我想知道是否有比终止 Firefox 或 Chrome 中的选项卡更好的
有没有办法在程序执行期间生成一个交互式 python 控制台(最好是 iPython)而不暂停主程序并且能够检查和修改程序变量?类似于浏览器为 JavaScript 提供的功能。 我知道 pdb.se
我正在使用 FFmpeg @ Android 并希望能够进入 FFmpeg 代码(Eclipse + Seqouya),同时编译 FFmpeg 我使用 --disable-stripping --en
我从使用互操作调用 win32 api 函数的 .net 进程中得到一个异常。 我有一个调试器,我想查看 LastError 的值。 是否可以从 Visual Studio 调试器中查看 LastEr
我正在尝试通过 VBA 创建一个宏,以在 IE 的多个选项卡中打开一组指定的链接。目前我正在使用下面的代码,如果我试图打开 3 个或更少的选项卡,它大部分时间都可以工作。任何超过 3 的代码都会在“N
好的,这似乎是一个愚蠢的问题,因为 MonoDevelop 越来越成熟,所以我确定我只是想念它,但我环顾四周,所有关于这个主题的问题似乎都是关于远程调试或 Mac 上的调试。 我使用的是 Ubuntu
如何调试 Rscripts是从命令行运行的? 我目前正在使用 getopt传递命令行选项的包,当有错误时,我很难: 看看到底出了什么问题; 在 R 中交互式调试(因为脚本需要命令行选项。) 有没有人有
支持 PDF 和网络上的信息很少。我碰巧在博客中看到一篇文章,提到 $.write() 或 $.writeln() 将向 javascript 控制台写入一个字符串。相当有用。有谁知道这个 $ 对象是
PyCharm 1.5 中是否可以使用 Firefox 和 Chrome 支持的 JavaScript 调试? 如果是这样,它能否与 Python/Django 调试器一起有效运行? 如果没有,有没有
我确定这以前发生在人们身上,某些东西在 Debug模式下工作,你在发布时编译,但有些东西坏了。 这发生在我在嵌入式 XP 环境中工作时,我发现最好的方法确实是编写一个日志文件来确定它会出错的地方。 您
我目前正在为即将到来的项目评估 Flow3。 AOP 模式和依赖注入(inject)将非常适合我们的目的。 现在我想不通的是如何在 Controller Action 中调试一些结果。 public
最初,我有一个包含测试服务器的 Django 应用程序。要调试此设置,我只需添加 import pdb; pdb.set_trace()代码中的任何位置,并且有一个断点将我扔到终端中的交互式调试器中(
我是一名优秀的程序员,十分优秀!