1
0
Fork 0
mirror of https://github.com/ruby/ruby.git synced 2022-11-09 12:17:21 -05:00

* 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.


git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@25579 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
This commit is contained in:
nahi 2009-10-30 13:09:03 +00:00
parent 104c5f6b55
commit d1cb4a5ba7
3 changed files with 58 additions and 3 deletions

View file

@ -1,3 +1,11 @@
Fri Oct 30 22:09:47 2009 NAKAMURA, Hiroshi <nahi@ruby-lang.org>
* 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.
Fri Oct 30 18:54:04 2009 Yukihiro Matsumoto <matz@ruby-lang.org>
* string.c (trnext): detect empty range and raise exception.

View file

@ -2158,13 +2158,20 @@ module Net #:nodoc:
end
def each_response_header(sock)
key = value = nil
while true
line = sock.readuntil("\n", true).sub(/\s+\z/, '')
break if line.empty?
m = /\A([^:]+):\s*/.match(line) or
raise HTTPBadResponse, 'wrong header line format'
yield m[1], m.post_match
if line[0] == ?\ or line[0] == ?\t and value
value << ' ' unless value.empty?
value << line.strip
else
yield key, value if key
key, value = line.strip.split(/\s*:\s*/, 2)
raise HTTPBadResponse, 'wrong header line format' if value.nil?
end
end
yield key, value if key
end
end

View file

@ -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