Merged revisions 86450 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/branches/py3k ........ r86450 | senthil.kumaran | 2010-11-13 20:27:49 +0800 (Sat, 13 Nov 2010) | 3 lines Fix Issue5111 - Wrap the Ipv6 host with [] in the Host header ........
This commit is contained in:
parent
650db5bd68
commit
2e89cf3465
@ -873,6 +873,13 @@ class HTTPConnection:
|
|||||||
host_enc = self.host.encode("ascii")
|
host_enc = self.host.encode("ascii")
|
||||||
except UnicodeEncodeError:
|
except UnicodeEncodeError:
|
||||||
host_enc = self.host.encode("idna")
|
host_enc = self.host.encode("idna")
|
||||||
|
|
||||||
|
# As per RFC 273, IPv6 address should be wrapped with []
|
||||||
|
# when used as Host header
|
||||||
|
|
||||||
|
if self.host.find(':') >= 0:
|
||||||
|
host_enc = b'[' + host_enc + b']'
|
||||||
|
|
||||||
if self.port == self.default_port:
|
if self.port == self.default_port:
|
||||||
self.putheader('Host', host_enc)
|
self.putheader('Host', host_enc)
|
||||||
else:
|
else:
|
||||||
|
@ -96,6 +96,25 @@ class HeaderTests(TestCase):
|
|||||||
conn.putheader('Content-length', 42)
|
conn.putheader('Content-length', 42)
|
||||||
self.assertTrue(b'Content-length: 42' in conn._buffer)
|
self.assertTrue(b'Content-length: 42' in conn._buffer)
|
||||||
|
|
||||||
|
def test_ipv6host_header(self):
|
||||||
|
# Default host header on IPv6 transaction should wrapped by [] if
|
||||||
|
# its actual IPv6 address
|
||||||
|
expected = b'GET /foo HTTP/1.1\r\nHost: [2001::]:81\r\n' \
|
||||||
|
b'Accept-Encoding: identity\r\n\r\n'
|
||||||
|
conn = client.HTTPConnection('[2001::]:81')
|
||||||
|
sock = FakeSocket('')
|
||||||
|
conn.sock = sock
|
||||||
|
conn.request('GET', '/foo')
|
||||||
|
self.assertTrue(sock.data.startswith(expected))
|
||||||
|
|
||||||
|
expected = b'GET /foo HTTP/1.1\r\nHost: [2001:102A::]\r\n' \
|
||||||
|
b'Accept-Encoding: identity\r\n\r\n'
|
||||||
|
conn = client.HTTPConnection('[2001:102A::]')
|
||||||
|
sock = FakeSocket('')
|
||||||
|
conn.sock = sock
|
||||||
|
conn.request('GET', '/foo')
|
||||||
|
self.assertTrue(sock.data.startswith(expected))
|
||||||
|
|
||||||
|
|
||||||
class BasicTest(TestCase):
|
class BasicTest(TestCase):
|
||||||
def test_status_lines(self):
|
def test_status_lines(self):
|
||||||
|
@ -155,6 +155,8 @@ C-API
|
|||||||
Library
|
Library
|
||||||
-------
|
-------
|
||||||
|
|
||||||
|
- Issue #5111: IPv6 Host in the Header is wrapped inside [ ]. Patch by Chandru.
|
||||||
|
|
||||||
- Issue #4471: Properly shutdown socket in IMAP.shutdown(). Patch by
|
- Issue #4471: Properly shutdown socket in IMAP.shutdown(). Patch by
|
||||||
Lorenzo M. Catucci.
|
Lorenzo M. Catucci.
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user