New submission from Serhiy Storchaka:
posixpath.join() raises misleading exception in case when all arguments are
bytearrays:
>>> import posixpath
>>> posixpath.join(bytearray(b'foo'), bytearray(b'bar'))
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
File "/home/serhiy/py/cpython/Lib/posixpath.py", line 91, in join
"components.") from None
TypeError: Can't mix strings and bytes in path components.
This bug was introduced in issue15377 and misleading test which provoked it was
added in issue15180.
I proposed two patches. Patch for 3.4 only eliminates wrong specialcasing of
bytearray (none of os.path methods work with bytearray). Patch for 3.5 also
adds better error messages for wrong argument types of posixpath.join (of
course we can apply it to 3.4 too).
----------
components: Library (Lib)
files: posixpath_join_bytearray-3.4.diff
keywords: patch
messages: 223654
nosy: hynek, ncoghlan, serhiy.storchaka
priority: normal
severity: normal
stage: patch review
status: open
title: posixpath.join() and bytearray
type: behavior
versions: Python 3.4, Python 3.5
Added file: http://bugs.python.org/file36028/posixpath_join_bytearray-3.4.diff
_______________________________________
Python tracker <[email protected]>
<http://bugs.python.org/issue22034>
_______________________________________
_______________________________________________
Python-bugs-list mailing list
Unsubscribe:
https://mail.python.org/mailman/options/python-bugs-list/archive%40mail-archive.com