summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorVictor Stinner <vstinner@python.org>2023-09-27 11:00:22 (GMT)
committerGitHub <noreply@github.com>2023-09-27 11:00:22 (GMT)
commit8ac20e5404127d68624339c0b318abe2d14fe514 (patch)
tree4839d2475e8f6ec08eaaa7aadb94102af6e9bfaa
parent242316860480fd33eb2a0afeb1154b64c46aa155 (diff)
downloadcpython-8ac20e5404127d68624339c0b318abe2d14fe514.zip
cpython-8ac20e5404127d68624339c0b318abe2d14fe514.tar.gz
cpython-8ac20e5404127d68624339c0b318abe2d14fe514.tar.bz2
[3.11] gh-109615: Fix support test_copy_python_src_ignore() (#109958) (#109962)
gh-109615: Fix support test_copy_python_src_ignore() (#109958) Fix the test when run on an installed Python: use "abs_srcdir" of sysconfig, and skip the test if the Python source code cannot be found. * Tools/patchcheck/patchcheck.py, Tools/freeze/test/freeze.py and Lib/test/libregrtest/utils.py now first try to get "abs_srcdir" from sysconfig, before getting "srcdir" from sysconfig. * test.pythoninfo logs sysconfig "abs_srcdir". (cherry picked from commit b89ed9df39851348fbb1552294644f99f6b17d2c)
-rw-r--r--Lib/test/libregrtest/main.py12
-rw-r--r--Lib/test/pythoninfo.py3
-rw-r--r--Lib/test/test_support.py7
-rw-r--r--Tools/freeze/test/freeze.py9
-rwxr-xr-xTools/scripts/patchcheck.py9
5 files changed, 32 insertions, 8 deletions
diff --git a/Lib/test/libregrtest/main.py b/Lib/test/libregrtest/main.py
index e4e65e9..7192244 100644
--- a/Lib/test/libregrtest/main.py
+++ b/Lib/test/libregrtest/main.py
@@ -731,11 +731,13 @@ class Regrtest:
if sysconfig.is_python_build():
self.tmp_dir = sysconfig.get_config_var('abs_builddir')
if self.tmp_dir is None:
- # gh-74470: On Windows, only srcdir is available. Using
- # abs_builddir mostly matters on UNIX when building Python
- # out of the source tree, especially when the source tree
- # is read only.
- self.tmp_dir = sysconfig.get_config_var('srcdir')
+ self.tmp_dir = sysconfig.get_config_var('abs_srcdir')
+ if not self.tmp_dir:
+ # gh-74470: On Windows, only srcdir is available. Using
+ # abs_builddir mostly matters on UNIX when building
+ # Python out of the source tree, especially when the
+ # source tree is read only.
+ self.tmp_dir = sysconfig.get_config_var('srcdir')
self.tmp_dir = os.path.join(self.tmp_dir, 'build')
else:
self.tmp_dir = tempfile.gettempdir()
diff --git a/Lib/test/pythoninfo.py b/Lib/test/pythoninfo.py
index 69d2fc0..db8dfe2 100644
--- a/Lib/test/pythoninfo.py
+++ b/Lib/test/pythoninfo.py
@@ -524,7 +524,10 @@ def collect_sysconfig(info_add):
'Py_NOGIL',
'SHELL',
'SOABI',
+ 'abs_builddir',
+ 'abs_srcdir',
'prefix',
+ 'srcdir',
):
value = sysconfig.get_config_var(name)
if name == 'ANDROID_API_LEVEL' and not value:
diff --git a/Lib/test/test_support.py b/Lib/test/test_support.py
index a6b241e..53220ec 100644
--- a/Lib/test/test_support.py
+++ b/Lib/test/test_support.py
@@ -779,8 +779,13 @@ class TestSupport(unittest.TestCase):
#self.assertEqual(available, 2)
def test_copy_python_src_ignore(self):
- src_dir = sysconfig.get_config_var('srcdir')
+ src_dir = sysconfig.get_config_var('abs_srcdir')
+ if not src_dir:
+ src_dir = sysconfig.get_config_var('srcdir')
src_dir = os.path.abspath(src_dir)
+ if not os.path.exists(src_dir):
+ self.skipTest(f"cannot access Python source code directory:"
+ f" {src_dir!r}")
ignored = {'.git', '__pycache__'}
diff --git a/Tools/freeze/test/freeze.py b/Tools/freeze/test/freeze.py
index bb15941..cdf77c5 100644
--- a/Tools/freeze/test/freeze.py
+++ b/Tools/freeze/test/freeze.py
@@ -7,9 +7,16 @@ import sysconfig
from test import support
+def get_python_source_dir():
+ src_dir = sysconfig.get_config_var('abs_srcdir')
+ if not src_dir:
+ src_dir = sysconfig.get_config_var('srcdir')
+ return os.path.abspath(src_dir)
+
+
TESTS_DIR = os.path.dirname(__file__)
TOOL_ROOT = os.path.dirname(TESTS_DIR)
-SRCDIR = os.path.abspath(sysconfig.get_config_var('srcdir'))
+SRCDIR = get_python_source_dir()
MAKE = shutil.which('make')
FREEZE = os.path.join(TOOL_ROOT, 'freeze.py')
diff --git a/Tools/scripts/patchcheck.py b/Tools/scripts/patchcheck.py
index a324eaf..c2dceea 100755
--- a/Tools/scripts/patchcheck.py
+++ b/Tools/scripts/patchcheck.py
@@ -11,6 +11,13 @@ import reindent
import untabify
+def get_python_source_dir():
+ src_dir = sysconfig.get_config_var('abs_srcdir')
+ if not src_dir:
+ src_dir = sysconfig.get_config_var('srcdir')
+ return os.path.abspath(src_dir)
+
+
# Excluded directories which are copies of external libraries:
# don't check their coding style
EXCLUDE_DIRS = [os.path.join('Modules', '_ctypes', 'libffi_osx'),
@@ -18,7 +25,7 @@ EXCLUDE_DIRS = [os.path.join('Modules', '_ctypes', 'libffi_osx'),
os.path.join('Modules', '_decimal', 'libmpdec'),
os.path.join('Modules', 'expat'),
os.path.join('Modules', 'zlib')]
-SRCDIR = sysconfig.get_config_var('srcdir')
+SRCDIR = get_python_source_dir()
def n_files_str(count):