2012-07-16 162 views
5

我有一个自定义宝石,我遇到了一个真正奇怪的LoadError,当我把它作为宝石安装并试图要求它在irb中。自定义红宝石宝石上的奇怪LoadError

一切工作正常与我的rspec测试项目文件夹内。这只在将它用作irb中的实际宝石时才会发生。

它引发LoadError异常的文件(/lib/mws/api/order_response.rb)确实存在。我尝试重命名文件并更新需要它的文件(/lib/mws.rb)。我试过重新创建文件,因为可能存在权限问题。什么都没有

如果我注释掉那个特定文件的require行,一切正常。没有什么特别的文件。还有4个其他文件几乎完全相同(*_response.rb)。

我觉得我正在服用疯狂的药丸。我必须忽略某些东西,但我一定不会看到它。

跟踪:

[email protected]:~$ irb 
1.9.3p194 :001 > require 'mws' 
LoadError: cannot load such file -- mws/api/order_response 
    from /Users/chris/.rvm/rubies/ruby-1.9.3-p194/lib/ruby/site_ruby/1.9.1/rubygems/custom_require.rb:36:in `require' 
    from /Users/chris/.rvm/rubies/ruby-1.9.3-p194/lib/ruby/site_ruby/1.9.1/rubygems/custom_require.rb:36:in `require' 
    from /Users/chris/.rvm/gems/ruby-1.9.3-p194/gems/mws-0.1.18/lib/mws.rb:14:in `<top (required)>' 
    from /Users/chris/.rvm/rubies/ruby-1.9.3-p194/lib/ruby/site_ruby/1.9.1/rubygems/custom_require.rb:60:in `require' 
    from /Users/chris/.rvm/rubies/ruby-1.9.3-p194/lib/ruby/site_ruby/1.9.1/rubygems/custom_require.rb:60:in `rescue in require' 
    from /Users/chris/.rvm/rubies/ruby-1.9.3-p194/lib/ruby/site_ruby/1.9.1/rubygems/custom_require.rb:35:in `require' 
    from (irb):1 
    from /Users/chris/.rvm/rubies/ruby-1.9.3-p194/bin/irb:16:in `<main>' 

文件与要求(/lib/mws.rb

require 'mws/base' 
require 'mws/connection' 
require 'mws/utility' 

require 'mws/api/seller' 
require 'mws/api/product' 
require 'mws/api/order' 
require 'mws/api/report' 

require 'mws/api/general_response' 
require 'mws/api/product_response' 
require 'mws/api/report_response' 
require 'mws/api/seller_response' 
require 'mws/api/order_response' # <--- the offending line 

module MWS 
    # @see Base#initialize MWS::Base for instantiation details. 
    # @return [Base] returns MWS::Base object. 
    def self.new(merchant_id, access_key, secret_key) 
    MWS::Base.new(merchant_id, access_key, secret_key) 
    end 
end 

# The below is for documentation generation purposes. 

# MWS is a wrapper for the Amazon Marketplace Web Service (MWS) API. 
module MWS 
    # API handles all the Amazon MWS API specific stuff. 
    module API 
    end 
    # Utilities contains various functions needed throughout MWS. Utilities is a mixin to multiple classes. 
    module Utilities 
    end 
end 

文件,我需要(/lib/mws/api/order_response.rb):

module MWS 
    module API 

    # Class for parsing Amazon's XML responses into managable objects. 
    class OrderResponse 

     # Include GeneralResponse instance methods as class methods 
     extend GeneralResponse 

    end 
    end 
end 

我的文件结构

enter image description here

回答

2

能应检查/Users/chris/.rvm/gems/ruby-1.9.3-p194/gems/mws-0.1.18/lib/mws/api,如果该文件位于那里(而没有模糊的权限)。

如果不是这种情况,您可能忘记将它添加到您的gemspec中。

如果它在那里,请尝试以绝对路径来请求/加载它(用于调试目的)。

+0

这几乎是答案,但我详细说明了为什么在下面:http://stackoverflow.com/questions/11499140/weird-loaderror-on-custom-ruby-gem/11820819#11820819 – 2012-08-05 23:03:51

4

对于任何有兴趣的人,我使用珠宝商来处理这个宝石。事实证明,珠宝商在构建gemspec时使用你的Git仓库。

如果您尚未将所有必需的文件添加到您的git存储库,则在生成新的gemspec文件时,珠宝商的gemspec rake任务将不包括它们。

+2

哇。这个答案今天帮助了我很多。我以为我疯了或什么。 :) – oesgalha 2014-02-10 12:53:09

+0

很高兴我能帮忙。它也给我一个循环。 – 2014-03-02 22:15:56