[Python-checkins] cpython: Fix #17272 - Make Request.full_url and Request.get_full_url return same result

senthil.kumaran python-checkins at python.org
Fri May 24 18:14:35 CEST 2013


http://hg.python.org/cpython/rev/51c5870144e7
changeset: 83909:51c5870144e7
user: Senthil Kumaran <senthil at uthcode.com>
date: Fri May 24 09:14:12 2013 -0700
summary:
 Fix #17272 - Make Request.full_url and Request.get_full_url return same result under all circumstances.
Document the change of Request.full_url to a property.
files:
 Doc/library/urllib.request.rst | 10 ++++++++++
 Lib/test/test_urllib2.py | 15 +++++++++++++++
 Lib/test/test_urllib2net.py | 8 ++++++++
 Lib/urllib/request.py | 4 ++--
 4 files changed, 35 insertions(+), 2 deletions(-)
diff --git a/Doc/library/urllib.request.rst b/Doc/library/urllib.request.rst
--- a/Doc/library/urllib.request.rst
+++ b/Doc/library/urllib.request.rst
@@ -396,6 +396,12 @@
 
 The original URL passed to the constructor.
 
+ .. versionchanged:: 3.4
+
+ Request.full_url is a property with setter, getter and a deleter. Getting
+ :attr:`~Request.full_url` returns the original request URL with the
+ fragment, if it was present.
+
 .. attribute:: Request.type
 
 The URI scheme.
@@ -482,6 +488,10 @@
 
 Return the URL given in the constructor.
 
+ .. versionchanged:: 3.4
+
+ Returns :attr:`Request.full_url`
+
 
 .. method:: Request.set_proxy(host, type)
 
diff --git a/Lib/test/test_urllib2.py b/Lib/test/test_urllib2.py
--- a/Lib/test/test_urllib2.py
+++ b/Lib/test/test_urllib2.py
@@ -11,6 +11,7 @@
 # The proxy bypass method imported below has logic specific to the OSX
 # proxy config data structure but is testable on all platforms.
 from urllib.request import Request, OpenerDirector, _proxy_bypass_macosx_sysconf
+from urllib.parse import urlparse
 import urllib.error
 
 # XXX
@@ -919,7 +920,13 @@
 r = Request('http://example.com')
 for url in urls:
 r.full_url = url
+ parsed = urlparse(url)
+
 self.assertEqual(r.get_full_url(), url)
+ # full_url setter uses splittag to split into components.
+ # splittag sets the fragment as None while urlparse sets it to ''
+ self.assertEqual(r.fragment or '', parsed.fragment)
+ self.assertEqual(urlparse(r.get_full_url()).query, parsed.query)
 
 def test_full_url_deleter(self):
 r = Request('http://www.example.com')
@@ -1537,6 +1544,14 @@
 req = Request(url)
 self.assertEqual(req.get_full_url(), url)
 
+ def test_url_fullurl_get_full_url(self):
+ urls = ['http://docs.python.org',
+ 'http://docs.python.org/library/urllib2.html#OK',
+ 'http://www.python.org/?qs=query#fragment=true' ]
+ for url in urls:
+ req = Request(url)
+ self.assertEqual(req.get_full_url(), req.full_url)
+
 def test_main(verbose=None):
 from test import test_urllib2
 support.run_doctest(test_urllib2, verbose)
diff --git a/Lib/test/test_urllib2net.py b/Lib/test/test_urllib2net.py
--- a/Lib/test/test_urllib2net.py
+++ b/Lib/test/test_urllib2net.py
@@ -164,6 +164,14 @@
 self.assertEqual(res.geturl(),
 "http://docs.python.org/2/glossary.html#glossary")
 
+ def test_redirect_url_withfrag(self):
+ redirect_url_with_frag = "http://bitly.com/urllibredirecttest"
+ with support.transient_internet(redirect_url_with_frag):
+ req = urllib.request.Request(redirect_url_with_frag)
+ res = urllib.request.urlopen(req)
+ self.assertEqual(res.geturl(),
+ "http://docs.python.org/3.4/glossary.html#term-global-interpreter-lock")
+
 def test_custom_headers(self):
 url = "http://www.example.com"
 with support.transient_internet(url):
diff --git a/Lib/urllib/request.py b/Lib/urllib/request.py
--- a/Lib/urllib/request.py
+++ b/Lib/urllib/request.py
@@ -275,6 +275,8 @@
 
 @property
 def full_url(self):
+ if self.fragment:
+ return '{}#{}'.format(self._full_url, self.fragment)
 return self._full_url
 
 @full_url.setter
@@ -326,8 +328,6 @@
 return "GET"
 
 def get_full_url(self):
- if self.fragment:
- return '{}#{}'.format(self.full_url, self.fragment)
 return self.full_url
 
 def set_proxy(self, host, type):
-- 
Repository URL: http://hg.python.org/cpython


More information about the Python-checkins mailing list

AltStyle によって変換されたページ (->オリジナル) /