mirror of
https://github.com/python/cpython.git
synced 2025-10-17 04:08:28 +00:00
gh-92550 - Fix regression in pathlib.Path.rglob()
(GH-92583)
We could try to remedy this by taking a slice, but we then run into an issue where the empty string will match altsep on POSIX. That rabbit hole could keep getting deeper.
A proper fix for the original issue involves making pathlib's path normalisation more configurable - in this case we want to retain trailing slashes, but in other we might want to preserve `./` prefixes, or elide `../` segments when we're sure we won't encounter symlinks.
This reverts commit ea2f5bcda1
.
This commit is contained in:
parent
cb35402c18
commit
dcdf250d2d
5 changed files with 2 additions and 38 deletions
|
@ -1662,11 +1662,6 @@ class _BasePathTest(object):
|
|||
else:
|
||||
_check(p.glob("*/fileB"), ['dirB/fileB', 'linkB/fileB'])
|
||||
|
||||
if not os_helper.can_symlink():
|
||||
_check(p.glob("*/"), ["dirA", "dirB", "dirC", "dirE"])
|
||||
else:
|
||||
_check(p.glob("*/"), ["dirA", "dirB", "dirC", "dirE", "linkB"])
|
||||
|
||||
def test_rglob_common(self):
|
||||
def _check(glob, expected):
|
||||
self.assertEqual(set(glob), { P(BASE, q) for q in expected })
|
||||
|
@ -1684,16 +1679,6 @@ class _BasePathTest(object):
|
|||
"linkB/fileB", "dirA/linkC/fileB"])
|
||||
_check(p.rglob("file*"), ["fileA", "dirB/fileB",
|
||||
"dirC/fileC", "dirC/dirD/fileD"])
|
||||
if not os_helper.can_symlink():
|
||||
_check(p.rglob("*/"), [
|
||||
"dirA", "dirB", "dirC", "dirC/dirD", "dirE",
|
||||
])
|
||||
else:
|
||||
_check(p.rglob("*/"), [
|
||||
"dirA", "dirA/linkC", "dirB", "dirB/linkD", "dirC",
|
||||
"dirC/dirD", "dirE", "linkB",
|
||||
])
|
||||
|
||||
p = P(BASE, "dirC")
|
||||
_check(p.rglob("file*"), ["dirC/fileC", "dirC/dirD/fileD"])
|
||||
_check(p.rglob("*/*"), ["dirC/dirD/fileD"])
|
||||
|
@ -2719,7 +2704,6 @@ class WindowsPathTest(_BasePathTest, unittest.TestCase):
|
|||
P = self.cls
|
||||
p = P(BASE)
|
||||
self.assertEqual(set(p.glob("FILEa")), { P(BASE, "fileA") })
|
||||
self.assertEqual(set(p.glob("*a\\")), { P(BASE, "dirA") })
|
||||
self.assertEqual(set(p.glob("F*a")), { P(BASE, "fileA") })
|
||||
self.assertEqual(set(map(str, p.glob("FILEa"))), {f"{p}\\FILEa"})
|
||||
self.assertEqual(set(map(str, p.glob("F*a"))), {f"{p}\\fileA"})
|
||||
|
@ -2728,7 +2712,6 @@ class WindowsPathTest(_BasePathTest, unittest.TestCase):
|
|||
P = self.cls
|
||||
p = P(BASE, "dirC")
|
||||
self.assertEqual(set(p.rglob("FILEd")), { P(BASE, "dirC/dirD/fileD") })
|
||||
self.assertEqual(set(p.rglob("*\\")), { P(BASE, "dirC/dirD") })
|
||||
self.assertEqual(set(map(str, p.rglob("FILEd"))), {f"{p}\\dirD\\FILEd"})
|
||||
|
||||
def test_expanduser(self):
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue