motionbox-oauth 0.4.5

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (88) hide show
  1. data/.gemtest +0 -0
  2. data/Gemfile +16 -0
  3. data/Gemfile.lock +46 -0
  4. data/HISTORY +160 -0
  5. data/LICENSE +20 -0
  6. data/README.rdoc +75 -0
  7. data/Rakefile +37 -0
  8. data/TODO +32 -0
  9. data/bin/oauth +5 -0
  10. data/examples/yql.rb +44 -0
  11. data/lib/digest/hmac.rb +104 -0
  12. data/lib/oauth.rb +13 -0
  13. data/lib/oauth/cli.rb +378 -0
  14. data/lib/oauth/client.rb +4 -0
  15. data/lib/oauth/client/action_controller_request.rb +65 -0
  16. data/lib/oauth/client/em_http.rb +124 -0
  17. data/lib/oauth/client/helper.rb +91 -0
  18. data/lib/oauth/client/net_http.rb +120 -0
  19. data/lib/oauth/consumer.rb +382 -0
  20. data/lib/oauth/core_ext.rb +31 -0
  21. data/lib/oauth/errors.rb +3 -0
  22. data/lib/oauth/errors/error.rb +4 -0
  23. data/lib/oauth/errors/problem.rb +14 -0
  24. data/lib/oauth/errors/unauthorized.rb +12 -0
  25. data/lib/oauth/helper.rb +88 -0
  26. data/lib/oauth/oauth.rb +13 -0
  27. data/lib/oauth/oauth_test_helper.rb +25 -0
  28. data/lib/oauth/request_proxy.rb +24 -0
  29. data/lib/oauth/request_proxy/action_controller_request.rb +62 -0
  30. data/lib/oauth/request_proxy/base.rb +174 -0
  31. data/lib/oauth/request_proxy/curb_request.rb +55 -0
  32. data/lib/oauth/request_proxy/em_http_request.rb +74 -0
  33. data/lib/oauth/request_proxy/jabber_request.rb +41 -0
  34. data/lib/oauth/request_proxy/mock_request.rb +44 -0
  35. data/lib/oauth/request_proxy/net_http.rb +72 -0
  36. data/lib/oauth/request_proxy/rack_request.rb +44 -0
  37. data/lib/oauth/request_proxy/typhoeus_request.rb +53 -0
  38. data/lib/oauth/server.rb +66 -0
  39. data/lib/oauth/signature.rb +45 -0
  40. data/lib/oauth/signature/base.rb +110 -0
  41. data/lib/oauth/signature/hmac/base.rb +15 -0
  42. data/lib/oauth/signature/hmac/md5.rb +8 -0
  43. data/lib/oauth/signature/hmac/rmd160.rb +8 -0
  44. data/lib/oauth/signature/hmac/sha1.rb +9 -0
  45. data/lib/oauth/signature/hmac/sha2.rb +8 -0
  46. data/lib/oauth/signature/md5.rb +13 -0
  47. data/lib/oauth/signature/plaintext.rb +23 -0
  48. data/lib/oauth/signature/rsa/sha1.rb +46 -0
  49. data/lib/oauth/signature/sha1.rb +13 -0
  50. data/lib/oauth/token.rb +7 -0
  51. data/lib/oauth/tokens/access_token.rb +71 -0
  52. data/lib/oauth/tokens/consumer_token.rb +33 -0
  53. data/lib/oauth/tokens/request_token.rb +32 -0
  54. data/lib/oauth/tokens/server_token.rb +9 -0
  55. data/lib/oauth/tokens/token.rb +17 -0
  56. data/oauth.gemspec +150 -0
  57. data/tasks/deployment.rake +34 -0
  58. data/tasks/environment.rake +7 -0
  59. data/tasks/website.rake +17 -0
  60. data/test/cases/oauth_case.rb +19 -0
  61. data/test/cases/spec/1_0-final/test_construct_request_url.rb +62 -0
  62. data/test/cases/spec/1_0-final/test_normalize_request_parameters.rb +88 -0
  63. data/test/cases/spec/1_0-final/test_parameter_encodings.rb +86 -0
  64. data/test/cases/spec/1_0-final/test_signature_base_strings.rb +77 -0
  65. data/test/integration/consumer_test.rb +307 -0
  66. data/test/keys/rsa.cert +11 -0
  67. data/test/keys/rsa.pem +16 -0
  68. data/test/test_access_token.rb +26 -0
  69. data/test/test_action_controller_request_proxy.rb +133 -0
  70. data/test/test_consumer.rb +171 -0
  71. data/test/test_curb_request_proxy.rb +77 -0
  72. data/test/test_em_http_client.rb +80 -0
  73. data/test/test_em_http_request_proxy.rb +115 -0
  74. data/test/test_helper.rb +26 -0
  75. data/test/test_hmac_sha1.rb +20 -0
  76. data/test/test_net_http_client.rb +280 -0
  77. data/test/test_net_http_request_proxy.rb +72 -0
  78. data/test/test_oauth_helper.rb +71 -0
  79. data/test/test_rack_request_proxy.rb +40 -0
  80. data/test/test_request_token.rb +51 -0
  81. data/test/test_rsa_sha1.rb +59 -0
  82. data/test/test_server.rb +40 -0
  83. data/test/test_signature.rb +22 -0
  84. data/test/test_signature_base.rb +32 -0
  85. data/test/test_signature_plain_text.rb +31 -0
  86. data/test/test_token.rb +14 -0
  87. data/test/test_typhoeus_request_proxy.rb +80 -0
  88. metadata +284 -0
