#15180: Clarify posixpath.join() error message when mixing str & bytes

This commit is contained in:
Hynek Schlawack 2012-07-15 16:46:23 +02:00
commit 9ac4d8808f
3 changed files with 25 additions and 8 deletions

View File

@ -74,13 +74,21 @@ def join(a, *p):
will be discarded."""
sep = _get_sep(a)
path = a
for b in p:
if b.startswith(sep):
path = b
elif not path or path.endswith(sep):
path += b
try:
for b in p:
if b.startswith(sep):
path = b
elif not path or path.endswith(sep):
path += b
else:
path += sep + b
except TypeError:
strs = [isinstance(s, str) for s in (a, ) + p]
if any(strs) and not all(strs):
raise TypeError("Can't mix strings and bytes in path "
"components.") from None
else:
path += sep + b
raise
return path

View File

@ -56,8 +56,15 @@ class PosixPathTest(unittest.TestCase):
self.assertEqual(posixpath.join(b"/foo/", b"bar/", b"baz/"),
b"/foo/bar/baz/")
self.assertRaises(TypeError, posixpath.join, b"bytes", "str")
self.assertRaises(TypeError, posixpath.join, "str", b"bytes")
with self.assertRaises(TypeError) as e:
posixpath.join(b'bytes', 'str')
self.assertIn("Can't mix strings and bytes", e.args[0])
with self.assertRaises(TypeError) as e:
posixpath.join('str', b'bytes')
self.assertIn("Can't mix strings and bytes", e.args[0])
with self.assertRaises(TypeError) as e:
posixpath.join('str', bytearray(b'bytes'))
self.assertIn("Can't mix strings and bytes", e.args[0])
def test_split(self):
self.assertEqual(posixpath.split("/foo/bar"), ("/foo", "bar"))

View File

@ -38,6 +38,8 @@ Core and Builtins
Library
-------
- Issue #15180: Clarify posixpath.join() error message when mixing str & bytes
- Issue #15343: pkgutil now includes an iter_importer_modules implementation
for importlib.machinery.FileFinder (similar to the way it already handled
zipimport.zipimporter)