ruby - `binding.pry` 导致 `ArgumentError: non-absolute home`
问题描述
在什么情况下,pry可能会因此错误而失败?
ArgumentError: non-absolute home
故障点代码:
puts "ENV['HOME']: #{ENV['HOME']}"
binding.pry
堆栈跟踪:
ENV['HOME']: localhost:3000
rake aborted!
ArgumentError: non-absolute home
/Users/bart_simpson/.rvm/gems/ruby-2.5.1@kewl_project/gems/pry-0.12.2/lib/pry/pry_class.rb:105:in `expand_path'
/Users/bart_simpson/.rvm/gems/ruby-2.5.1@kewl_project/gems/pry-0.12.2/lib/pry/pry_class.rb:105:in `real_path_to'
/Users/bart_simpson/.rvm/gems/ruby-2.5.1@kewl_project/gems/pry-0.12.2/lib/pry/pry_class.rb:100:in `block in rc_files_to_load'
/Users/bart_simpson/.rvm/gems/ruby-2.5.1@kewl_project/gems/pry-0.12.2/lib/pry/pry_class.rb:100:in `map'
/Users/bart_simpson/.rvm/gems/ruby-2.5.1@kewl_project/gems/pry-0.12.2/lib/pry/pry_class.rb:100:in `rc_files_to_load'
/Users/bart_simpson/.rvm/gems/ruby-2.5.1@kewl_project/gems/pry-0.12.2/lib/pry/pry_class.rb:88:in `load_rc_files'
/Users/bart_simpson/.rvm/gems/ruby-2.5.1@kewl_project/gems/pry-0.12.2/lib/pry/pry_class.rb:148:in `initial_session_setup'
/Users/bart_simpson/.rvm/gems/ruby-2.5.1@kewl_project/gems/pry-0.12.2/lib/pry/pry_class.rb:184:in `start'
/Users/bart_simpson/.rvm/gems/ruby-2.5.1@kewl_project/gems/pry-0.12.2/lib/pry/core_extensions.rb:43:in `pry'
/Users/bart_simpson/Projects/kewl_project/kewl_project/lib/tasks/kewl_project_tasks_helper.rb:104:in `block in import_energy_storage_facilities_from_state_task2'
/Users/bart_simpson/.rvm/rubies/ruby-2.5.1/lib/ruby/2.5.0/csv.rb:1764:in `each'
/Users/bart_simpson/.rvm/rubies/ruby-2.5.1/lib/ruby/2.5.0/csv.rb:1142:in `block in foreach'
/Users/bart_simpson/.rvm/rubies/ruby-2.5.1/lib/ruby/2.5.0/csv.rb:1289:in `open'
/Users/bart_simpson/.rvm/rubies/ruby-2.5.1/lib/ruby/2.5.0/csv.rb:1141:in `foreach'
/Users/bart_simpson/Projects/kewl_project/kewl_project/lib/tasks/kewl_project_tasks_helper.rb:100:in `import_energy_storage_facilities_from_state_task2'
/Users/bart_simpson/Projects/kewl_project/kewl_project/lib/tasks/kewl_project_tasks_helper.rb:69:in `import_energy_storage_facilities_via_state_task'
/Users/bart_simpson/Projects/kewl_project/kewl_project/lib/tasks/kewl_project.rake:215:in `block (2 levels) in <main>'
/Users/bart_simpson/.rvm/gems/ruby-2.5.1@kewl_project/gems/rake-12.3.2/lib/rake/task.rb:273:in `block in execute'
/Users/bart_simpson/.rvm/gems/ruby-2.5.1@kewl_project/gems/rake-12.3.2/lib/rake/task.rb:273:in `each'
/Users/bart_simpson/.rvm/gems/ruby-2.5.1@kewl_project/gems/rake-12.3.2/lib/rake/task.rb:273:in `execute'
/Users/bart_simpson/.rvm/gems/ruby-2.5.1@kewl_project/gems/rake-12.3.2/lib/rake/task.rb:214:in `block in invoke_with_call_chain'
/Users/bart_simpson/.rvm/rubies/ruby-2.5.1/lib/ruby/2.5.0/monitor.rb:226:in `mon_synchronize'
/Users/bart_simpson/.rvm/gems/ruby-2.5.1@kewl_project/gems/rake-12.3.2/lib/rake/task.rb:194:in `invoke_with_call_chain'
/Users/bart_simpson/.rvm/gems/ruby-2.5.1@kewl_project/gems/rake-12.3.2/lib/rake/task.rb:183:in `invoke'
/Users/bart_simpson/.rvm/gems/ruby-2.5.1@kewl_project/gems/rake-12.3.2/lib/rake/application.rb:160:in `invoke_task'
/Users/bart_simpson/.rvm/gems/ruby-2.5.1@kewl_project/gems/rake-12.3.2/lib/rake/application.rb:116:in `block (2 levels) in top_level'
/Users/bart_simpson/.rvm/gems/ruby-2.5.1@kewl_project/gems/rake-12.3.2/lib/rake/application.rb:116:in `each'
/Users/bart_simpson/.rvm/gems/ruby-2.5.1@kewl_project/gems/rake-12.3.2/lib/rake/application.rb:116:in `block in top_level'
/Users/bart_simpson/.rvm/gems/ruby-2.5.1@kewl_project/gems/rake-12.3.2/lib/rake/application.rb:125:in `run_with_threads'
/Users/bart_simpson/.rvm/gems/ruby-2.5.1@kewl_project/gems/rake-12.3.2/lib/rake/application.rb:110:in `top_level'
/Users/bart_simpson/.rvm/gems/ruby-2.5.1@kewl_project/gems/rake-12.3.2/lib/rake/application.rb:83:in `block in run'
/Users/bart_simpson/.rvm/gems/ruby-2.5.1@kewl_project/gems/rake-12.3.2/lib/rake/application.rb:186:in `standard_exception_handling'
/Users/bart_simpson/.rvm/gems/ruby-2.5.1@kewl_project/gems/rake-12.3.2/lib/rake/application.rb:80:in `run'
/Users/bart_simpson/.rvm/gems/ruby-2.5.1@kewl_project/gems/rake-12.3.2/exe/rake:27:in `<top (required)>'
/Users/bart_simpson/.rvm/gems/ruby-2.5.1@kewl_project/bin/rake:23:in `load'
/Users/bart_simpson/.rvm/gems/ruby-2.5.1@kewl_project/bin/rake:23:in `<main>'
/Users/bart_simpson/.rvm/gems/ruby-2.5.1@kewl_project/bin/ruby_executable_hooks:24:in `eval'
/Users/bart_simpson/.rvm/gems/ruby-2.5.1@kewl_project/bin/ruby_executable_hooks:24:in `<main>'
Tasks: TOP => kewl_project:import_energy_storage_facilities
更新
我发现如果我在模块顶部binding.pry
之后立即发出require 'pry'
(即不在方法内但在任何方法范围之外),那么它可以工作并且ENV['HOME']
是我们所期望的:
/Users/bart_simpson
所以现在的问题是:在哪里ENV['HOME']
得到改变localhost:3000
??
解决方案
ENV['HOME']
被覆盖。
有人添加ENV['HOME']='localhost:3000'
到我们的应用程序环境变量中。坏的!
很抱歉浪费了大家的时间!
推荐阅读
- r - 无法弄清楚为什么正则表达式组在 str_match 中不起作用
- regex - JMeter 中的正则表达式
- python - 如何加快 AWS Transcribe 的处理时间?
- python - 使用 Beautiful soup 抓取数据后如何注入弹性搜索
- machine-learning - 使用随机训练/测试集进行分类的模型选择
- python - 无法使用 pyuic4 命令将 .ui 转换为 .py
- java - java.lang.OutOfMemoryError: Java heap space error,while parsing 5mb data through Stax parser in intellij idea
- arrays - 使用 jq 将带有数组的 tsv 转换为 JSON
- artifactory - 无法使用 jfrog cli 从工件下载符号链接
- c# - MVC 将值/参数从控制器传递到视图