diff options
author | Zackery Spytz <zspytz@gmail.com> | 2024-04-03 07:17:13 -0700 |
---|---|---|
committer | GitHub <noreply@github.com> | 2024-04-03 16:17:13 +0200 |
commit | fc5f68e58ecfbc8c452e1c2f33a2a53d3f2d7ea2 (patch) | |
tree | 0138ade12916a1453a5cf316b5176984ee1ca867 /Lib/test/test_unittest | |
parent | ea94b3b149eeadf33c2f7c46f16dcda0adc7cf4e (diff) | |
download | cpython-fc5f68e58ecfbc8c452e1c2f33a2a53d3f2d7ea2.tar.gz cpython-fc5f68e58ecfbc8c452e1c2f33a2a53d3f2d7ea2.zip |
gh-59215: unittest: restore _top_level_dir at end of discovery (GH-15242)
Diffstat (limited to 'Lib/test/test_unittest')
-rw-r--r-- | Lib/test/test_unittest/test_discovery.py | 26 |
1 files changed, 25 insertions, 1 deletions
diff --git a/Lib/test/test_unittest/test_discovery.py b/Lib/test/test_unittest/test_discovery.py index 004898ed431..a44b18406c0 100644 --- a/Lib/test/test_unittest/test_discovery.py +++ b/Lib/test/test_unittest/test_discovery.py @@ -406,10 +406,34 @@ class TestDiscovery(unittest.TestCase): top_level_dir = os.path.abspath('/foo/bar') start_dir = os.path.abspath('/foo/bar/baz') self.assertEqual(suite, "['tests']") - self.assertEqual(loader._top_level_dir, top_level_dir) + self.assertEqual(loader._top_level_dir, os.path.abspath('/foo')) self.assertEqual(_find_tests_args, [(start_dir, 'pattern')]) self.assertIn(top_level_dir, sys.path) + def test_discover_should_not_persist_top_level_dir_between_calls(self): + original_isfile = os.path.isfile + original_isdir = os.path.isdir + original_sys_path = sys.path[:] + def restore(): + os.path.isfile = original_isfile + os.path.isdir = original_isdir + sys.path[:] = original_sys_path + self.addCleanup(restore) + + os.path.isfile = lambda path: True + os.path.isdir = lambda path: True + loader = unittest.TestLoader() + loader.suiteClass = str + dir = '/foo/bar' + top_level_dir = '/foo' + + loader.discover(dir, top_level_dir=top_level_dir) + self.assertEqual(loader._top_level_dir, None) + + loader._top_level_dir = dir2 = '/previous/dir' + loader.discover(dir, top_level_dir=top_level_dir) + self.assertEqual(loader._top_level_dir, dir2) + def test_discover_start_dir_is_package_calls_package_load_tests(self): # This test verifies that the package load_tests in a package is indeed # invoked when the start_dir is a package (and not the top level). |