Commit 4c69be22 authored by aiudirog's avatar aiudirog Committed by Serhiy Storchaka

bpo-34775: Return NotImplemented in PurePath division. (GH-9509)

parent 0378d986
...@@ -907,10 +907,16 @@ class PurePath(object): ...@@ -907,10 +907,16 @@ class PurePath(object):
return self._make_child(args) return self._make_child(args)
def __truediv__(self, key): def __truediv__(self, key):
return self._make_child((key,)) try:
return self._make_child((key,))
except TypeError:
return NotImplemented
def __rtruediv__(self, key): def __rtruediv__(self, key):
return self._from_parts([key] + self._parts) try:
return self._from_parts([key] + self._parts)
except TypeError:
return NotImplemented
@property @property
def parent(self): def parent(self):
......
...@@ -2329,5 +2329,46 @@ class WindowsPathTest(_BasePathTest, unittest.TestCase): ...@@ -2329,5 +2329,46 @@ class WindowsPathTest(_BasePathTest, unittest.TestCase):
check() check()
class CompatiblePathTest(unittest.TestCase):
"""
Test that a type can be made compatible with PurePath
derivatives by implementing division operator overloads.
"""
class CompatPath:
"""
Minimum viable class to test PurePath compatibility.
Simply uses the division operator to join a given
string and the string value of another object with
a forward slash.
"""
def __init__(self, string):
self.string = string
def __truediv__(self, other):
return type(self)(f"{self.string}/{other}")
def __rtruediv__(self, other):
return type(self)(f"{other}/{self.string}")
def test_truediv(self):
result = pathlib.PurePath("test") / self.CompatPath("right")
self.assertIsInstance(result, self.CompatPath)
self.assertEqual(result.string, "test/right")
with self.assertRaises(TypeError):
# Verify improper operations still raise a TypeError
pathlib.PurePath("test") / 10
def test_rtruediv(self):
result = self.CompatPath("left") / pathlib.PurePath("test")
self.assertIsInstance(result, self.CompatPath)
self.assertEqual(result.string, "left/test")
with self.assertRaises(TypeError):
# Verify improper operations still raise a TypeError
10 / pathlib.PurePath("test")
if __name__ == "__main__": if __name__ == "__main__":
unittest.main() unittest.main()
Division handling of PurePath now returns NotImplemented instead of raising
a TypeError when passed something other than an instance of str or PurePath.
Patch by Roger Aiudi.
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment