merge from 3.1
This commit is contained in:
commit
56f1e2d875
|
@ -27,9 +27,12 @@ def url2pathname(url):
|
|||
drive = comp[0][-1].upper()
|
||||
components = comp[1].split('/')
|
||||
path = drive + ':'
|
||||
for comp in components:
|
||||
for comp in components:
|
||||
if comp:
|
||||
path = path + '\\' + urllib.parse.unquote(comp)
|
||||
# Issue #11474 - handing url such as |c/|
|
||||
if path.endswith(':') and url.endswith('/'):
|
||||
path += '\\'
|
||||
return path
|
||||
|
||||
def pathname2url(p):
|
||||
|
|
|
@ -9,6 +9,7 @@ import io
|
|||
import unittest
|
||||
from test import support
|
||||
import os
|
||||
import sys
|
||||
import tempfile
|
||||
|
||||
def hexescape(char):
|
||||
|
@ -1021,6 +1022,23 @@ class Pathname_Tests(unittest.TestCase):
|
|||
"url2pathname() failed; %s != %s" %
|
||||
(expect, result))
|
||||
|
||||
@unittest.skipUnless(sys.platform == 'win32',
|
||||
'test specific to the urllib.url2path function.')
|
||||
def test_ntpath(self):
|
||||
given = ('/C:/', '///C:/', '/C|//')
|
||||
expect = 'C:\\'
|
||||
for url in given:
|
||||
result = urllib.request.url2pathname(url)
|
||||
self.assertEqual(expect, result,
|
||||
'urllib.request..url2pathname() failed; %s != %s' %
|
||||
(expect, result))
|
||||
given = '///C|/path'
|
||||
expect = 'C:\\path'
|
||||
result = urllib.request.url2pathname(given)
|
||||
self.assertEqual(expect, result,
|
||||
'urllib.request.url2pathname() failed; %s != %s' %
|
||||
(expect, result))
|
||||
|
||||
class Utility_Tests(unittest.TestCase):
|
||||
"""Testcase to test the various utility functions in the urllib."""
|
||||
|
||||
|
|
Loading…
Reference in New Issue