@@ -0,0 +1,20 @@
1
+ require File.expand_path('../test_helper', __FILE__)
2
+
3
+ class TestSignatureHmacSha1 < Test::Unit::TestCase
4
+ def test_that_hmac_sha1_implements_hmac_sha1
5
+ assert OAuth::Signature.available_methods.include?('hmac-sha1')
6
+ end
7
+
8
+ def test_that_get_request_from_oauth_test_cases_produces_matching_signature
9
+ request = Net::HTTP::Get.new('/photos?file=vacation.jpg&size=original&oauth_version=1.0&oauth_consumer_key=dpf43f3p2l4k3l03&oauth_token=nnch734d00sl2jdk&oauth_timestamp=1191242096&oauth_nonce=kllo9940pd9333jh&oauth_signature_method=HMAC-SHA1')
10
+
11
+ consumer = OAuth::Consumer.new('dpf43f3p2l4k3l03', 'kd94hf93k423kf44')
12
+ token = OAuth::Token.new('nnch734d00sl2jdk', 'pfkkdhi9sl3r4s00')
13
+
14
+ signature = OAuth::Signature.sign(request, { :consumer => consumer,
15
+ :token => token,
16
+ :uri => 'http://photos.example.net/photos' } )
17
+
18
+ assert_equal 'tR3+Ty81lMeYAr/Fid0kMTYa/WM=', signature
19
+ end
20
+ end
@@ -0,0 +1,280 @@
1
+ require File.expand_path('../test_helper', __FILE__)
2
+
3
+ class NetHTTPClientTest < Test::Unit::TestCase
4
+
5
+ def setup
6
+ @consumer = OAuth::Consumer.new('consumer_key_86cad9', '5888bf0345e5d237')
7
+ @token = OAuth::Token.new('token_411a7f', '3196ffd991c8ebdb')
8
+ @request_uri = URI.parse('http://example.com/test?key=value')
9
+ @request_parameters = { 'key' => 'value' }
10
+ @nonce = 225579211881198842005988698334675835446
11
+ @timestamp = "1199645624"
12
+ @http = Net::HTTP.new(@request_uri.host, @request_uri.port)
13
+ end
14
+
15
+ def test_that_using_auth_headers_on_get_requests_works
16
+ request = Net::HTTP::Get.new(@request_uri.path + "?" + request_parameters_to_s)
17
+ request.oauth!(@http, @consumer, @token, {:nonce => @nonce, :timestamp => @timestamp})
18
+
19
+ assert_equal 'GET', request.method
20
+ assert_equal '/test?key=value', request.path
21
+ correct_sorted_params = "oauth_nonce=\"225579211881198842005988698334675835446\", oauth_signature_method=\"HMAC-SHA1\", oauth_token=\"token_411a7f\", oauth_timestamp=\"1199645624\", oauth_consumer_key=\"consumer_key_86cad9\", oauth_signature=\"1oO2izFav1GP4kEH2EskwXkCRFg%3D\", oauth_version=\"1.0\""
22
+ auth_intro, auth_params = request['authorization'].split(' ', 2)
23
+ assert_equal auth_intro, 'OAuth'
24
+ assert_matching_headers correct_sorted_params, request['authorization']
25
+ end
26
+
27
+ def test_that_using_auth_headers_on_get_requests_works_with_plaintext
28
+ require 'oauth/signature/plaintext'
29
+ c = OAuth::Consumer.new('consumer_key_86cad9', '5888bf0345e5d237',{
30
+ :signature_method => 'PLAINTEXT'
31
+ })
32
+ request = Net::HTTP::Get.new(@request_uri.path + "?" + request_parameters_to_s)
33
+ request.oauth!(@http, c, @token, {:nonce => @nonce, :timestamp => @timestamp, :signature_method => 'PLAINTEXT'})
34
+
35
+ assert_equal 'GET', request.method
36
+ assert_equal '/test?key=value', request.path
37
+ assert_matching_headers "oauth_nonce=\"225579211881198842005988698334675835446\", oauth_signature_method=\"PLAINTEXT\", oauth_token=\"token_411a7f\", oauth_timestamp=\"1199645624\", oauth_consumer_key=\"consumer_key_86cad9\", oauth_signature=\"5888bf0345e5d237%263196ffd991c8ebdb\", oauth_version=\"1.0\"", request['authorization']
38
+ end
39
+
40
+ def test_that_using_auth_headers_on_post_requests_works
41
+ request = Net::HTTP::Post.new(@request_uri.path)
42
+ request.set_form_data( @request_parameters )
43
+ request.oauth!(@http, @consumer, @token, {:nonce => @nonce, :timestamp => @timestamp})
44
+
45
+ assert_equal 'POST', request.method
46
+ assert_equal '/test', request.path
47
+ assert_equal 'key=value', request.body
48
+ correct_sorted_params = "oauth_nonce=\"225579211881198842005988698334675835446\", oauth_signature_method=\"HMAC-SHA1\", oauth_token=\"token_411a7f\", oauth_timestamp=\"1199645624\", oauth_consumer_key=\"consumer_key_86cad9\", oauth_signature=\"26g7wHTtNO6ZWJaLltcueppHYiI%3D\", oauth_version=\"1.0\""
49
+ assert_matching_headers correct_sorted_params, request['authorization']
50
+ end
51
+
52
+ def test_that_using_auth_headers_on_post_requests_with_data_works
53
+ request = Net::HTTP::Post.new(@request_uri.path)
54
+ request.body = "data"
55
+ request.content_type = 'text/ascii'
56
+ request.oauth!(@http, @consumer, @token, {:nonce => @nonce, :timestamp => @timestamp})
57
+
58
+ assert_equal 'POST', request.method
59
+ assert_equal '/test', request.path
60
+ assert_equal 'data', request.body
61
+ assert_equal 'text/ascii', request.content_type
62
+ assert_matching_headers "oauth_nonce=\"225579211881198842005988698334675835446\", oauth_body_hash=\"oXyaqmHoChv3HQ2FCvTluqmAC70%3D\", oauth_signature_method=\"HMAC-SHA1\", oauth_token=\"token_411a7f\", oauth_timestamp=\"1199645624\", oauth_consumer_key=\"consumer_key_86cad9\", oauth_signature=\"0DA6pGTapdHSqC15RZelY5rNLDw%3D\", oauth_version=\"1.0\"", request['authorization']
63
+ end
64
+
65
+ def test_that_body_hash_is_obmitted_when_no_algorithm_is_defined
66
+ request = Net::HTTP::Post.new(@request_uri.path)
67
+ request.body = "data"
68
+ request.content_type = 'text/ascii'
69
+ request.oauth!(@http, @consumer, @token, {:nonce => @nonce, :timestamp => @timestamp, :signature_method => 'plaintext'})
70
+
71
+ assert_equal 'POST', request.method
72
+ assert_equal '/test', request.path
73
+ assert_equal 'data', request.body
74
+ assert_equal 'text/ascii', request.content_type
75
+ assert_matching_headers "oauth_nonce=\"225579211881198842005988698334675835446\", oauth_signature_method=\"plaintext\", oauth_token=\"token_411a7f\", oauth_timestamp=\"1199645624\", oauth_consumer_key=\"consumer_key_86cad9\", oauth_signature=\"5888bf0345e5d237%263196ffd991c8ebdb\", oauth_version=\"1.0\"", request['authorization']
76
+ end
77
+
78
+ def test_that_version_is_added_to_existing_user_agent
79
+ request = Net::HTTP::Post.new(@request_uri.path)
80
+ request['User-Agent'] = "MyApp"
81
+ request.set_form_data( @request_parameters )
82
+ request.oauth!(@http, @consumer, @token, {:nonce => @nonce, :timestamp => @timestamp})
83
+
84
+ assert_equal "MyApp (OAuth gem v#{OAuth::VERSION})", request['User-Agent']
85
+ end
86
+
87
+ def test_that_version_is_set_when_no_user_agent
88
+ request = Net::HTTP::Post.new(@request_uri.path)
89
+ request.set_form_data( @request_parameters )
90
+ request.oauth!(@http, @consumer, @token, {:nonce => @nonce, :timestamp => @timestamp})
91
+
92
+ assert_equal "OAuth gem v#{OAuth::VERSION}", request['User-Agent']
93
+ end
94
+
95
+ def test_that_using_get_params_works
96
+ request = Net::HTTP::Get.new(@request_uri.path + "?" + request_parameters_to_s)
97
+ request.oauth!(@http, @consumer, @token, {:scheme => 'query_string', :nonce => @nonce, :timestamp => @timestamp})
98
+
99
+ assert_equal 'GET', request.method
100
+ uri = URI.parse(request.path)
101
+ assert_equal '/test', uri.path
102
+ assert_equal nil, uri.fragment
103
+ assert_equal "key=value&oauth_consumer_key=consumer_key_86cad9&oauth_nonce=225579211881198842005988698334675835446&oauth_signature=1oO2izFav1GP4kEH2EskwXkCRFg%3D&oauth_signature_method=HMAC-SHA1&oauth_timestamp=1199645624&oauth_token=token_411a7f&oauth_version=1.0", uri.query.split("&").sort.join("&")
104
+ assert_equal nil, request['authorization']
105
+ end
106
+
107
+ def test_that_using_get_params_works_with_plaintext
108
+ request = Net::HTTP::Get.new(@request_uri.path + "?" + request_parameters_to_s)
109
+ request.oauth!(@http, @consumer, @token, {:scheme => 'query_string', :nonce => @nonce, :timestamp => @timestamp, :signature_method => 'PLAINTEXT'})
110
+
111
+ assert_equal 'GET', request.method
112
+ uri = URI.parse(request.path)
113
+ assert_equal '/test', uri.path
114
+ assert_equal nil, uri.fragment
115
+ assert_equal "key=value&oauth_consumer_key=consumer_key_86cad9&oauth_nonce=225579211881198842005988698334675835446&oauth_signature=5888bf0345e5d237%263196ffd991c8ebdb&oauth_signature_method=PLAINTEXT&oauth_timestamp=1199645624&oauth_token=token_411a7f&oauth_version=1.0", uri.query.split("&").sort.join("&")
116
+ assert_equal nil, request['authorization']
117
+ end
118
+
119
+ def test_that_using_post_params_works
120
+ request = Net::HTTP::Post.new(@request_uri.path)
121
+ request.set_form_data( @request_parameters )
122
+ request.oauth!(@http, @consumer, @token, {:scheme => 'body', :nonce => @nonce, :timestamp => @timestamp})
123
+
124
+ assert_equal 'POST', request.method
125
+ assert_equal '/test', request.path
126
+ assert_equal "key=value&oauth_consumer_key=consumer_key_86cad9&oauth_nonce=225579211881198842005988698334675835446&oauth_signature=26g7wHTtNO6ZWJaLltcueppHYiI%3d&oauth_signature_method=HMAC-SHA1&oauth_timestamp=1199645624&oauth_token=token_411a7f&oauth_version=1.0", request.body.split("&").sort.join("&")
127
+ assert_equal nil, request['authorization']
128
+ end
129
+
130
+ def test_that_using_post_params_works_with_plaintext
131
+ request = Net::HTTP::Post.new(@request_uri.path)
132
+ request.set_form_data( @request_parameters )
133
+ request.oauth!(@http, @consumer, @token, {:scheme => 'body', :nonce => @nonce, :timestamp => @timestamp, :signature_method => 'PLAINTEXT'})
134
+
135
+ assert_equal 'POST', request.method
136
+ assert_equal '/test', request.path
137
+ assert_equal "key=value&oauth_consumer_key=consumer_key_86cad9&oauth_nonce=225579211881198842005988698334675835446&oauth_signature=5888bf0345e5d237%263196ffd991c8ebdb&oauth_signature_method=PLAINTEXT&oauth_timestamp=1199645624&oauth_token=token_411a7f&oauth_version=1.0", request.body.split("&").sort.join("&")
138
+ assert_equal nil, request['authorization']
139
+ end
140
+
141
+ def test_that_using_post_with_uri_params_works
142
+ request = Net::HTTP::Post.new(@request_uri.path + "?" + request_parameters_to_s)
143
+ request.set_form_data( {} ) # just to make sure we have a correct mime type and thus no body hash
144
+ request.oauth!(@http, @consumer, @token, {:scheme => 'query_string', :nonce => @nonce, :timestamp => @timestamp})
145
+
146
+ assert_equal 'POST', request.method
147
+ uri = URI.parse(request.path)
148
+ assert_equal '/test', uri.path
149
+ assert_equal nil, uri.fragment
150
+ assert_equal "key=value&oauth_consumer_key=consumer_key_86cad9&oauth_nonce=225579211881198842005988698334675835446&oauth_signature=26g7wHTtNO6ZWJaLltcueppHYiI%3D&oauth_signature_method=HMAC-SHA1&oauth_timestamp=1199645624&oauth_token=token_411a7f&oauth_version=1.0", uri.query.split("&").sort.join('&')
151
+ assert_equal "", request.body
152
+ assert_equal nil, request['authorization']
153
+ end
154
+
155
+ def test_that_using_post_with_uri_and_form_params_works
156
+ request = Net::HTTP::Post.new(@request_uri.path + "?" + request_parameters_to_s)
157
+ request.set_form_data( { 'key2' => 'value2' } )
158
+ request.oauth!(@http, @consumer, @token, {:scheme => :query_string, :nonce => @nonce, :timestamp => @timestamp})
159
+
160
+ assert_equal 'POST', request.method
161
+ uri = URI.parse(request.path)
162
+ assert_equal '/test', uri.path
163
+ assert_equal nil, uri.fragment
164
+ assert_equal "key=value&oauth_consumer_key=consumer_key_86cad9&oauth_nonce=225579211881198842005988698334675835446&oauth_signature=4kSU8Zd1blWo3W6qJH7eaRTMkg0%3D&oauth_signature_method=HMAC-SHA1&oauth_timestamp=1199645624&oauth_token=token_411a7f&oauth_version=1.0", uri.query.split("&").sort.join('&')
165
+ assert_equal "key2=value2", request.body
166
+ assert_equal nil, request['authorization']
167
+ end
168
+
169
+ def test_that_using_post_with_uri_and_data_works
170
+ request = Net::HTTP::Post.new(@request_uri.path + "?" + request_parameters_to_s)
171
+ request.body = "data"
172
+ request.content_type = 'text/ascii'
173
+ request.oauth!(@http, @consumer, @token, {:scheme => :query_string, :nonce => @nonce, :timestamp => @timestamp})
174
+
175
+ assert_equal 'POST', request.method
176
+ uri = URI.parse(request.path)
177
+ assert_equal '/test', uri.path
178
+ assert_equal nil, uri.fragment
179
+ assert_equal "data", request.body
180
+ assert_equal 'text/ascii', request.content_type
181
+ assert_equal "key=value&oauth_body_hash=oXyaqmHoChv3HQ2FCvTluqmAC70%3D&oauth_consumer_key=consumer_key_86cad9&oauth_nonce=225579211881198842005988698334675835446&oauth_signature=MHRKU42iVHU4Ke9kBUDa9Zw6IAM%3D&oauth_signature_method=HMAC-SHA1&oauth_timestamp=1199645624&oauth_token=token_411a7f&oauth_version=1.0", uri.query.split("&").sort.join('&')
182
+ assert_equal nil, request['authorization']
183
+ end
184
+
185
+
186
+ def test_example_from_specs
187
+ consumer=OAuth::Consumer.new("dpf43f3p2l4k3l03","kd94hf93k423kf44")
188
+ token = OAuth::Token.new('nnch734d00sl2jdk', 'pfkkdhi9sl3r4s00')
189
+ request_uri = URI.parse('http://photos.example.net/photos?file=vacation.jpg&size=original')
190
+ nonce = 'kllo9940pd9333jh'
191
+ timestamp = "1191242096"
192
+ http = Net::HTTP.new(request_uri.host, request_uri.port)
193
+
194
+ request = Net::HTTP::Get.new(request_uri.path + "?" + request_uri.query)
195
+ signature_base_string=request.signature_base_string(http, consumer, token, {:nonce => nonce, :timestamp => timestamp})
196
+ assert_equal 'GET&http%3A%2F%2Fphotos.example.net%2Fphotos&file%3Dvacation.jpg%26oauth_consumer_key%3Ddpf43f3p2l4k3l03%26oauth_nonce%3Dkllo9940pd9333jh%26oauth_signature_method%3DHMAC-SHA1%26oauth_timestamp%3D1191242096%26oauth_token%3Dnnch734d00sl2jdk%26oauth_version%3D1.0%26size%3Doriginal',signature_base_string
197
+
198
+ # request = Net::HTTP::Get.new(request_uri.path + "?" + request_uri.query)
199
+ request.oauth!(http, consumer, token, {:nonce => nonce, :timestamp => timestamp, :realm=>"http://photos.example.net/"})
200
+
201
+ assert_equal 'GET', request.method
202
+ correct_sorted_params = 'oauth_nonce="kllo9940pd9333jh", oauth_signature_method="HMAC-SHA1", oauth_token="nnch734d00sl2jdk", oauth_timestamp="1191242096", oauth_consumer_key="dpf43f3p2l4k3l03", oauth_signature="tR3%2BTy81lMeYAr%2FFid0kMTYa%2FWM%3D", oauth_version="1.0"'.split(', ').sort
203
+ correct_sorted_params.unshift 'OAuth realm="http://photos.example.net/"'
204
+ assert_equal correct_sorted_params, request['authorization'].split(', ').sort
205
+ end
206
+
207
+ def test_step_by_step_token_request
208
+ token_response = "oauth_token=requestkey&oauth_token_secret=requestsecret"
209
+ stub_request(:get, %r{http://term\.ie/oauth/example/request_token\.php(\?.*)?}).to_return(:body => token_response)
210
+
211
+ consumer=OAuth::Consumer.new(
212
+ "key",
213
+ "secret")
214
+ request_uri = URI.parse('http://term.ie/oauth/example/request_token.php')
215
+ nonce = rand(2**128).to_s
216
+ timestamp = Time.now.to_i.to_s
217
+ http = Net::HTTP.new(request_uri.host, request_uri.port)
218
+
219
+ request = Net::HTTP::Get.new(request_uri.path)
220
+ signature_base_string=request.signature_base_string(http, consumer, nil, {:scheme=>:query_string,:nonce => nonce, :timestamp => timestamp})
221
+ assert_equal "GET&http%3A%2F%2Fterm.ie%2Foauth%2Fexample%2Frequest_token.php&oauth_consumer_key%3Dkey%26oauth_nonce%3D#{nonce}%26oauth_signature_method%3DHMAC-SHA1%26oauth_timestamp%3D#{timestamp}%26oauth_version%3D1.0",signature_base_string
222
+
223
+ # request = Net::HTTP::Get.new(request_uri.path)
224
+ request.oauth!(http, consumer, nil, {:scheme=>:query_string,:nonce => nonce, :timestamp => timestamp})
225
+ assert_equal 'GET', request.method
226
+ assert_nil request.body
227
+ assert_nil request['authorization']
228
+ # assert_equal 'OAuth oauth_nonce="kllo9940pd9333jh", oauth_signature_method="HMAC-SHA1", oauth_token="", oauth_timestamp="'+timestamp+'", oauth_consumer_key="key", oauth_signature="tR3%2BTy81lMeYAr%2FFid0kMTYa%2FWM%3D", oauth_version="1.0"', request['authorization']
229
+
230
+ response=http.request(request)
231
+ assert_equal "200",response.code
232
+ # assert_equal request['authorization'],response.body
233
+ assert_equal token_response, response.body
234
+ end
235
+
236
+ def test_that_put_bodies_signed
237
+ request = Net::HTTP::Put.new(@request_uri.path)
238
+ request.body = "<?xml version=\"1.0\"?><foo><bar>baz</bar></foo>"
239
+ request["Content-Type"] = "application/xml"
240
+ signature_base_string=request.signature_base_string(@http, @consumer, nil, { :nonce => @nonce, :timestamp => @timestamp })
241
+ assert_equal "PUT&http%3A%2F%2Fexample.com%2Ftest&oauth_body_hash%3DDvAa1AWdFoH9K%252B%252F2AHm3f6wH27k%253D%26oauth_consumer_key%3Dconsumer_key_86cad9%26oauth_nonce%3D225579211881198842005988698334675835446%26oauth_signature_method%3DHMAC-SHA1%26oauth_timestamp%3D1199645624%26oauth_version%3D1.0", signature_base_string
242
+ end
243
+
244
+ def test_that_put_bodies_not_signed_even_if_form_urlencoded
245
+ request = Net::HTTP::Put.new(@request_uri.path)
246
+ request.set_form_data( { 'key2' => 'value2' } )
247
+ signature_base_string=request.signature_base_string(@http, @consumer, nil, { :nonce => @nonce, :timestamp => @timestamp })
248
+ assert_equal "PUT&http%3A%2F%2Fexample.com%2Ftest&oauth_consumer_key%3Dconsumer_key_86cad9%26oauth_nonce%3D225579211881198842005988698334675835446%26oauth_signature_method%3DHMAC-SHA1%26oauth_timestamp%3D1199645624%26oauth_version%3D1.0", signature_base_string
249
+ end
250
+
251
+ def test_that_post_bodies_signed_if_form_urlencoded
252
+ request = Net::HTTP::Post.new(@request_uri.path)
253
+ request.set_form_data( { 'key2' => 'value2' } )
254
+ signature_base_string=request.signature_base_string(@http, @consumer, nil, { :nonce => @nonce, :timestamp => @timestamp })
255
+ assert_equal "POST&http%3A%2F%2Fexample.com%2Ftest&key2%3Dvalue2%26oauth_consumer_key%3Dconsumer_key_86cad9%26oauth_nonce%3D225579211881198842005988698334675835446%26oauth_signature_method%3DHMAC-SHA1%26oauth_timestamp%3D1199645624%26oauth_version%3D1.0", signature_base_string
256
+ end
257
+
258
+ def test_that_post_bodies_signed_if_other_content_type
259
+ request = Net::HTTP::Post.new(@request_uri.path)
260
+ request.body = "<?xml version=\"1.0\"?><foo><bar>baz</bar></foo>"
261
+ request["Content-Type"] = "application/xml"
262
+ signature_base_string=request.signature_base_string(@http, @consumer, nil, { :nonce => @nonce, :timestamp => @timestamp })
263
+ assert_equal "POST&http%3A%2F%2Fexample.com%2Ftest&oauth_body_hash%3DDvAa1AWdFoH9K%252B%252F2AHm3f6wH27k%253D%26oauth_consumer_key%3Dconsumer_key_86cad9%26oauth_nonce%3D225579211881198842005988698334675835446%26oauth_signature_method%3DHMAC-SHA1%26oauth_timestamp%3D1199645624%26oauth_version%3D1.0", signature_base_string
264
+ end
265
+
266
+ def test_that_site_address_is_not_modified_in_place
267
+ options = { :site => 'http://twitter.com', :request_endpoint => 'http://api.twitter.com' }
268
+ request = Net::HTTP::Get.new(@request_uri.path + "?" + request_parameters_to_s)
269
+ request.oauth!(@http, @consumer, @token, options)
270
+ assert_equal "http://twitter.com", options[:site]
271
+ assert_equal "http://api.twitter.com", options[:request_endpoint]
272
+ end
273
+
274
+ protected
275
+
276
+ def request_parameters_to_s
277
+ @request_parameters.map { |k,v| "#{k}=#{v}" }.join("&")
278
+ end
279
+
280
+ end
@@ -0,0 +1,72 @@
1
+ require File.expand_path('../test_helper', __FILE__)
2
+
3
+ class NetHTTPRequestProxyTest < Test::Unit::TestCase
4
+
5
+ def test_that_proxy_simple_get_request_works
6
+ request = Net::HTTP::Get.new('/test?key=value')
7
+ request_proxy = OAuth::RequestProxy.proxy(request, {:uri => 'http://example.com/test?key=value'})
8
+
9
+ expected_parameters = {'key' => ['value']}
10
+ assert_equal expected_parameters, request_proxy.parameters_for_signature
11
+ assert_equal 'http://example.com/test', request_proxy.normalized_uri
12
+ assert_equal 'GET', request_proxy.method
13
+ end
14
+
15
+ def test_that_proxy_simple_post_request_works_with_arguments
16
+ request = Net::HTTP::Post.new('/test')
17
+ params = {'key' => 'value'}
18
+ request_proxy = OAuth::RequestProxy.proxy(request, {:uri => 'http://example.com/test', :parameters => params})
19
+
20
+ expected_parameters = {'key' => ['value']}
21
+ assert_equal expected_parameters, request_proxy.parameters_for_signature
22
+ assert_equal 'http://example.com/test', request_proxy.normalized_uri
23
+ assert_equal 'POST', request_proxy.method
24
+ end
25
+
26
+ def test_that_proxy_simple_post_request_works_with_form_data
27
+ request = Net::HTTP::Post.new('/test')
28
+ params = {'key' => 'value'}
29
+ request.set_form_data(params)
30
+ request_proxy = OAuth::RequestProxy.proxy(request, {:uri => 'http://example.com/test'})
31
+
32
+ expected_parameters = {'key' => ['value']}
33
+ assert_equal expected_parameters, request_proxy.parameters_for_signature
34
+ assert_equal 'http://example.com/test', request_proxy.normalized_uri
35
+ assert_equal 'POST', request_proxy.method
36
+ end
37
+
38
+ def test_that_proxy_simple_put_request_works_with_argugments
39
+ request = Net::HTTP::Put.new('/test')
40
+ params = {'key' => 'value'}
41
+ request_proxy = OAuth::RequestProxy.proxy(request, {:uri => 'http://example.com/test', :parameters => params})
42
+
43
+ expected_parameters = {'key' => ['value']}
44
+ assert_equal expected_parameters, request_proxy.parameters_for_signature
45
+ assert_equal 'http://example.com/test', request_proxy.normalized_uri
46
+ assert_equal 'PUT', request_proxy.method
47
+ end
48
+
49
+ def test_that_proxy_simple_put_request_works_with_form_data
50
+ request = Net::HTTP::Put.new('/test')
51
+ params = {'key' => 'value'}
52
+ request.set_form_data(params)
53
+ request_proxy = OAuth::RequestProxy.proxy(request, {:uri => 'http://example.com/test'})
54
+
55
+ expected_parameters = {}
56
+ assert_equal expected_parameters, request_proxy.parameters_for_signature
57
+ assert_equal 'http://example.com/test', request_proxy.normalized_uri
58
+ assert_equal 'PUT', request_proxy.method
59
+ end
60
+
61
+ def test_that_proxy_post_request_uses_post_parameters
62
+ request = Net::HTTP::Post.new('/test?key=value')
63
+ request.set_form_data({'key2' => 'value2'})
64
+ request_proxy = OAuth::RequestProxy.proxy(request, {:uri => 'http://example.com/test?key=value', :parameters => {'key3' => 'value3'}})
65
+
66
+ expected_parameters = {'key' => ['value'], 'key2' => ['value2'], 'key3' => ['value3']}
67
+ assert_equal expected_parameters, request_proxy.parameters_for_signature
68
+ assert_equal 'http://example.com/test', request_proxy.normalized_uri
69
+ assert_equal 'POST', request_proxy.method
70
+ end
71
+
72
+ end
@@ -0,0 +1,71 @@
1
+ require File.expand_path('../test_helper', __FILE__)
2
+
3
+ class TestOAuthHelper < Test::Unit::TestCase
4
+
5
+ def test_parse_valid_header
6
+ header = 'OAuth ' \
7
+ 'realm="http://example.com/method", ' \
8
+ 'oauth_consumer_key="vince_clortho", ' \
9
+ 'oauth_token="token_value", ' \
10
+ 'oauth_signature_method="HMAC-SHA1", ' \
11
+ 'oauth_signature="signature_here", ' \
12
+ 'oauth_timestamp="1240004133", oauth_nonce="nonce", ' \
13
+ 'oauth_version="1.0" '
14
+
15
+ params = OAuth::Helper.parse_header(header)
16
+
17
+ assert_equal "http://example.com/method", params['realm']
18
+ assert_equal "vince_clortho", params['oauth_consumer_key']
19
+ assert_equal "token_value", params['oauth_token']
20
+ assert_equal "HMAC-SHA1", params['oauth_signature_method']
21
+ assert_equal "signature_here", params['oauth_signature']
22
+ assert_equal "1240004133", params['oauth_timestamp']
23
+ assert_equal "nonce", params['oauth_nonce']
24
+ assert_equal "1.0", params['oauth_version']
25
+ end
26
+
27
+ def test_parse_header_ill_formed
28
+ header = "OAuth garbage"
29
+
30
+ assert_raise OAuth::Problem do
31
+ OAuth::Helper.parse_header(header)
32
+ end
33
+ end
34
+
35
+ def test_parse_header_contains_equals
36
+ header = 'OAuth ' \
37
+ 'realm="http://example.com/method", ' \
38
+ 'oauth_consumer_key="vince_clortho", ' \
39
+ 'oauth_token="token_value", ' \
40
+ 'oauth_signature_method="HMAC-SHA1", ' \
41
+ 'oauth_signature="signature_here_with_=", ' \
42
+ 'oauth_timestamp="1240004133", oauth_nonce="nonce", ' \
43
+ 'oauth_version="1.0" '
44
+
45
+ assert_raise OAuth::Problem do
46
+ OAuth::Helper.parse_header(header)
47
+ end
48
+ end
49
+
50
+ def test_parse_valid_header_with_and_signs
51
+ header = 'OAuth ' \
52
+ 'realm="http://example.com/method"&' \
53
+ 'oauth_consumer_key="vince_clortho"&' \
54
+ 'oauth_token="token_value"&' \
55
+ 'oauth_signature_method="HMAC-SHA1"&' \
56
+ 'oauth_signature="signature_here"&' \
57
+ 'oauth_timestamp="1240004133"&oauth_nonce="nonce"&' \
58
+ 'oauth_version="1.0"'
59
+
60
+ params = OAuth::Helper.parse_header(header)
61
+
62
+ assert_equal "http://example.com/method", params['realm']
63
+ assert_equal "vince_clortho", params['oauth_consumer_key']
64
+ assert_equal "token_value", params['oauth_token']
65
+ assert_equal "HMAC-SHA1", params['oauth_signature_method']
66
+ assert_equal "signature_here", params['oauth_signature']
67
+ assert_equal "1240004133", params['oauth_timestamp']
68
+ assert_equal "nonce", params['oauth_nonce']
69
+ assert_equal "1.0", params['oauth_version']
70
+ end
71
+ end
@@ -0,0 +1,40 @@
1
+ require File.expand_path('../test_helper', __FILE__)
2
+ require 'oauth/request_proxy/rack_request'
3
+ require 'rack/request'
4
+ require 'rack/mock'
5
+
6
+ class RackRequestProxyTest < Test::Unit::TestCase
7
+
8
+ def test_that_proxy_simple_get_request_works
9
+ request = Rack::Request.new(Rack::MockRequest.env_for('http://example.com/test?key=value'))
10
+ request_proxy = OAuth::RequestProxy.proxy(request, {:uri => 'http://example.com/test?key=value'})
11
+
12
+ expected_parameters = {'key' => 'value'}
13
+ assert_equal expected_parameters, request_proxy.parameters
14
+ assert_equal 'http://example.com/test', request_proxy.normalized_uri
15
+ assert_equal 'GET', request_proxy.method
16
+ end
17
+
18
+ def test_that_proxy_simple_post_request_works
19
+ request = Rack::Request.new(Rack::MockRequest.env_for('http://example.com/test', :method => 'POST'))
20
+ params = {'key' => 'value'}
21
+ request_proxy = OAuth::RequestProxy.proxy(request, {:uri => 'http://example.com/test', :parameters => params})
22
+
23
+ expected_parameters = {'key' => 'value'}
24
+ assert_equal expected_parameters, request_proxy.parameters
25
+ assert_equal 'http://example.com/test', request_proxy.normalized_uri
26
+ assert_equal 'POST', request_proxy.method
27
+ end
28
+
29
+ def test_that_proxy_post_and_get_request_works
30
+ request = Rack::Request.new(Rack::MockRequest.env_for('http://example.com/test?key=value', :method => 'POST', :input => 'key2=value2'))
31
+ params = {'key2' => 'value2'}
32
+ request_proxy = OAuth::RequestProxy.proxy(request, {:uri => 'http://example.com/test?key=value', :parameters => params})
33
+
34
+ expected_parameters = {'key' => 'value', 'key2' => 'value2'}
35
+ assert_equal expected_parameters, request_proxy.parameters
36
+ assert_equal 'http://example.com/test', request_proxy.normalized_uri
37
+ assert_equal 'POST', request_proxy.method
38
+ end
39
+
40
+ end