mirror of
https://github.com/python/cpython.git
synced 2025-09-26 18:29:57 +00:00
[3.12] gh-115421: List all test subdirs in Makefile, and test them (GH-115813) (#116462)
* gh-115421: Test that our Makefile has all needed test folders (GH-115813) * Update the list of installed test subdirectories --------- Co-authored-by: Nikita Sobolev <mail@sobolevn.me>
This commit is contained in:
parent
cbd94fdb6c
commit
0ab2384c5f
2 changed files with 69 additions and 1 deletions
64
Lib/test/test_tools/test_makefile.py
Normal file
64
Lib/test/test_tools/test_makefile.py
Normal file
|
@ -0,0 +1,64 @@
|
|||
"""
|
||||
Tests for `Makefile`.
|
||||
"""
|
||||
|
||||
import os
|
||||
import unittest
|
||||
from test import support
|
||||
import sysconfig
|
||||
|
||||
MAKEFILE = sysconfig.get_makefile_filename()
|
||||
|
||||
if not support.check_impl_detail(cpython=True):
|
||||
raise unittest.SkipTest('cpython only')
|
||||
if not os.path.exists(MAKEFILE) or not os.path.isfile(MAKEFILE):
|
||||
raise unittest.SkipTest('Makefile could not be found')
|
||||
|
||||
|
||||
class TestMakefile(unittest.TestCase):
|
||||
def list_test_dirs(self):
|
||||
result = []
|
||||
found_testsubdirs = False
|
||||
with open(MAKEFILE, 'r', encoding='utf-8') as f:
|
||||
for line in f:
|
||||
if line.startswith('TESTSUBDIRS='):
|
||||
found_testsubdirs = True
|
||||
result.append(
|
||||
line.removeprefix('TESTSUBDIRS=').replace(
|
||||
'\\', '',
|
||||
).strip(),
|
||||
)
|
||||
continue
|
||||
if found_testsubdirs:
|
||||
if '\t' not in line:
|
||||
break
|
||||
result.append(line.replace('\\', '').strip())
|
||||
return result
|
||||
|
||||
def test_makefile_test_folders(self):
|
||||
test_dirs = self.list_test_dirs()
|
||||
idle_test = 'idlelib/idle_test'
|
||||
self.assertIn(idle_test, test_dirs)
|
||||
|
||||
used = [idle_test]
|
||||
for dirpath, _, _ in os.walk(support.TEST_HOME_DIR):
|
||||
dirname = os.path.basename(dirpath)
|
||||
if dirname == '__pycache__':
|
||||
continue
|
||||
|
||||
relpath = os.path.relpath(dirpath, support.STDLIB_DIR)
|
||||
with self.subTest(relpath=relpath):
|
||||
self.assertIn(
|
||||
relpath,
|
||||
test_dirs,
|
||||
msg=(
|
||||
f"{relpath!r} is not included in the Makefile's list "
|
||||
"of test directories to install"
|
||||
)
|
||||
)
|
||||
used.append(relpath)
|
||||
|
||||
# Check that there are no extra entries:
|
||||
unique_test_dirs = set(test_dirs)
|
||||
self.assertSetEqual(unique_test_dirs, set(used))
|
||||
self.assertEqual(len(test_dirs), len(unique_test_dirs))
|
|
@ -2245,7 +2245,11 @@ TESTSUBDIRS= idlelib/idle_test \
|
|||
test/wheeldata \
|
||||
test/xmltestdata \
|
||||
test/xmltestdata/c14n-20 \
|
||||
test/ziptestdata
|
||||
test/ziptestdata \
|
||||
test/test_concurrent_futures \
|
||||
test/test_multiprocessing_fork \
|
||||
test/test_multiprocessing_forkserver \
|
||||
test/test_multiprocessing_spawn
|
||||
|
||||
COMPILEALL_OPTS=-j0
|
||||
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue