From: Georg Brandl Date: Sat, 22 Jan 2011 22:06:24 +0000 (+0000) Subject: #10983: fix several bugs in the _tunnel implementation that seem to have missed while... X-Git-Tag: v3.2rc2~82 X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=c7c199f9077992fe949c97d25fdf95c387379c3b;p=python #10983: fix several bugs in the _tunnel implementation that seem to have missed while porting between branches. A unittest is needed! --- diff --git a/Lib/http/client.py b/Lib/http/client.py index 347aa61c9c..36b734929b 100644 --- a/Lib/http/client.py +++ b/Lib/http/client.py @@ -653,6 +653,7 @@ class HTTPConnection: self._method = None self._tunnel_host = None self._tunnel_port = None + self._tunnel_headers = {} self._set_hostport(host, port) @@ -691,15 +692,16 @@ class HTTPConnection: def _tunnel(self): self._set_hostport(self._tunnel_host, self._tunnel_port) - connect_str = "CONNECT %s:%d HTTP/1.0\r\n" %(self.host, self.port) + connect_str = "CONNECT %s:%d HTTP/1.0\r\n" % (self.host, self.port) connect_bytes = connect_str.encode("ascii") self.send(connect_bytes) - for header, value in self._tunnel_headers.iteritems(): + for header, value in self._tunnel_headers.items(): header_str = "%s: %s\r\n" % (header, value) header_bytes = header_str.encode("latin1") self.send(header_bytes) + self.send(b'\r\n') - response = self.response_class(self.sock, method = self._method) + response = self.response_class(self.sock, method=self._method) (version, code, message) = response._read_status() if code != 200: diff --git a/Misc/NEWS b/Misc/NEWS index 22bc428789..22766433e3 100644 --- a/Misc/NEWS +++ b/Misc/NEWS @@ -16,6 +16,8 @@ Core and Builtins Library ------- +- Issue #10983: Fix several bugs making tunnel requests in http.client. + - Issue #10955: zipimport uses ASCII encoding instead of cp497 to decode filenames, at bootstrap, if the codec registry is not ready yet. It is still possible to have non-ASCII filenames using the Unicode flag (UTF-8 encoding)