在Rails控制台中禁用堆栈跟踪显示

时间:2015-12-04 22:58:12

标签: ruby-on-rails-4 rails-console

有没有办法减少rails控制台中错误报告的详细程度?具体来说,关闭堆栈跟踪显示?它在大多数时候都没有用,当我遇到愚蠢的手指时,这是彻头彻尾的烦恼。

当我输入类似的内容时:

MyModel.vtrsyr

我不需要堆栈跟踪告诉我没有' vtrsyr'方法

1 个答案:

答案 0 :(得分:7)

重要的是rails控制台使用irb,并且可以访问irb配置选项范围

$ rails c
Loading development environment (Rails 4.2.0)
>> conf
=> conf.ap_name="irb"
conf.auto_indent_mode=false
conf.back_trace_limit=16
.
.
.

它是:conf.back_trace_limit。所以:

conf.back_trace_limit = 0

将有效地禁用当前会话的回溯,输出将简洁明了:

>> MyModel.gnu
NoMethodError: undefined method `gnu' for MyModel:Class

>> obj.do_defective_math
ZeroDivisionError: divided by 0

为了使事情更方便,可以在〜/ .irbrc中定义一个函数。类似的东西:

def toggle_trace
  if conf.back_trace_limit > 0
    conf.back_trace_limit = 0
  else
    conf.back_trace_limit = IRB.conf[:BACK_TRACE_LIMIT]
  end
end

可以称为控制台会话,以根据需要禁用或启用后向跟踪