summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorAlex Waygood <Alex.Waygood@Gmail.com>2023-12-01 18:54:38 (GMT)
committerGitHub <noreply@github.com>2023-12-01 18:54:38 (GMT)
commitacc62db8af4e472a4922c10b91c60c36c49a5f79 (patch)
treee19d65baad90503005070a9d4d1d53ebbc09dad2
parent36dbebed44785579034ffb1a59f0a1a5b987c9bf (diff)
downloadcpython-acc62db8af4e472a4922c10b91c60c36c49a5f79.zip
cpython-acc62db8af4e472a4922c10b91c60c36c49a5f79.tar.gz
cpython-acc62db8af4e472a4922c10b91c60c36c49a5f79.tar.bz2
[3.12] gh-109413: libregrtest: Backport `.py`-file changes from #112558 (#112605)
-rw-r--r--Lib/test/libregrtest/cmdline.py4
-rw-r--r--Lib/test/libregrtest/refleak.py3
-rw-r--r--Lib/test/libregrtest/results.py2
-rw-r--r--Lib/test/libregrtest/run_workers.py9
-rw-r--r--Lib/test/libregrtest/runtests.py3
-rw-r--r--Lib/test/libregrtest/setup.py3
-rw-r--r--Lib/test/libregrtest/utils.py6
7 files changed, 18 insertions, 12 deletions
diff --git a/Lib/test/libregrtest/cmdline.py b/Lib/test/libregrtest/cmdline.py
index 9ba6ec6..23ca356 100644
--- a/Lib/test/libregrtest/cmdline.py
+++ b/Lib/test/libregrtest/cmdline.py
@@ -3,7 +3,7 @@ import os.path
import shlex
import sys
from test.support import os_helper
-from .utils import ALL_RESOURCES, RESOURCE_NAMES
+from .utils import ALL_RESOURCES, RESOURCE_NAMES, TestFilter
USAGE = """\
@@ -161,7 +161,7 @@ class Namespace(argparse.Namespace):
self.forever = False
self.header = False
self.failfast = False
- self.match_tests = []
+ self.match_tests: TestFilter = []
self.pgo = False
self.pgo_extended = False
self.worker_json = None
diff --git a/Lib/test/libregrtest/refleak.py b/Lib/test/libregrtest/refleak.py
index ada1a65..5836a84 100644
--- a/Lib/test/libregrtest/refleak.py
+++ b/Lib/test/libregrtest/refleak.py
@@ -52,7 +52,8 @@ def runtest_refleak(test_name, test_func,
except ImportError:
zdc = None # Run unmodified on platforms without zipimport support
else:
- zdc = zipimport._zip_directory_cache.copy()
+ # private attribute that mypy doesn't know about:
+ zdc = zipimport._zip_directory_cache.copy() # type: ignore[attr-defined]
abcs = {}
for abc in [getattr(collections.abc, a) for a in collections.abc.__all__]:
if not isabstract(abc):
diff --git a/Lib/test/libregrtest/results.py b/Lib/test/libregrtest/results.py
index ad17448..477de77 100644
--- a/Lib/test/libregrtest/results.py
+++ b/Lib/test/libregrtest/results.py
@@ -33,7 +33,7 @@ class TestResults:
self.test_times: list[tuple[float, TestName]] = []
self.stats = TestStats()
# used by --junit-xml
- self.testsuite_xml: list[str] = []
+ self.testsuite_xml: list = []
def is_all_good(self):
return (not self.bad
diff --git a/Lib/test/libregrtest/run_workers.py b/Lib/test/libregrtest/run_workers.py
index 25ca862..7d2c1cd 100644
--- a/Lib/test/libregrtest/run_workers.py
+++ b/Lib/test/libregrtest/run_workers.py
@@ -10,7 +10,7 @@ import tempfile
import threading
import time
import traceback
-from typing import Literal, TextIO
+from typing import Any, Literal, TextIO
from test import support
from test.support import os_helper, MS_WINDOWS
@@ -243,7 +243,9 @@ class WorkerThread(threading.Thread):
json_fd = json_tmpfile.fileno()
if MS_WINDOWS:
- json_handle = msvcrt.get_osfhandle(json_fd)
+ # The msvcrt module is only available on Windows;
+ # we run mypy with `--platform=linux` in CI
+ json_handle: int = msvcrt.get_osfhandle(json_fd) # type: ignore[attr-defined]
json_file = JsonFile(json_handle,
JsonFileType.WINDOWS_HANDLE)
else:
@@ -257,7 +259,7 @@ class WorkerThread(threading.Thread):
else:
match_tests = None
- kwargs = {}
+ kwargs: dict[str, Any] = {}
if match_tests:
kwargs['match_tests'] = [(test, True) for test in match_tests]
if self.runtests.output_on_failure:
@@ -343,6 +345,7 @@ class WorkerThread(threading.Thread):
json_file, json_tmpfile = self.create_json_file(stack)
worker_runtests = self.create_worker_runtests(test_name, json_file)
+ retcode: str | int | None
retcode, tmp_files = self.run_tmp_files(worker_runtests,
stdout_file.fileno())
diff --git a/Lib/test/libregrtest/runtests.py b/Lib/test/libregrtest/runtests.py
index 283c104..4bf2b1f 100644
--- a/Lib/test/libregrtest/runtests.py
+++ b/Lib/test/libregrtest/runtests.py
@@ -33,7 +33,8 @@ class JsonFile:
popen_kwargs['pass_fds'] = [self.file]
case JsonFileType.WINDOWS_HANDLE:
# Windows handle
- startupinfo = subprocess.STARTUPINFO()
+ # We run mypy with `--platform=linux` so it complains about this:
+ startupinfo = subprocess.STARTUPINFO() # type: ignore[attr-defined]
startupinfo.lpAttributeList = {"handle_list": [self.file]}
popen_kwargs['startupinfo'] = startupinfo
diff --git a/Lib/test/libregrtest/setup.py b/Lib/test/libregrtest/setup.py
index 97edba9..9e97414 100644
--- a/Lib/test/libregrtest/setup.py
+++ b/Lib/test/libregrtest/setup.py
@@ -124,7 +124,8 @@ def setup_tests(runtests: RunTests):
support.LONG_TIMEOUT = min(support.LONG_TIMEOUT, timeout)
if runtests.hunt_refleak:
- unittest.BaseTestSuite._cleanup = False
+ # private attribute that mypy doesn't know about:
+ unittest.BaseTestSuite._cleanup = False # type: ignore[attr-defined]
if runtests.gc_threshold is not None:
gc.set_threshold(runtests.gc_threshold)
diff --git a/Lib/test/libregrtest/utils.py b/Lib/test/libregrtest/utils.py
index 2dd057d..af61e42 100644
--- a/Lib/test/libregrtest/utils.py
+++ b/Lib/test/libregrtest/utils.py
@@ -12,7 +12,7 @@ import sys
import sysconfig
import tempfile
import textwrap
-from collections.abc import Callable
+from collections.abc import Callable, Iterable
from test import support
from test.support import os_helper
@@ -556,7 +556,7 @@ def is_cross_compiled():
return ('_PYTHON_HOST_PLATFORM' in os.environ)
-def format_resources(use_resources: tuple[str, ...]):
+def format_resources(use_resources: Iterable[str]):
use_resources = set(use_resources)
all_resources = set(ALL_RESOURCES)
@@ -596,7 +596,7 @@ def display_header(use_resources: tuple[str, ...],
print("== Python build:", ' '.join(get_build_info()))
print("== cwd:", os.getcwd())
- cpu_count = os.cpu_count()
+ cpu_count: object = os.cpu_count()
if cpu_count:
affinity = process_cpu_count()
if affinity and affinity != cpu_count: