httpclient 2.5.3.3 → 2.6.0
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/bin/httpclient +11 -5
- data/bin/jsonclient +32 -78
- data/lib/httpclient.rb +49 -17
- data/lib/httpclient/auth.rb +60 -87
- data/lib/httpclient/cookie.rb +160 -388
- data/lib/httpclient/http.rb +40 -11
- data/lib/httpclient/session.rb +6 -22
- data/lib/httpclient/version.rb +1 -1
- data/lib/httpclient/webagent-cookie.rb +459 -0
- data/lib/jsonclient.rb +63 -0
- data/test/test_auth.rb +51 -6
- data/test/test_cookie.rb +128 -231
- data/test/test_http-access2.rb +6 -8
- data/test/test_httpclient.rb +96 -33
- data/test/test_jsonclient.rb +80 -0
- data/test/test_webagent-cookie.rb +465 -0
- metadata +6 -2
data/lib/jsonclient.rb
ADDED
@@ -0,0 +1,63 @@
|
|
1
|
+
require 'httpclient'
|
2
|
+
require 'json'
|
3
|
+
|
4
|
+
# JSONClient auto-converts Hash <-> JSON in request and response.
|
5
|
+
# * For POST or PUT request, convert Hash body to JSON String with 'application/json; charset=utf-8' header.
|
6
|
+
# * For response, convert JSON String to Hash when content-type is '(application|text)/(x-)?json'
|
7
|
+
class JSONClient < HTTPClient
|
8
|
+
CONTENT_TYPE_JSON_REGEX = /(application|text)\/(x-)?json/i
|
9
|
+
CONTENT_TYPE_JSON = 'application/json; charset=utf-8'
|
10
|
+
|
11
|
+
attr_reader :content_type_json_request
|
12
|
+
attr_reader :content_type_json_response_regex
|
13
|
+
|
14
|
+
def initialize(*args)
|
15
|
+
super
|
16
|
+
@content_type_json_request = CONTENT_TYPE_JSON
|
17
|
+
@content_type_json_response_regex = CONTENT_TYPE_JSON_REGEX
|
18
|
+
end
|
19
|
+
|
20
|
+
def post(uri, *args, &block)
|
21
|
+
request(:post, uri, argument_to_hash_for_json(args), &block)
|
22
|
+
end
|
23
|
+
|
24
|
+
def put(uri, *args, &block)
|
25
|
+
request(:put, uri, argument_to_hash_for_json(args), &block)
|
26
|
+
end
|
27
|
+
|
28
|
+
def request(method, uri, *args, &block)
|
29
|
+
res = super
|
30
|
+
if @content_type_json_response_regex =~ res.content_type
|
31
|
+
res = wrap_json_response(res)
|
32
|
+
end
|
33
|
+
res
|
34
|
+
end
|
35
|
+
|
36
|
+
private
|
37
|
+
|
38
|
+
def argument_to_hash_for_json(args)
|
39
|
+
hash = argument_to_hash(args, :body, :header, :follow_redirect)
|
40
|
+
if hash[:body].is_a?(Hash)
|
41
|
+
hash[:header] = json_header(hash[:header])
|
42
|
+
hash[:body] = JSON.generate(hash[:body])
|
43
|
+
end
|
44
|
+
hash
|
45
|
+
end
|
46
|
+
|
47
|
+
def json_header(header)
|
48
|
+
header ||= {}
|
49
|
+
if header.is_a?(Hash)
|
50
|
+
header['Content-Type'] = @content_type_json_request
|
51
|
+
else
|
52
|
+
header << ['Content-Type', @content_type_json_request]
|
53
|
+
end
|
54
|
+
header
|
55
|
+
end
|
56
|
+
|
57
|
+
def wrap_json_response(original)
|
58
|
+
res = ::HTTP::Message.new_response(JSON.parse(original.content))
|
59
|
+
res.http_header = original.http_header
|
60
|
+
res.previous = original
|
61
|
+
res
|
62
|
+
end
|
63
|
+
end
|
data/test/test_auth.rb
CHANGED
@@ -115,14 +115,25 @@ class TestAuth < Test::Unit::TestCase
|
|
115
115
|
res.body = 'digest_sess_auth OK' + req.query_string.to_s
|
116
116
|
end
|
117
117
|
|
118
|
-
# TODO:
|
119
|
-
|
120
|
-
|
121
|
-
|
118
|
+
# TODO: monkey patching for rack-ntlm-test-services's incompat.
|
119
|
+
module ::Net
|
120
|
+
module NTLM
|
121
|
+
# ruby-ntlm 0.3.0 -> 0.4.0
|
122
|
+
def self.decode_utf16le(*arg)
|
123
|
+
EncodeUtil.decode_utf16le(*arg)
|
124
|
+
end
|
125
|
+
# Make it work if @value == nil
|
126
|
+
class SecurityBuffer < FieldSet
|
127
|
+
def data_size
|
128
|
+
@active && @value ? @value.size : 0
|
129
|
+
end
|
130
|
+
end
|
131
|
+
end
|
132
|
+
end
|
133
|
+
def test_ntlm_auth
|
122
134
|
c = HTTPClient.new
|
123
135
|
c.set_auth("http://localhost:#{serverport}/ntlm_auth", 'admin', 'admin')
|
124
136
|
assert_equal('ntlm_auth OK', c.get_content("http://localhost:#{serverport}/ntlm_auth"))
|
125
|
-
puts c.inspect
|
126
137
|
end
|
127
138
|
|
128
139
|
def test_basic_auth
|
@@ -146,7 +157,11 @@ class TestAuth < Test::Unit::TestCase
|
|
146
157
|
c.www_auth.basic_auth.instance_eval { @scheme = "BASIC" }
|
147
158
|
#
|
148
159
|
c.set_auth("http://localhost:#{serverport}/", 'admin', 'admin')
|
149
|
-
|
160
|
+
res = c.get("http://localhost:#{serverport}/basic_auth")
|
161
|
+
assert_equal('basic_auth OK', res.content)
|
162
|
+
assert_equal(200, res.status)
|
163
|
+
assert_equal(401, res.previous.status)
|
164
|
+
assert_equal(nil, res.previous.previous)
|
150
165
|
ensure
|
151
166
|
@basic_auth.instance_eval { @auth_scheme = webrick_backup }
|
152
167
|
end
|
@@ -425,4 +440,34 @@ class TestAuth < Test::Unit::TestCase
|
|
425
440
|
assert(str.index(%q(POST /photos)))
|
426
441
|
assert(str.index(%q(Authorization: OAuth realm="http://photos.example.net/", oauth_consumer_key="dpf43f3p2l4k3l03", oauth_nonce="kllo9940pd9333jh", oauth_signature="wPkvxykrw%2BBTdCcGqKr%2B3I%2BPsiM%3D", oauth_signature_method="HMAC-SHA1", oauth_timestamp="1191242096", oauth_token="nnch734d00sl2jdk", oauth_version="1.0")))
|
427
442
|
end
|
443
|
+
|
444
|
+
def test_basic_auth_post_with_multipart
|
445
|
+
c = HTTPClient.new
|
446
|
+
c.set_auth("http://localhost:#{serverport}/", 'admin', 'admin')
|
447
|
+
File.open(__FILE__) do |f|
|
448
|
+
# read 'f' twice for authorization negotiation
|
449
|
+
assert_equal('basic_auth OK', c.post("http://localhost:#{serverport}/basic_auth", :file => f).content)
|
450
|
+
end
|
451
|
+
end
|
452
|
+
|
453
|
+
def test_negotiate_and_basic
|
454
|
+
c = HTTPClient.new
|
455
|
+
c.test_loopback_http_response << %Q(HTTP/1.1 401 Unauthorized\r\nWWW-Authenticate: NTLM\r\nWWW-Authenticate: Basic realm="foo"\r\nConnection: Keep-Alive\r\nContent-Length: 0\r\n\r\n)
|
456
|
+
c.test_loopback_http_response << %Q(HTTP/1.1 401 Unauthorized\r\nWWW-Authenticate: NTLM TlRMTVNTUAACAAAAAAAAACgAAAABAAAAAAAAAAAAAAA=\r\nConnection: Keep-Alive\r\nContent-Length: 0\r\n\r\n)
|
457
|
+
c.test_loopback_http_response << %Q(HTTP/1.0 200 OK\r\nConnection: Keep-Alive\r\nContent-Length: 1\r\n\r\na)
|
458
|
+
c.test_loopback_http_response << %Q(HTTP/1.0 200 OK\r\nConnection: Keep-Alive\r\nContent-Length: 1\r\n\r\nb)
|
459
|
+
c.debug_dev = str = ''
|
460
|
+
c.set_auth('http://www.example.org/', 'admin', 'admin')
|
461
|
+
# Do NTLM negotiation
|
462
|
+
c.get('http://www.example.org/foo')
|
463
|
+
# BasicAuth authenticator should not respond to it because NTLM
|
464
|
+
# negotiation has been finished.
|
465
|
+
assert_match(%r(Authorization: NTLM), str)
|
466
|
+
assert_not_match(%r(Authorization: Basic), str)
|
467
|
+
# ditto for other resource that is protected with NTLM
|
468
|
+
c.debug_dev = str = ''
|
469
|
+
c.get('http://www.example.org/foo/subdir')
|
470
|
+
assert_not_match(%r(Authorization: NTLM), str)
|
471
|
+
assert_not_match(%r(Authorization: Basic), str)
|
472
|
+
end
|
428
473
|
end
|
data/test/test_cookie.rb
CHANGED
@@ -1,131 +1,20 @@
|
|
1
1
|
require 'test/unit'
|
2
2
|
require 'uri'
|
3
|
+
require 'tempfile'
|
3
4
|
|
5
|
+
require 'httpclient/util'
|
4
6
|
require 'httpclient/cookie'
|
5
7
|
|
6
8
|
class TestCookie < Test::Unit::TestCase
|
7
9
|
include HTTPClient::Util
|
8
10
|
|
9
11
|
def setup()
|
10
|
-
@c = WebAgent::Cookie.new()
|
12
|
+
@c = WebAgent::Cookie.new('hoge', 'funi')
|
11
13
|
end
|
12
14
|
|
13
15
|
def test_s_new()
|
14
16
|
assert_instance_of(WebAgent::Cookie, @c)
|
15
17
|
end
|
16
|
-
|
17
|
-
def test_discard?
|
18
|
-
assert_equal(false, !!(@c.discard?))
|
19
|
-
@c.discard = true
|
20
|
-
assert_equal(true, !!(@c.discard?))
|
21
|
-
end
|
22
|
-
|
23
|
-
def test_match()
|
24
|
-
url = urify('http://www.rubycolor.org/hoge/funi/#919191')
|
25
|
-
|
26
|
-
@c.domain = 'www.rubycolor.org'
|
27
|
-
assert_equal(true, @c.match?(url))
|
28
|
-
|
29
|
-
@c.domain = '.rubycolor.org'
|
30
|
-
assert_equal(true, @c.match?(url))
|
31
|
-
|
32
|
-
@c.domain = 'aaa.www.rubycolor.org'
|
33
|
-
assert_equal(false, @c.match?(url))
|
34
|
-
|
35
|
-
@c.domain = 'aaa.www.rubycolor.org'
|
36
|
-
assert_equal(false, @c.match?(url))
|
37
|
-
|
38
|
-
@c.domain = 'www.rubycolor.org'
|
39
|
-
@c.path = '/'
|
40
|
-
assert_equal(true, @c.match?(url))
|
41
|
-
|
42
|
-
@c.domain = 'www.rubycolor.org'
|
43
|
-
@c.path = '/hoge'
|
44
|
-
assert_equal(true, @c.match?(url))
|
45
|
-
|
46
|
-
@c.domain = 'www.rubycolor.org'
|
47
|
-
@c.path = '/hoge/hoge'
|
48
|
-
assert_equal(false, @c.match?(url))
|
49
|
-
|
50
|
-
@c.domain = 'www.rubycolor.org'
|
51
|
-
@c.path = '/hoge'
|
52
|
-
@c.secure = true
|
53
|
-
assert_equal(false, @c.match?(url))
|
54
|
-
|
55
|
-
url2 = urify('https://www.rubycolor.org/hoge/funi/#919191')
|
56
|
-
@c.domain = 'www.rubycolor.org'
|
57
|
-
@c.path = '/hoge'
|
58
|
-
@c.secure = true
|
59
|
-
assert_equal(true, @c.match?(url2))
|
60
|
-
|
61
|
-
@c.domain = 'www.rubycolor.org'
|
62
|
-
@c.path = '/hoge'
|
63
|
-
@c.secure = nil
|
64
|
-
assert_equal(true, @c.match?(url2)) ## not false!
|
65
|
-
|
66
|
-
url.port = 80
|
67
|
-
@c.domain = 'www.rubycolor.org'
|
68
|
-
@c.path = '/hoge'
|
69
|
-
# @c.port = [80,8080]
|
70
|
-
assert_equal(true, @c.match?(url))
|
71
|
-
|
72
|
-
url_nopath = URI.parse('http://www.rubycolor.org')
|
73
|
-
@c.domain = 'www.rubycolor.org'
|
74
|
-
@c.path = '/'
|
75
|
-
assert_equal(true, @c.match?(url_nopath))
|
76
|
-
|
77
|
-
end
|
78
|
-
|
79
|
-
def test_head_match?()
|
80
|
-
assert_equal(true, @c.head_match?("",""))
|
81
|
-
assert_equal(false, @c.head_match?("a",""))
|
82
|
-
assert_equal(true, @c.head_match?("","a"))
|
83
|
-
assert_equal(true, @c.head_match?("abcde","abcde"))
|
84
|
-
assert_equal(true, @c.head_match?("abcde","abcdef"))
|
85
|
-
assert_equal(false, @c.head_match?("abcdef","abcde"))
|
86
|
-
assert_equal(false, @c.head_match?("abcde","bcde"))
|
87
|
-
assert_equal(false, @c.head_match?("bcde","abcde"))
|
88
|
-
end
|
89
|
-
|
90
|
-
def test_tail_match?()
|
91
|
-
assert_equal(true, @c.tail_match?("",""))
|
92
|
-
assert_equal(false, @c.tail_match?("a",""))
|
93
|
-
assert_equal(true, @c.tail_match?("","a"))
|
94
|
-
assert_equal(true, @c.tail_match?("abcde","abcde"))
|
95
|
-
assert_equal(false, @c.tail_match?("abcde","abcdef"))
|
96
|
-
assert_equal(false, @c.tail_match?("abcdef","abcde"))
|
97
|
-
assert_equal(false, @c.tail_match?("abcde","bcde"))
|
98
|
-
assert_equal(true, @c.tail_match?("bcde","abcde"))
|
99
|
-
end
|
100
|
-
|
101
|
-
|
102
|
-
def test_domain_match()
|
103
|
-
extend WebAgent::CookieUtils
|
104
|
-
assert_equal(true, !!domain_match("hoge.co.jp","."))
|
105
|
-
# assert_equal(true, !!domain_match("locahost",".local"))
|
106
|
-
assert_equal(true, !!domain_match("192.168.10.1","192.168.10.1"))
|
107
|
-
assert_equal(false, !!domain_match("192.168.10.1","192.168.10.2"))
|
108
|
-
# assert_equal(false, !!domain_match("hoge.co.jp",".hoge.co.jp"))
|
109
|
-
# allows; host == rubyforge.org, domain == .rubyforge.org
|
110
|
-
assert_equal(true, !!domain_match("hoge.co.jp",".hoge.co.jp"))
|
111
|
-
assert_equal(true, !!domain_match("www.hoge.co.jp", "www.hoge.co.jp"))
|
112
|
-
assert_equal(false, !!domain_match("www.hoge.co.jp", "www2.hoge.co.jp"))
|
113
|
-
assert_equal(true, !!domain_match("www.hoge.co.jp", ".hoge.co.jp"))
|
114
|
-
assert_equal(true, !!domain_match("www.aa.hoge.co.jp", ".hoge.co.jp"))
|
115
|
-
assert_equal(false, !!domain_match("www.hoge.co.jp", "hoge.co.jp"))
|
116
|
-
end
|
117
|
-
|
118
|
-
def test_join_quotedstr()
|
119
|
-
arr1 = ['hoge=funi', 'hoge2=funi2']
|
120
|
-
assert_equal(arr1, @c.instance_eval{join_quotedstr(arr1,';')})
|
121
|
-
arr2 = ['hoge="fu', 'ni"', 'funi=funi']
|
122
|
-
assert_equal(['hoge="fu;ni"','funi=funi'],
|
123
|
-
@c.instance_eval{join_quotedstr(arr2,';')})
|
124
|
-
arr3 = ['hoge="funi";hoge2="fu','ni2";hoge3="hoge"', 'funi="funi"']
|
125
|
-
assert_equal(['hoge="funi";hoge2="fu,ni2";hoge3="hoge"', 'funi="funi"'],
|
126
|
-
@c.instance_eval{join_quotedstr(arr3,',')})
|
127
|
-
end
|
128
|
-
|
129
18
|
end
|
130
19
|
|
131
20
|
class TestCookieManager < Test::Unit::TestCase
|
@@ -139,13 +28,13 @@ class TestCookieManager < Test::Unit::TestCase
|
|
139
28
|
end
|
140
29
|
|
141
30
|
def test_parse()
|
142
|
-
str = "inkid=n92b0ADOgACIgUb9lsjHqAAAHu2a; expires=Wed, 01-Dec-
|
31
|
+
str = "inkid=n92b0ADOgACIgUb9lsjHqAAAHu2a; expires=Wed, 01-Dec-2999 00:00:00 GMT; path=/"
|
143
32
|
@cm.parse(str, urify('http://www.test.jp'))
|
144
33
|
cookie = @cm.cookies[0]
|
145
34
|
assert_instance_of(WebAgent::Cookie, cookie)
|
146
35
|
assert_equal("inkid", cookie.name)
|
147
36
|
assert_equal("n92b0ADOgACIgUb9lsjHqAAAHu2a", cookie.value)
|
148
|
-
assert_equal(Time.gm(
|
37
|
+
assert_equal(Time.gm(2999, 12, 1, 0,0,0), cookie.expires)
|
149
38
|
assert_equal("/", cookie.path)
|
150
39
|
end
|
151
40
|
|
@@ -157,7 +46,8 @@ class TestCookieManager < Test::Unit::TestCase
|
|
157
46
|
assert_equal("xmen", cookie.name)
|
158
47
|
assert_equal("off,0,0,1", cookie.value)
|
159
48
|
assert_equal("/", cookie.path)
|
160
|
-
assert_equal("
|
49
|
+
assert_equal("excite.co.jp", cookie.domain)
|
50
|
+
assert_equal(".excite.co.jp", cookie.dot_domain)
|
161
51
|
assert_equal(Time.gm(2037,12,31,12,0,0), cookie.expires)
|
162
52
|
end
|
163
53
|
|
@@ -169,7 +59,8 @@ class TestCookieManager < Test::Unit::TestCase
|
|
169
59
|
assert_equal("xmen", cookie.name)
|
170
60
|
assert_equal("off,0,0,1", cookie.value)
|
171
61
|
assert_equal("/", cookie.path)
|
172
|
-
assert_equal("
|
62
|
+
assert_equal("excite.co.jp", cookie.domain)
|
63
|
+
assert_equal(".excite.co.jp", cookie.dot_domain)
|
173
64
|
assert_equal(Time.gm(2037,12,31,12,0,0), cookie.expires)
|
174
65
|
assert_equal(true, cookie.secure?)
|
175
66
|
assert_equal(true, cookie.http_only?)
|
@@ -183,7 +74,8 @@ class TestCookieManager < Test::Unit::TestCase
|
|
183
74
|
assert_equal("xmen", cookie.name)
|
184
75
|
assert_equal("off,0,0,1", cookie.value)
|
185
76
|
assert_equal("/;;", cookie.path)
|
186
|
-
assert_equal("
|
77
|
+
assert_equal("excite.co.jp", cookie.domain)
|
78
|
+
assert_equal(".excite.co.jp", cookie.dot_domain)
|
187
79
|
assert_equal(Time.gm(2037,12,31,12,0,0), cookie.expires)
|
188
80
|
end
|
189
81
|
|
@@ -194,19 +86,21 @@ class TestCookieManager < Test::Unit::TestCase
|
|
194
86
|
# end
|
195
87
|
|
196
88
|
def test_check_expired_cookies()
|
197
|
-
|
198
|
-
|
199
|
-
|
200
|
-
|
201
|
-
|
202
|
-
|
203
|
-
|
89
|
+
format = "%a, %d-%b-%Y %H:%M:%S GMT"
|
90
|
+
c1 = WebAgent::Cookie.new('hoge1', 'funi', :domain => 'http://www.example.com/', :path => '/')
|
91
|
+
c2 = WebAgent::Cookie.new('hoge2', 'funi', :domain => 'http://www.example.com/', :path => '/')
|
92
|
+
c3 = WebAgent::Cookie.new('hoge3', 'funi', :domain => 'http://www.example.com/', :path => '/')
|
93
|
+
c4 = WebAgent::Cookie.new('hoge4', 'funi', :domain => 'http://www.example.com/', :path => '/')
|
94
|
+
c1.expires = (Time.now - 100).gmtime.strftime(format)
|
95
|
+
c2.expires = (Time.now + 100).gmtime.strftime(format)
|
96
|
+
c3.expires = (Time.now - 10).gmtime.strftime(format)
|
204
97
|
c4.expires = nil
|
205
98
|
cookies = [c1,c2,c3,c4]
|
206
99
|
@cm.cookies = cookies
|
207
|
-
@cm.
|
208
|
-
|
209
|
-
assert_equal(
|
100
|
+
assert_equal(c2.name, @cm.cookies[0].name)
|
101
|
+
assert_equal(c2.expires, @cm.cookies[0].expires)
|
102
|
+
assert_equal(c4.name, @cm.cookies[1].name)
|
103
|
+
assert_equal(c4.expires, @cm.cookies[1].expires)
|
210
104
|
end
|
211
105
|
|
212
106
|
def test_parse_expires
|
@@ -236,13 +130,13 @@ class TestCookieManager < Test::Unit::TestCase
|
|
236
130
|
end
|
237
131
|
|
238
132
|
def test_parse_after_expiration
|
239
|
-
str = "inkid=n92b0ADOgACIgUb9lsjHqAAAHu2a; expires=Wed, 01-Dec-
|
133
|
+
str = "inkid=n92b0ADOgACIgUb9lsjHqAAAHu2a; expires=Wed, 01-Dec-2999 00:00:00 GMT; path=/"
|
240
134
|
@cm.parse(str, urify('http://www.test.jp'))
|
241
135
|
cookie = @cm.cookies[0]
|
242
136
|
assert_instance_of(WebAgent::Cookie, cookie)
|
243
137
|
assert_equal("inkid", cookie.name)
|
244
138
|
assert_equal("n92b0ADOgACIgUb9lsjHqAAAHu2a", cookie.value)
|
245
|
-
assert_equal(Time.gm(
|
139
|
+
assert_equal(Time.gm(2999, 12, 1, 0,0,0), cookie.expires)
|
246
140
|
assert_equal("/", cookie.path)
|
247
141
|
|
248
142
|
time = Time.at(Time.now.to_i + 60).utc
|
@@ -263,49 +157,43 @@ class TestCookieManager < Test::Unit::TestCase
|
|
263
157
|
str = "xmen=off,0,0,2; path=/; domain=.excite.co.jp; expires=Wednesday, 31-Dec-2037 12:00:00 GMT"
|
264
158
|
@cm.parse(str, urify("http://www.excite.co.jp/"))
|
265
159
|
|
266
|
-
@cm.cookies[0].use = true
|
267
|
-
@cm.cookies[1].use = true
|
268
|
-
|
269
160
|
url = urify('http://www.excite.co.jp/hoge/funi/')
|
270
161
|
cookie_str = @cm.find(url)
|
271
|
-
assert_equal("xmen
|
162
|
+
assert_equal("xmen=\"off,0,0,2\"", cookie_str)
|
272
163
|
end
|
273
164
|
|
274
165
|
def test_load_cookies()
|
275
|
-
|
276
|
-
|
277
|
-
|
166
|
+
cookiefile = Tempfile.new('test_cookie')
|
167
|
+
File.open(cookiefile.path, 'w') do |f|
|
168
|
+
f.write <<EOF
|
278
169
|
http://www.zdnet.co.jp/news/0106/08/e_gibson.html NGUserID d29b8f49-10875-992421294-1 2145801600 www.zdnet.co.jp / 9 0
|
279
|
-
http://www.zdnet.co.jp/news/0106/08/e_gibson.html PACK zd3-992421294-7436
|
170
|
+
http://www.zdnet.co.jp/news/0106/08/e_gibson.html PACK zd3-992421294-7436 2293839999 .zdnet.co.jp / 13 0
|
280
171
|
http://example.org/ key value 0 .example.org / 13 0
|
281
172
|
http://example.org/ key value .example.org / 13 0
|
282
173
|
EOF
|
283
|
-
}
|
284
|
-
|
285
|
-
@cm.cookies_file = 'tmp_test.tmp'
|
286
|
-
@cm.load_cookies()
|
287
|
-
c0, c1, c2, c3 = @cm.cookies
|
288
|
-
assert_equal('http://www.zdnet.co.jp/news/0106/08/e_gibson.html', c0.url.to_s)
|
289
|
-
assert_equal('NGUserID', c0.name)
|
290
|
-
assert_equal('d29b8f49-10875-992421294-1', c0.value)
|
291
|
-
assert_equal(Time.at(2145801600), c0.expires)
|
292
|
-
assert_equal('www.zdnet.co.jp', c0.domain)
|
293
|
-
assert_equal('/', c0.path)
|
294
|
-
assert_equal(9, c0.flag)
|
295
|
-
#
|
296
|
-
assert_equal('http://www.zdnet.co.jp/news/0106/08/e_gibson.html', c1.url.to_s)
|
297
|
-
assert_equal('PACK', c1.name)
|
298
|
-
assert_equal('zd3-992421294-7436', c1.value)
|
299
|
-
assert_equal(Time.at(1293839999), c1.expires)
|
300
|
-
assert_equal('.zdnet.co.jp', c1.domain)
|
301
|
-
assert_equal('/', c1.path)
|
302
|
-
assert_equal(13, c1.flag)
|
303
|
-
#
|
304
|
-
assert_equal(nil, c2.expires)
|
305
|
-
assert_equal(nil, c3.expires) # allow empty 'expires' (should not happen)
|
306
|
-
ensure
|
307
|
-
File.unlink("tmp_test.tmp")
|
308
174
|
end
|
175
|
+
|
176
|
+
@cm.cookies_file = cookiefile.path
|
177
|
+
@cm.load_cookies()
|
178
|
+
c0, c1, c2 = @cm.cookies
|
179
|
+
assert_equal('http://www.zdnet.co.jp/news/0106/08/e_gibson.html', c0.url.to_s)
|
180
|
+
assert_equal('NGUserID', c0.name)
|
181
|
+
assert_equal('d29b8f49-10875-992421294-1', c0.value)
|
182
|
+
assert_equal(Time.at(2145801600), c0.expires)
|
183
|
+
assert_equal('www.zdnet.co.jp', c0.domain)
|
184
|
+
assert_equal('/', c0.path)
|
185
|
+
assert_equal(9, c0.flag)
|
186
|
+
#
|
187
|
+
assert_equal('http://www.zdnet.co.jp/news/0106/08/e_gibson.html', c1.url.to_s)
|
188
|
+
assert_equal('PACK', c1.name)
|
189
|
+
assert_equal('zd3-992421294-7436', c1.value)
|
190
|
+
assert_equal(Time.at(2293839999), c1.expires)
|
191
|
+
assert_equal('zdnet.co.jp', c1.domain)
|
192
|
+
assert_equal('.zdnet.co.jp', c1.dot_domain)
|
193
|
+
assert_equal('/', c1.path)
|
194
|
+
assert_equal(13, c1.flag)
|
195
|
+
#
|
196
|
+
assert_equal(nil, c2.expires)
|
309
197
|
end
|
310
198
|
|
311
199
|
def test_save_cookie()
|
@@ -313,56 +201,44 @@ EOF
|
|
313
201
|
http://www.zdnet.co.jp/news/0106/08/e_gibson.html NGUserID d29b8f49-10875-992421294-1 2145801600 www.zdnet.co.jp / 9
|
314
202
|
http://www.zdnet.co.jp/news/0106/08/e_gibson.html PACK zd3-992421294-7436 2145801600 .zdnet.co.jp / 13
|
315
203
|
EOF
|
316
|
-
|
317
|
-
|
318
|
-
|
319
|
-
|
320
|
-
@cm.cookies_file = 'tmp_test.tmp'
|
321
|
-
@cm.load_cookies()
|
322
|
-
@cm.instance_eval{@is_saved = false}
|
323
|
-
@cm.cookies_file = 'tmp_test2.tmp'
|
324
|
-
@cm.save_cookies()
|
325
|
-
str2 = ''
|
326
|
-
File.open("tmp_test2.tmp","r") {|f|
|
327
|
-
str2 = f.read()
|
328
|
-
}
|
329
|
-
assert_equal(str, str2)
|
330
|
-
#
|
331
|
-
assert(File.exist?('tmp_test2.tmp'))
|
332
|
-
File.unlink("tmp_test2.tmp")
|
333
|
-
@cm.save_cookies()
|
334
|
-
assert(!File.exist?('tmp_test2.tmp'))
|
335
|
-
@cm.save_cookies(true)
|
336
|
-
assert(File.exist?('tmp_test2.tmp'))
|
337
|
-
ensure
|
338
|
-
File.unlink("tmp_test.tmp")
|
339
|
-
if FileTest.exist?("tmp_test2.tmp")
|
340
|
-
File.unlink("tmp_test2.tmp")
|
341
|
-
end
|
204
|
+
cookiefile = Tempfile.new('test_cookie')
|
205
|
+
cookiefile2 = Tempfile.new('test_cookie2')
|
206
|
+
File.open(cookiefile.path, 'w') do |f|
|
207
|
+
f.write str
|
342
208
|
end
|
209
|
+
|
210
|
+
@cm.cookies_file = cookiefile.path
|
211
|
+
@cm.load_cookies()
|
212
|
+
@cm.instance_eval{@is_saved = false}
|
213
|
+
@cm.cookies_file = cookiefile2.path
|
214
|
+
@cm.save_cookies()
|
215
|
+
str2 = ''
|
216
|
+
File.open(cookiefile2.path, 'r') do |f|
|
217
|
+
str2 = f.read
|
218
|
+
end
|
219
|
+
assert_equal(str.split.sort, str2.split.sort)
|
220
|
+
assert(File.exist?(cookiefile2.path))
|
221
|
+
File.unlink(cookiefile2.path)
|
222
|
+
@cm.save_cookies()
|
223
|
+
assert(File.exist?(cookiefile2.path))
|
343
224
|
end
|
344
225
|
|
345
226
|
def test_not_saved_expired_cookies
|
346
|
-
|
347
|
-
|
348
|
-
|
349
|
-
|
350
|
-
|
351
|
-
|
352
|
-
|
353
|
-
|
354
|
-
|
355
|
-
|
356
|
-
|
357
|
-
ensure
|
358
|
-
File.unlink("tmp_test.tmp") if File.exist?("tmp_test.tmp")
|
359
|
-
end
|
227
|
+
cookiefile = Tempfile.new('test_cookie')
|
228
|
+
@cm.cookies_file = cookiefile.path
|
229
|
+
uri = urify('http://www.example.org')
|
230
|
+
@cm.parse("foo=1; path=/", uri)
|
231
|
+
@cm.parse("bar=2; path=/; expires=", uri)
|
232
|
+
@cm.parse("baz=3; path=/; expires=\"\"", uri)
|
233
|
+
@cm.parse("qux=4; path=/; expires=#{(Time.now.gmtime + 10).asctime}", uri)
|
234
|
+
@cm.parse("quxx=5; path=/; expires=#{(Time.now.gmtime - 10).asctime}", uri)
|
235
|
+
@cm.save_cookies
|
236
|
+
@cm.load_cookies
|
237
|
+
assert_equal(1, @cm.cookies.size) # +10 cookies only
|
360
238
|
end
|
361
239
|
|
362
240
|
def test_add()
|
363
|
-
c = WebAgent::Cookie.new()
|
364
|
-
c.name = "hoge"
|
365
|
-
c.value = "funi"
|
241
|
+
c = WebAgent::Cookie.new('hoge', 'funi')
|
366
242
|
c.url = urify("http://www.inac.co.jp/hoge")
|
367
243
|
@cm.add(c)
|
368
244
|
c = @cm.cookies[0]
|
@@ -372,41 +248,62 @@ EOF
|
|
372
248
|
end
|
373
249
|
|
374
250
|
def test_add2()
|
375
|
-
c = WebAgent::Cookie.new()
|
376
|
-
c.name = "hoge"
|
377
|
-
c.value = "funi"
|
251
|
+
c = WebAgent::Cookie.new('hoge', 'funi')
|
378
252
|
c.path = ''
|
379
253
|
c.url = urify("http://www.inac.co.jp/hoge/hoge2/hoge3")
|
380
254
|
@cm.add(c)
|
381
255
|
#
|
382
|
-
c = WebAgent::Cookie.new()
|
383
|
-
c.name = "hoge"
|
384
|
-
c.value = "funi"
|
256
|
+
c = WebAgent::Cookie.new('hoge', 'funi')
|
385
257
|
#c.path = '' NO path given -> same as URL
|
386
258
|
c.url = urify("http://www.inac.co.jp/hoge/hoge2/hoge3")
|
387
259
|
@cm.add(c)
|
388
260
|
#
|
389
261
|
c1, c2 = @cm.cookies
|
390
|
-
assert_equal('', c1.path)
|
391
|
-
assert_equal('/
|
262
|
+
assert_equal('/hoge/hoge2/', c1.path)
|
263
|
+
assert_equal('/', c2.path)
|
264
|
+
end
|
265
|
+
|
266
|
+
def test_keep_escaped
|
267
|
+
uri = urify('http://www.example.org')
|
268
|
+
|
269
|
+
@cm.parse("bar=2; path=/", uri)
|
270
|
+
c = @cm.cookies.first
|
271
|
+
assert_equal('2', c.value)
|
272
|
+
assert_equal('bar=2', @cm.find(uri))
|
273
|
+
|
274
|
+
@cm.parse("bar=\"2\"; path=/", uri)
|
275
|
+
c = @cm.cookies.first
|
276
|
+
assert_equal('2', c.value)
|
277
|
+
assert_equal('bar=2', @cm.find(uri))
|
278
|
+
|
279
|
+
@cm.parse("bar=; path=/", uri)
|
280
|
+
c = @cm.cookies.first
|
281
|
+
assert_equal('', c.value)
|
282
|
+
assert_equal('bar=', @cm.find(uri))
|
283
|
+
|
284
|
+
@cm.parse("bar=\"\"; path=/", uri)
|
285
|
+
c = @cm.cookies.first
|
286
|
+
assert_equal('', c.value)
|
287
|
+
assert_equal('bar=', @cm.find(uri))
|
392
288
|
end
|
393
289
|
|
394
|
-
def
|
395
|
-
|
396
|
-
|
397
|
-
|
398
|
-
|
399
|
-
|
400
|
-
|
401
|
-
|
402
|
-
|
403
|
-
|
404
|
-
|
405
|
-
|
406
|
-
|
407
|
-
|
408
|
-
assert_equal(
|
409
|
-
assert_equal(
|
290
|
+
def test_load_cookies_escaped
|
291
|
+
uri = urify('http://example.org/')
|
292
|
+
f = Tempfile.new('test_cookie')
|
293
|
+
File.open(f.path, 'w') do |f|
|
294
|
+
f.write <<EOF
|
295
|
+
http://example.org/ key1 "value" 0 .example.org / 13 0
|
296
|
+
http://example.org/ key2 "" 0 .example.org / 13 0
|
297
|
+
http://example.org/ key3 0 .example.org / 13 0
|
298
|
+
EOF
|
299
|
+
end
|
300
|
+
@cm.cookies_file = f.path
|
301
|
+
@cm.load_cookies
|
302
|
+
c0, c1, c2 = @cm.cookies
|
303
|
+
assert_equal('"value"', c0.value)
|
304
|
+
assert_equal('""', c1.value)
|
305
|
+
assert_equal('', c2.value)
|
306
|
+
assert_equal('key1="\\"value\\""; key2="\\"\\""; key3=', @cm.find(uri))
|
410
307
|
end
|
411
308
|
|
412
309
|
end
|