summaryrefslogtreecommitdiffstats
path: root/Lib
diff options
context:
space:
mode:
authorMichael W. Hudson <mwh@python.net>2002-03-18 13:06:00 (GMT)
committerMichael W. Hudson <mwh@python.net>2002-03-18 13:06:00 (GMT)
commitbd3e771a979de04e273f735e69fb8842006137be (patch)
tree9af3ccf4b84b034358b9ee4c23be964c2481b5ba /Lib
parent5c137c225113764faae183034e7a85175a699ae2 (diff)
downloadcpython-bd3e771a979de04e273f735e69fb8842006137be.zip
cpython-bd3e771a979de04e273f735e69fb8842006137be.tar.gz
cpython-bd3e771a979de04e273f735e69fb8842006137be.tar.bz2
amk's fix attached to
[ 516299 ] urlparse can get fragments wrong
Diffstat (limited to 'Lib')
-rw-r--r--Lib/test/output/test_urlparse5
-rw-r--r--Lib/test/test_urlparse.py18
-rw-r--r--Lib/urlparse.py4
3 files changed, 26 insertions, 1 deletions
diff --git a/Lib/test/output/test_urlparse b/Lib/test/output/test_urlparse
index ca71729..c478783 100644
--- a/Lib/test/output/test_urlparse
+++ b/Lib/test/output/test_urlparse
@@ -1,4 +1,9 @@
test_urlparse
+http://www.python.org = ('http', 'www.python.org', '', '', '', '')
+http://www.python.org#abc = ('http', 'www.python.org', '', '', '', 'abc')
+http://www.python.org/#abc = ('http', 'www.python.org', '/', '', '', 'abc')
+http://a/b/c/d;p?q#f = ('http', 'a', '/b/c/d', 'p', 'q', 'f')
+
urlparse.urljoin() tests
g:h = 'g:h'
diff --git a/Lib/test/test_urlparse.py b/Lib/test/test_urlparse.py
index 20336bc..48c526b 100644
--- a/Lib/test/test_urlparse.py
+++ b/Lib/test/test_urlparse.py
@@ -4,6 +4,24 @@ errors = 0
RFC1808_BASE = "http://a/b/c/d;p?q#f"
+for url, expected in [('http://www.python.org',
+ ('http', 'www.python.org', '', '', '', '')),
+ ('http://www.python.org#abc',
+ ('http', 'www.python.org', '', '', '', 'abc')),
+ ('http://www.python.org/#abc',
+ ('http', 'www.python.org', '/', '', '', 'abc')),
+ (RFC1808_BASE,
+ ('http', 'a', '/b/c/d', 'p', 'q', 'f')),
+ ]:
+ result = urlparse.urlparse(url)
+ print "%-13s = %r" % (url, result)
+ if result != expected:
+ errors += 1
+ print "urlparse(%r)" % url
+ print ("expected %r,\n"
+ " got %r") % (expected, result)
+print
+
def checkJoin(relurl, expected):
global errors
result = urlparse.urljoin(RFC1808_BASE, relurl)
diff --git a/Lib/urlparse.py b/Lib/urlparse.py
index cd6ad26..ee99645 100644
--- a/Lib/urlparse.py
+++ b/Lib/urlparse.py
@@ -87,7 +87,9 @@ def urlsplit(url, scheme='', allow_fragments=1):
if url[:2] == '//':
i = url.find('/', 2)
if i < 0:
- i = len(url)
+ i = url.find('#')
+ if i < 0:
+ i = len(url)
netloc = url[2:i]
url = url[i:]
if allow_fragments and '#' in url: