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

This commit is contained in:
Hynek Schlawack 2012-07-15 16:21:30 +02:00
parent a3d1cac4b2
commit 4774946c3b
3 changed files with 24 additions and 8 deletions

View file

@ -74,13 +74,20 @@ 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.")
else:
path += sep + b
raise
return path

View file

@ -56,8 +56,15 @@ def test_join(self):
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

@ -87,6 +87,8 @@ Core and Builtins
Library
-------
- Issue #15180: Clarify posixpath.join() error message when mixing str & bytes
- Issue #15230: runpy.run_path now correctly sets __package__ as described
in the documentation