diff options
author | Victor Stinner <vstinner@python.org> | 2020-03-20 14:10:14 (GMT) |
---|---|---|
committer | GitHub <noreply@github.com> | 2020-03-20 14:10:14 (GMT) |
commit | ba26bf30940f4347fedcf8ebc374c6e2dc375afa (patch) | |
tree | 9e5c8fdd01d05f0086650963ce7355a0a880ff22 /Lib/test | |
parent | 29723368e797f36ba8940f25b6e677852b7313b2 (diff) | |
download | cpython-ba26bf30940f4347fedcf8ebc374c6e2dc375afa.zip cpython-ba26bf30940f4347fedcf8ebc374c6e2dc375afa.tar.gz cpython-ba26bf30940f4347fedcf8ebc374c6e2dc375afa.tar.bz2 |
[3.8] bpo-27807: Skip test_site.test_startup_imports() if pth file (GH-19060) (GH-19090)
test_site.test_startup_imports() is now skipped if a path of sys.path
contains a .pth file.
Sort test_site imports.
Diffstat (limited to 'Lib/test')
-rw-r--r-- | Lib/test/test_site.py | 19 |
1 files changed, 19 insertions, 0 deletions
diff --git a/Lib/test/test_site.py b/Lib/test/test_site.py index 41c4229..1bbc697 100644 --- a/Lib/test/test_site.py +++ b/Lib/test/test_site.py @@ -10,6 +10,7 @@ from test import support from test.support import (captured_stderr, TESTFN, EnvironmentVarGuard, change_cwd) import builtins +import glob import os import sys import re @@ -512,6 +513,23 @@ class ImportSideEffectTests(unittest.TestCase): class StartupImportTests(unittest.TestCase): def test_startup_imports(self): + # Get sys.path in isolated mode (python3 -I) + popen = subprocess.Popen([sys.executable, '-I', '-c', + 'import sys; print(repr(sys.path))'], + stdout=subprocess.PIPE, + encoding='utf-8') + stdout = popen.communicate()[0] + self.assertEqual(popen.returncode, 0, repr(stdout)) + isolated_paths = eval(stdout) + + # bpo-27807: Even with -I, the site module executes all .pth files + # found in sys.path (see site.addpackage()). Skip the test if at least + # one .pth file is found. + for path in isolated_paths: + pth_files = glob.glob(os.path.join(path, "*.pth")) + if pth_files: + self.skipTest(f"found {len(pth_files)} .pth files in: {path}") + # This tests checks which modules are loaded by Python when it # initially starts upon startup. popen = subprocess.Popen([sys.executable, '-I', '-v', '-c', @@ -520,6 +538,7 @@ class StartupImportTests(unittest.TestCase): stderr=subprocess.PIPE, encoding='utf-8') stdout, stderr = popen.communicate() + self.assertEqual(popen.returncode, 0, (stdout, stderr)) modules = eval(stdout) self.assertIn('site', modules) |