【问题标题】:How to correctly set up Pry in Rails 4.2如何在 Rails 4.2 中正确设置 Pry
【发布时间】:2015-11-01 11:05:45
【问题描述】:

我对需要安装哪些 gem 才能在 Rails 4.2 项目中正确运行 Pry 感到困惑。直到最近我似乎都过得很好。出于某种原因,每当我尝试在命令行中使用nextstep 等单步执行控制台会话时,binding.pry 现在似乎会吐出来。它会抛出一个丑陋的堆栈跟踪,然后在代码中显示相同的点,而无需进一步。在第二个next 命令之后,它会抛出相同的堆栈跟踪并退出,将执行返回到本地主机服务器。我在带有No frames collected 的浏览器页面上收到运行时错误。

如果我在代码中注释掉 binding.pry,一切正常。所以我强烈怀疑我的 Pry 配置有问题。似乎有几十种 Pry 变体,没有明确的指导说明应该安装哪些,哪些可能会发生冲突等。

这是我在代码到达binding.pry 调用后在 Pry 控制台中调用 next 时得到的堆栈跟踪:

From: /Users/me/sites/arailsapp/app/controllers/bars_controller.rb @ line 31 BarsController#edit:

    29: def edit
    30:   binding.pry
 => 31:   @bar = Bar.find(params[:id])
    32:   @foo = @bar.foo
    33: end

[6] pry(#<BarsController>)> n
Completed 500 Internal Server Error in 2685ms (ActiveRecord: 0.0ms)

RuntimeError - No frames collected.:
  pry-byebug (3.2.0) lib/byebug/processors/pry_processor.rb:122:in `perform_next'
  pry-byebug (3.2.0) lib/byebug/processors/pry_processor.rb:60:in `perform'
  pry-byebug (3.2.0) lib/byebug/processors/pry_processor.rb:49:in `run'
  pry-byebug (3.2.0) lib/byebug/processors/pry_processor.rb:111:in `resume_pry'
  pry-byebug (3.2.0) lib/byebug/processors/pry_processor.rb:69:in `at_line'
  byebug (5.0.0) lib/byebug/context.rb:90:in `at_line'
  app/controllers/scholarships_controller.rb:31:in `edit'
  actionpack (4.2.1) lib/action_controller/metal/implicit_render.rb:4:in `send_action'
  actionpack (4.2.1) lib/abstract_controller/base.rb:198:in `process_action'
  actionpack (4.2.1) lib/action_controller/metal/rendering.rb:10:in `process_action'
  actionpack (4.2.1) lib/abstract_controller/callbacks.rb:20:in `block in process_action'
  activesupport (4.2.1) lib/active_support/callbacks.rb:117:in `call'

  # omitting the next ~40 lines in the Rails stack...

第二节看起来和第一节一样——此时执行返回到服务器。

这是我的 Gemfile:

source 'https://rubygems.org'

ruby '2.2.0'

gem 'rails', '4.2.1'
gem 'pg', '~> 0.18.2'
gem 'haml-rails', '~> 0.9.0'
gem 'sass-rails', '~> 5.0'
gem 'jquery-rails'
gem 'turbolinks'
gem 'jbuilder', '~> 2.0'
gem 'sdoc', '~> 0.4.0', group: :doc
gem 'will_paginate', '~> 3.0.7'
gem 'will_paginate-bootstrap'
gem "nilify_blanks"
gem 'filterrific', '~> 2.0.5'
gem 'chardinjs-rails'

# Install bootstrap and associated gems
gem 'bootstrap-sass', '~> 3.3.4.1'
gem 'autoprefixer-rails', '~> 5.2.0'

# Use ActiveModel has_secure_password
gem 'bcrypt', '~> 3.1.7'

group :production do
  gem 'rails_12factor', '~> 0.0.3'
end

group :assets do
  gem 'uglifier', '>= 1.3.0'
  gem 'coffee-rails', '~> 4.1.0'
end

group :development do
  gem 'better_errors', '~> 2.1.1'
  gem 'annotate', '~> 2.6.10'
end

group :development, :test do
  gem 'pry-rails'
  gem 'pry-stack_explorer'      
  gem 'pry-byebug'
  gem 'web-console', '~> 2.0'
  gem 'spring'
  gem 'spring-commands-rspec', '~> 1.0.4'
  gem 'rspec-rails', '~> 3.2.3'
  gem 'guard-rspec', '~> 4.6.0'
  gem 'sqlite3'
  gem 'factory_girl_rails', '~> 4.5.0', require: false
end

group :test do
  gem 'database_cleaner', '~> 1.4.1'
  gem 'faker', '~> 1.4.3'
  gem 'capybara', '~> 2.4.4'
  gem 'launchy', '~> 2.4.3'
  gem 'shoulda', '~> 3.5.0'
end

我也尝试过将 pry-stack_explorerpry-byebug gems 注释掉...没有区别。

最后,我的 .pryrc 文件:

# ~/.pryrc
if defined?(PryByebug)
  Pry.commands.alias_command 'c', 'continue'
  Pry.commands.alias_command 's', 'step'
  Pry.commands.alias_command 'n', 'next'
  Pry.commands.alias_command 'f', 'finish'
end

# Hit Enter to repeat last command
Pry::Commands.command /^$/, "repeat last command" do
  _pry_.run_command Pry.history.to_a.last
end

【问题讨论】:

  • 我只使用撬轨。有时我将它与 byebug(不是 pry-byebug)一起使用。也许从一个开始,并确保在更新时捆绑。这些 gem 有时会引发兔子洞错误,因此如果您不相信 pry 报告的内容,请添加一些日志记录。
  • 首先,从您的 Gemfile 中删除 pry-stack_explorer 并重新捆绑。该 gem 与 pry-byebug 不兼容,pry-byebug 提供相同的功能,因此没有必要。
  • @deivid 抱歉,也许我很困惑,但是 pry-byebug 提供的与 show-stack 等效的功能是什么?我看不到任何显示当前堆栈的能力。 “pry-backtrace”很接近,但是内部的pry方法很混乱。
  • 嘿,你是对的。我们有命令来上下移动堆栈,但不能显示它。不过,您可以使用 Ruby,Thread.current.backtrace_locations

标签: debugging ruby-on-rails-4.2 pry pry-rails


【解决方案1】:

一些摆弄和几次服务器重启似乎已经解决了这个问题。感谢 Deivid 建议删除 pry-stack_explorer。这是测试和开发组的 Gemfile:

group :development do
  gem 'better_errors', '~> 2.1.1'
  gem 'annotate', '~> 2.6.10'
end

group :development, :test do
  gem 'pry-rails'
  gem 'pry-byebug'
  gem 'web-console', '~> 2.0'
  gem 'spring'
  gem 'spring-commands-rspec', '~> 1.0.4'
  gem 'rspec-rails', '~> 3.2.3'
  gem 'guard-rspec', '~> 4.6.0'
  gem 'sqlite3'
  gem 'factory_girl_rails', '~> 4.5.0', require: false
end

group :test do
  gem 'database_cleaner', '~> 1.4.1'
  gem 'faker', '~> 1.4.3'
  gem 'capybara', '~> 2.4.4'
  gem 'launchy', '~> 2.4.3'
  gem 'shoulda', '~> 3.5.0'
end

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 2012-06-03
    • 1970-01-01
    • 2014-06-24
    • 2021-11-16
    • 2014-11-10
    • 2023-03-15
    • 2017-09-06
    相关资源
    最近更新 更多