diff options
author | yugui <yugui@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2010-01-30 12:54:29 +0000 |
---|---|---|
committer | yugui <yugui@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2010-01-30 12:54:29 +0000 |
commit | 0777c729cd1ae095ce18b55fb1cdf20b0d34cb0d (patch) | |
tree | 44b595908f6da0ed3b0602cef57114bddb3dd2c3 /test | |
parent | a2339bc02147505ae459293c9fece5ae17b5f285 (diff) |
merges r25579 and r25581 from trunk into ruby_1_9_1.
--
* lib/net/http.rb (Net::HTTPResponse#each_response_header):
accept multiline message header of HTTP response. see #1796.
cf. RFC 2616 '4.2 Message Header'.
* test/net/http/test_httpresponse.rb: added.
--
* lib/net/http.rb (Net::HTTPResponse#each_response_header):
cosmetic: '?\ ' -> '?\s'
git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/branches/ruby_1_9_1@26511 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'test')
-rw-r--r-- | test/net/http/test_httpresponse.rb | 40 |
1 files changed, 40 insertions, 0 deletions
diff --git a/test/net/http/test_httpresponse.rb b/test/net/http/test_httpresponse.rb new file mode 100644 index 0000000000..ab6fdd0ea9 --- /dev/null +++ b/test/net/http/test_httpresponse.rb @@ -0,0 +1,40 @@ +require 'net/http' +require 'test/unit' +require 'stringio' + +class HTTPResponseTest < Test::Unit::TestCase + def test_singleline_header + io = dummy_io(<<EOS.gsub(/\n/, "\r\n")) +HTTP/1.1 200 OK +Content-Length: 5 +Connection: close + +hello +EOS + res = Net::HTTPResponse.read_new(io) + assert_equal('5', res.header['content-length']) + assert_equal('close', res.header['connection']) + end + + def test_multiline_header + io = dummy_io(<<EOS.gsub(/\n/, "\r\n")) +HTTP/1.1 200 OK +X-Foo: XXX + YYY +X-Bar: + XXX +\tYYY + +hello +EOS + res = Net::HTTPResponse.read_new(io) + assert_equal('XXX YYY', res.header['x-foo']) + assert_equal('XXX YYY', res.header['x-bar']) + end + +private + + def dummy_io(str) + Net::BufferedIO.new(StringIO.new(str)) + end +end |