2011-07-25 31 views
2

我在Rails功能测试中使用OAuth签名的请求时遇到了一个问题。Rails功能测试和OAuth参数问题

我很感激帮助,或指向工作示例。

我正尝试使用在oauth gem(0.4.5)中构建的ActionController :: TestRequest覆盖。

我已经试过这个解决方案没有效果:http://d.hatena.ne.jp/falkenhagen/20091110/1257830144

这是我现在在做什么?

require 'oauth/client/action_controller_request' 

我创建了一个方法,这样做登录到我可以传递一个OauthConsumer对象(ActiveRecord)和我的URL参数(用于查询字符串)。

def _do_oauth(consumer, params = {}) 
    c=OAuth::Consumer.new(consumer.consumer_key, consumer.consumer_secret) 
    t=OAuth::AccessToken.new(c) 
    ActionController::TestRequest.use_oauth=true 
    @request.configure_oauth(c, t, params) 
end 

,并在我的测试情况下调用它像这样:

params = { :store => 'foo' } 
_do_oauth(oauth_consumers(:one), params) # currently not working for passing params 
get :index, { :format => :json }.merge(params) 

但它看起来并不像请求是拿起“PARAMS”或正确编码它们。

我得到的(这发生在“获取”线以上)的错误:

ArgumentError: comparison of Array with Array failed 
/home/sp/.rvm/gems/ruby-1.9.2-p180/gems/oauth-0.4.5/lib/oauth/helper.rb:37:in `sort' 
/home/sp/.rvm/gems/ruby-1.9.2-p180/gems/oauth-0.4.5/lib/oauth/helper.rb:37:in `normalize' 
/home/sp/.rvm/gems/ruby-1.9.2-p180/gems/oauth-0.4.5/lib/oauth/request_proxy/base.rb:98:in `normalized_parameters' 
/home/sp/.rvm/gems/ruby-1.9.2-p180/gems/oauth-0.4.5/lib/oauth/request_proxy/base.rb:113:in `signature_base_string' 
/home/sp/.rvm/gems/ruby-1.9.2-p180/gems/oauth-0.4.5/lib/oauth/signature/base.rb:77:in `signature_base_string' 
/home/sp/.rvm/gems/ruby-1.9.2-p180/gems/oauth-0.4.5/lib/oauth/signature/hmac/base.rb:12:in `digest' 
/home/sp/.rvm/gems/ruby-1.9.2-p180/gems/oauth-0.4.5/lib/oauth/signature/base.rb:65:in `signature' 
/home/sp/.rvm/gems/ruby-1.9.2-p180/gems/oauth-0.4.5/lib/oauth/signature.rb:23:in `sign' 
/home/sp/.rvm/gems/ruby-1.9.2-p180/gems/oauth-0.4.5/lib/oauth/client/helper.rb:45:in `signature' 
/home/sp/.rvm/gems/ruby-1.9.2-p180/gems/oauth-0.4.5/lib/oauth/client/helper.rb:75:in `header' 
/home/sp/.rvm/gems/ruby-1.9.2-p180/gems/oauth-0.4.5/lib/oauth/client/action_controller_request.rb:54:in `set_oauth_header' 
/home/sp/.rvm/gems/ruby-1.9.2-p180/gems/oauth-0.4.5/lib/oauth/client/action_controller_request.rb:50:in `apply_oauth!' 
/home/sp/.rvm/gems/ruby-1.9.2-p180/gems/oauth-0.4.5/lib/oauth/client/action_controller_request.rb:14:in `process_with_new_base_test' 
/home/sp/.rvm/gems/ruby-1.9.2-p180/gems/actionpack-3.0.7/lib/action_controller/test_case.rb:412:in `process' 
/home/sp/.rvm/gems/ruby-1.9.2-p180/gems/actionpack-3.0.7/lib/action_controller/test_case.rb:47:in `process' 
/home/sp/.rvm/gems/ruby-1.9.2-p180/gems/actionpack-3.0.7/lib/action_controller/test_case.rb:350:in `get' 
test/functional/deals_controller_test.rb:56:in `block in <class:DealsControllerTest>' 

我假设它的东西做的查询参数不正确编码,或头没有正确格式化。任何帮助(甚至指向可行的示例)都将不胜感激。

我还应该指出,我试图测试的应用程序是一个双腿OAuth提供程序。所以,应用程序只是解析签名并检查消费者密钥/秘密签出。

+0

当params的顺序不正确时,我遇到了问题。也许可以帮助。不知道。 – lzap

+0

是的,我相信可能是这样。我很喜欢看到一个“正确”的方法来做到这一点。 – stuffinq2010

+0

你有没有得到你的规格工作在2腿oauthenticated控制器? – coneybeare

回答

4

这可能不会对最初的问题有帮助,但它可能会节省几分钟。

问题是如果一个散列有符号和字符串键的混合,那么散列上的排序方法就会吓倒。 Oauth在字符串哈希中添加了一些由字符串键入的条目。