Commit b7451cec authored by Senthil Kumaran's avatar Senthil Kumaran

Fix issue14826 - make urllib.request.Request quoted url consistent with URLOpener open method.

Patch contributed by Stephen Thorne.
parent 11f0b41e
...@@ -1246,6 +1246,11 @@ class URLopener_Tests(unittest.TestCase): ...@@ -1246,6 +1246,11 @@ class URLopener_Tests(unittest.TestCase):
# ftp.close() # ftp.close()
def test_quote_url(self):
Request = urllib.request.Request
request = Request("http://www.python.org/foo bar")
self.assertEqual(request.full_url, "http://www.python.org/foo%20bar")
def test_main(): def test_main():
support.run_unittest( support.run_unittest(
......
...@@ -180,7 +180,8 @@ class Request: ...@@ -180,7 +180,8 @@ class Request:
def __init__(self, url, data=None, headers={}, def __init__(self, url, data=None, headers={},
origin_req_host=None, unverifiable=False): origin_req_host=None, unverifiable=False):
# unwrap('<URL:type://host/path>') --> 'type://host/path' # unwrap('<URL:type://host/path>') --> 'type://host/path'
self.full_url = unwrap(url) self.full_url = unwrap(to_bytes(url))
self.full_url = quote(self.full_url, safe="%/:=&?~#+!$,;'@()*[]|")
self.full_url, self.fragment = splittag(self.full_url) self.full_url, self.fragment = splittag(self.full_url)
self.data = data self.data = data
self.headers = {} self.headers = {}
......
...@@ -87,6 +87,11 @@ Core and Builtins ...@@ -87,6 +87,11 @@ Core and Builtins
Library Library
------- -------
- Issue #14826: Quote urls in urllib.request.Request identically to how they
are quoted by urllib.request.URLopener. Allows urls to spaces in them to work
transparently with urllib.request.urlopen(...). Patch contributed by Stephen
Thorne.
- Issue #14990: Correctly fail with SyntaxError on invalid encoding - Issue #14990: Correctly fail with SyntaxError on invalid encoding
declaration. declaration.
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment