diff options
author | Steve Dower <steve.dower@python.org> | 2019-06-28 11:41:55 -0700 |
---|---|---|
committer | Ned Deily <nad@python.org> | 2019-07-01 22:25:25 -0400 |
commit | 57eba3aff16016be84b2fa8532b4f618fec79d97 (patch) | |
tree | 4661000b5d1af878075291ad93be1ab0cfebd234 /Lib/test | |
parent | 3c34ea97a341e4dd80b542c99c593f014a8ae410 (diff) | |
download | cpython-git-57eba3aff16016be84b2fa8532b4f618fec79d97.tar.gz |
bpo-37369: Fix venv and test symlinking (GH-14456)
Diffstat (limited to 'Lib/test')
-rw-r--r-- | Lib/test/test_platform.py | 24 | ||||
-rw-r--r-- | Lib/test/test_sysconfig.py | 17 | ||||
-rw-r--r-- | Lib/test/test_venv.py | 13 |
3 files changed, 42 insertions, 12 deletions
diff --git a/Lib/test/test_platform.py b/Lib/test/test_platform.py index 010ed6c634..d91e978a79 100644 --- a/Lib/test/test_platform.py +++ b/Lib/test/test_platform.py @@ -16,14 +16,24 @@ class PlatformTest(unittest.TestCase): @support.skip_unless_symlink def test_architecture_via_symlink(self): # issue3762 + if sys.platform == "win32" and not os.path.exists(sys.executable): + # App symlink appears to not exist, but we want the + # real executable here anyway + import _winapi + real = _winapi.GetModuleFileName(0) + else: + real = os.path.realpath(sys.executable) + link = os.path.abspath(support.TESTFN) + os.symlink(real, link) + # On Windows, the EXE needs to know where pythonXY.dll and *.pyd is at # so we add the directory to the path, PYTHONHOME and PYTHONPATH. env = None if sys.platform == "win32": env = {k.upper(): os.environ[k] for k in os.environ} env["PATH"] = "{};{}".format( - os.path.dirname(sys.executable), env.get("PATH", "")) - env["PYTHONHOME"] = os.path.dirname(sys.executable) + os.path.dirname(real), env.get("PATH", "")) + env["PYTHONHOME"] = os.path.dirname(real) if sysconfig.is_python_build(True): env["PYTHONPATH"] = os.path.dirname(os.__file__) @@ -40,11 +50,8 @@ class PlatformTest(unittest.TestCase): .format(p.returncode)) return r - real = os.path.realpath(sys.executable) - link = os.path.abspath(support.TESTFN) - os.symlink(real, link) try: - self.assertEqual(get(real), get(link, env=env)) + self.assertEqual(get(sys.executable), get(link, env=env)) finally: os.remove(link) @@ -280,6 +287,11 @@ class PlatformTest(unittest.TestCase): os.path.exists(sys.executable+'.exe'): # Cygwin horror executable = sys.executable + '.exe' + elif sys.platform == "win32" and not os.path.exists(sys.executable): + # App symlink appears to not exist, but we want the + # real executable here anyway + import _winapi + executable = _winapi.GetModuleFileName(0) else: executable = sys.executable res = platform.libc_ver(executable) diff --git a/Lib/test/test_sysconfig.py b/Lib/test/test_sysconfig.py index 1b1929885e..51bef19000 100644 --- a/Lib/test/test_sysconfig.py +++ b/Lib/test/test_sysconfig.py @@ -233,16 +233,26 @@ class TestSysConfig(unittest.TestCase): @skip_unless_symlink def test_symlink(self): + if sys.platform == "win32" and not os.path.exists(sys.executable): + # App symlink appears to not exist, but we want the + # real executable here anyway + import _winapi + real = _winapi.GetModuleFileName(0) + else: + real = os.path.realpath(sys.executable) + link = os.path.abspath(TESTFN) + os.symlink(real, link) + # On Windows, the EXE needs to know where pythonXY.dll is at so we have # to add the directory to the path. env = None if sys.platform == "win32": env = {k.upper(): os.environ[k] for k in os.environ} env["PATH"] = "{};{}".format( - os.path.dirname(sys.executable), env.get("PATH", "")) + os.path.dirname(real), env.get("PATH", "")) # Requires PYTHONHOME as well since we locate stdlib from the # EXE path and not the DLL path (which should be fixed) - env["PYTHONHOME"] = os.path.dirname(sys.executable) + env["PYTHONHOME"] = os.path.dirname(real) if sysconfig.is_python_build(True): env["PYTHONPATH"] = os.path.dirname(os.__file__) @@ -258,9 +268,6 @@ class TestSysConfig(unittest.TestCase): self.fail('Non-zero return code {0} (0x{0:08X})' .format(p.returncode)) return out, err - real = os.path.realpath(sys.executable) - link = os.path.abspath(TESTFN) - os.symlink(real, link) try: self.assertEqual(get(real), get(link, env)) finally: diff --git a/Lib/test/test_venv.py b/Lib/test/test_venv.py index c3ccb92913..67f9f46e65 100644 --- a/Lib/test/test_venv.py +++ b/Lib/test/test_venv.py @@ -58,6 +58,12 @@ class BaseTest(unittest.TestCase): self.include = 'include' executable = getattr(sys, '_base_executable', sys.executable) self.exe = os.path.split(executable)[-1] + if (sys.platform == 'win32' + and os.path.lexists(executable) + and not os.path.exists(executable)): + self.cannot_link_exe = True + else: + self.cannot_link_exe = False def tearDown(self): rmtree(self.env_dir) @@ -248,7 +254,12 @@ class BasicTest(BaseTest): # symlinked to 'python3.3' in the env, even when symlinking in # general isn't wanted. if usl: - self.assertTrue(os.path.islink(fn)) + if self.cannot_link_exe: + # Symlinking is skipped when our executable is already a + # special app symlink + self.assertFalse(os.path.islink(fn)) + else: + self.assertTrue(os.path.islink(fn)) # If a venv is created from a source build and that venv is used to # run the test, the pyvenv.cfg in the venv created in the test will |