Commit 92521fea authored by Steve Dower's avatar Steve Dower Committed by Zachary Ware

bpo-38081: Fixes ntpath.realpath('NUL') (GH-15899)

parent 455122a0
...@@ -535,9 +535,10 @@ else: ...@@ -535,9 +535,10 @@ else:
try: try:
path = _nt_readlink(path) path = _nt_readlink(path)
except OSError as ex: except OSError as ex:
# Stop on file (2) or directory (3) not found, or # Stop on incorrect function (1), file (2) or
# paths that are not reparse points (4390) # directory (3) not found, or paths that are
if ex.winerror in (2, 3, 4390): # not reparse points (4390)
if ex.winerror in (1, 2, 3, 4390):
break break
raise raise
except ValueError: except ValueError:
...@@ -553,9 +554,9 @@ else: ...@@ -553,9 +554,9 @@ else:
except OSError: except OSError:
pass pass
# Allow file (2) or directory (3) not found, invalid syntax (123), # Allow file (2) or directory (3) not found, incorrect parameter (87),
# and symlinks that cannot be followed (1921) # invalid syntax (123), and symlinks that cannot be followed (1921)
allowed_winerror = 2, 3, 123, 1921 allowed_winerror = 2, 3, 87, 123, 1921
# Non-strict algorithm is to find as much of the target directory # Non-strict algorithm is to find as much of the target directory
# as we can and join the rest. # as we can and join the rest.
......
...@@ -400,6 +400,10 @@ class TestNtpath(NtpathTestCase): ...@@ -400,6 +400,10 @@ class TestNtpath(NtpathTestCase):
self.assertPathEqual(ntpath.realpath("\\\\?\\" + ABSTFN + "3.link"), self.assertPathEqual(ntpath.realpath("\\\\?\\" + ABSTFN + "3.link"),
"\\\\?\\" + ABSTFN + "3.") "\\\\?\\" + ABSTFN + "3.")
@unittest.skipUnless(HAVE_GETFINALPATHNAME, 'need _getfinalpathname')
def test_realpath_nul(self):
tester("ntpath.realpath('NUL')", r'\\.\NUL')
def test_expandvars(self): def test_expandvars(self):
with support.EnvironmentVarGuard() as env: with support.EnvironmentVarGuard() as env:
env.clear() env.clear()
......
Prevent error calling :func:`os.path.realpath` on ``'NUL'``.
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