diff options
Diffstat (limited to 'Lib/test/test_posixpath.py')
| -rw-r--r-- | Lib/test/test_posixpath.py | 66 | 
1 files changed, 54 insertions, 12 deletions
| diff --git a/Lib/test/test_posixpath.py b/Lib/test/test_posixpath.py index 1d4596e..9d20471 100644 --- a/Lib/test/test_posixpath.py +++ b/Lib/test/test_posixpath.py @@ -57,18 +57,6 @@ class PosixPathTest(unittest.TestCase):          self.assertEqual(posixpath.join(b"/foo/", b"bar/", b"baz/"),                           b"/foo/bar/baz/") -    def test_join_errors(self): -        # Check posixpath.join raises friendly TypeErrors. -        errmsg = "Can't mix strings and bytes in path components" -        with self.assertRaisesRegex(TypeError, errmsg): -            posixpath.join(b'bytes', 'str') -        with self.assertRaisesRegex(TypeError, errmsg): -            posixpath.join('str', b'bytes') -        # regression, see #15377 -        with self.assertRaises(TypeError) as cm: -            posixpath.join(None, 'str') -        self.assertNotEqual(cm.exception.args[0], errmsg) -      def test_split(self):          self.assertEqual(posixpath.split("/foo/bar"), ("/foo", "bar"))          self.assertEqual(posixpath.split("/"), ("/", "")) @@ -523,6 +511,60 @@ class PosixPathTest(unittest.TestCase):          finally:              os.getcwdb = real_getcwdb +    def test_commonpath(self): +        def check(paths, expected): +            self.assertEqual(posixpath.commonpath(paths), expected) +            self.assertEqual(posixpath.commonpath([os.fsencode(p) for p in paths]), +                             os.fsencode(expected)) +        def check_error(exc, paths): +            self.assertRaises(exc, posixpath.commonpath, paths) +            self.assertRaises(exc, posixpath.commonpath, +                              [os.fsencode(p) for p in paths]) + +        self.assertRaises(ValueError, posixpath.commonpath, []) +        check_error(ValueError, ['/usr', 'usr']) +        check_error(ValueError, ['usr', '/usr']) + +        check(['/usr/local'], '/usr/local') +        check(['/usr/local', '/usr/local'], '/usr/local') +        check(['/usr/local/', '/usr/local'], '/usr/local') +        check(['/usr/local/', '/usr/local/'], '/usr/local') +        check(['/usr//local', '//usr/local'], '/usr/local') +        check(['/usr/./local', '/./usr/local'], '/usr/local') +        check(['/', '/dev'], '/') +        check(['/usr', '/dev'], '/') +        check(['/usr/lib/', '/usr/lib/python3'], '/usr/lib') +        check(['/usr/lib/', '/usr/lib64/'], '/usr') + +        check(['/usr/lib', '/usr/lib64'], '/usr') +        check(['/usr/lib/', '/usr/lib64'], '/usr') + +        check(['spam'], 'spam') +        check(['spam', 'spam'], 'spam') +        check(['spam', 'alot'], '') +        check(['and/jam', 'and/spam'], 'and') +        check(['and//jam', 'and/spam//'], 'and') +        check(['and/./jam', './and/spam'], 'and') +        check(['and/jam', 'and/spam', 'alot'], '') +        check(['and/jam', 'and/spam', 'and'], 'and') + +        check([''], '') +        check(['', 'spam/alot'], '') +        check_error(ValueError, ['', '/spam/alot']) + +        self.assertRaises(TypeError, posixpath.commonpath, +                          [b'/usr/lib/', '/usr/lib/python3']) +        self.assertRaises(TypeError, posixpath.commonpath, +                          [b'/usr/lib/', 'usr/lib/python3']) +        self.assertRaises(TypeError, posixpath.commonpath, +                          [b'usr/lib/', '/usr/lib/python3']) +        self.assertRaises(TypeError, posixpath.commonpath, +                          ['/usr/lib/', b'/usr/lib/python3']) +        self.assertRaises(TypeError, posixpath.commonpath, +                          ['/usr/lib/', b'usr/lib/python3']) +        self.assertRaises(TypeError, posixpath.commonpath, +                          ['usr/lib/', b'/usr/lib/python3']) +  class PosixCommonTest(test_genericpath.CommonTest, unittest.TestCase):      pathmodule = posixpath | 
