mirror of
https://github.com/python/cpython.git
synced 2025-09-26 18:29:57 +00:00
gh-84461: Use HOSTRUNNER to run regression tests (GH-93694)
Co-authored-by: Brett Cannon <brett@python.org>
This commit is contained in:
parent
4c496f1f11
commit
dc5e02b2f4
4 changed files with 55 additions and 6 deletions
|
@ -0,0 +1,2 @@
|
||||||
|
``run_tests.py`` now handles cross compiling env vars correctly and pass
|
||||||
|
``HOSTRUNNER`` to regression tests.
|
|
@ -8,7 +8,9 @@ simply passing a -u option to this script.
|
||||||
"""
|
"""
|
||||||
|
|
||||||
import os
|
import os
|
||||||
|
import shlex
|
||||||
import sys
|
import sys
|
||||||
|
import sysconfig
|
||||||
import test.support
|
import test.support
|
||||||
|
|
||||||
|
|
||||||
|
@ -19,15 +21,37 @@ def is_multiprocess_flag(arg):
|
||||||
def is_resource_use_flag(arg):
|
def is_resource_use_flag(arg):
|
||||||
return arg.startswith('-u') or arg.startswith('--use')
|
return arg.startswith('-u') or arg.startswith('--use')
|
||||||
|
|
||||||
|
def is_python_flag(arg):
|
||||||
|
return arg.startswith('-p') or arg.startswith('--python')
|
||||||
|
|
||||||
|
|
||||||
def main(regrtest_args):
|
def main(regrtest_args):
|
||||||
args = [sys.executable,
|
args = [sys.executable,
|
||||||
'-u', # Unbuffered stdout and stderr
|
'-u', # Unbuffered stdout and stderr
|
||||||
'-W', 'default', # Warnings set to 'default'
|
'-W', 'default', # Warnings set to 'default'
|
||||||
'-bb', # Warnings about bytes/bytearray
|
'-bb', # Warnings about bytes/bytearray
|
||||||
'-E', # Ignore environment variables
|
|
||||||
]
|
]
|
||||||
|
|
||||||
|
cross_compile = '_PYTHON_HOST_PLATFORM' in os.environ
|
||||||
|
if (hostrunner := os.environ.get("_PYTHON_HOSTRUNNER")) is None:
|
||||||
|
hostrunner = sysconfig.get_config_var("HOSTRUNNER")
|
||||||
|
if cross_compile:
|
||||||
|
# emulate -E, but keep PYTHONPATH + cross compile env vars, so
|
||||||
|
# test executable can load correct sysconfigdata file.
|
||||||
|
keep = {
|
||||||
|
'_PYTHON_PROJECT_BASE',
|
||||||
|
'_PYTHON_HOST_PLATFORM',
|
||||||
|
'_PYTHON_SYSCONFIGDATA_NAME',
|
||||||
|
'PYTHONPATH'
|
||||||
|
}
|
||||||
|
environ = {
|
||||||
|
name: value for name, value in os.environ.items()
|
||||||
|
if not name.startswith(('PYTHON', '_PYTHON')) or name in keep
|
||||||
|
}
|
||||||
|
else:
|
||||||
|
environ = os.environ.copy()
|
||||||
|
args.append("-E")
|
||||||
|
|
||||||
# Allow user-specified interpreter options to override our defaults.
|
# Allow user-specified interpreter options to override our defaults.
|
||||||
args.extend(test.support.args_from_interpreter_flags())
|
args.extend(test.support.args_from_interpreter_flags())
|
||||||
|
|
||||||
|
@ -38,16 +62,30 @@ def main(regrtest_args):
|
||||||
if sys.platform == 'win32':
|
if sys.platform == 'win32':
|
||||||
args.append('-n') # Silence alerts under Windows
|
args.append('-n') # Silence alerts under Windows
|
||||||
if not any(is_multiprocess_flag(arg) for arg in regrtest_args):
|
if not any(is_multiprocess_flag(arg) for arg in regrtest_args):
|
||||||
args.extend(['-j', '0']) # Use all CPU cores
|
if cross_compile and hostrunner:
|
||||||
|
# For now use only one core for cross-compiled builds;
|
||||||
|
# hostrunner can be expensive.
|
||||||
|
args.extend(['-j', '1'])
|
||||||
|
else:
|
||||||
|
args.extend(['-j', '0']) # Use all CPU cores
|
||||||
if not any(is_resource_use_flag(arg) for arg in regrtest_args):
|
if not any(is_resource_use_flag(arg) for arg in regrtest_args):
|
||||||
args.extend(['-u', 'all,-largefile,-audio,-gui'])
|
args.extend(['-u', 'all,-largefile,-audio,-gui'])
|
||||||
|
|
||||||
|
if cross_compile and hostrunner:
|
||||||
|
# If HOSTRUNNER is set and -p/--python option is not given, then
|
||||||
|
# use hostrunner to execute python binary for tests.
|
||||||
|
if not any(is_python_flag(arg) for arg in regrtest_args):
|
||||||
|
buildpython = sysconfig.get_config_var("BUILDPYTHON")
|
||||||
|
args.extend(["--python", f"{hostrunner} {buildpython}"])
|
||||||
|
|
||||||
args.extend(regrtest_args)
|
args.extend(regrtest_args)
|
||||||
print(' '.join(args))
|
|
||||||
|
print(shlex.join(args))
|
||||||
if sys.platform == 'win32':
|
if sys.platform == 'win32':
|
||||||
from subprocess import call
|
from subprocess import call
|
||||||
sys.exit(call(args))
|
sys.exit(call(args))
|
||||||
else:
|
else:
|
||||||
os.execv(sys.executable, args)
|
os.execve(sys.executable, args, environ)
|
||||||
|
|
||||||
|
|
||||||
if __name__ == '__main__':
|
if __name__ == '__main__':
|
||||||
|
|
6
configure
generated
vendored
6
configure
generated
vendored
|
@ -6782,7 +6782,7 @@ else
|
||||||
fi
|
fi
|
||||||
;; #(
|
;; #(
|
||||||
WASI/*) :
|
WASI/*) :
|
||||||
HOSTRUNNER='wasmtime run --env PYTHONPATH=$$(realpath --relative-to $(abs_srcdir) $(abs_builddir))/$$(cat pybuilddir.txt) --mapdir /::$(srcdir) --' ;; #(
|
HOSTRUNNER='wasmtime run --env PYTHONPATH=/$(shell realpath --relative-to $(abs_srcdir) $(abs_builddir))/$(shell cat pybuilddir.txt) --mapdir /::$(srcdir) --' ;; #(
|
||||||
*) :
|
*) :
|
||||||
HOSTRUNNER=''
|
HOSTRUNNER=''
|
||||||
;;
|
;;
|
||||||
|
@ -6792,6 +6792,10 @@ fi
|
||||||
{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $HOSTRUNNER" >&5
|
{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $HOSTRUNNER" >&5
|
||||||
$as_echo "$HOSTRUNNER" >&6; }
|
$as_echo "$HOSTRUNNER" >&6; }
|
||||||
|
|
||||||
|
if test -n "$HOSTRUNNER"; then
|
||||||
|
PYTHON_FOR_BUILD="_PYTHON_HOSTRUNNER='$HOSTRUNNER' $PYTHON_FOR_BUILD"
|
||||||
|
fi
|
||||||
|
|
||||||
{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $LDLIBRARY" >&5
|
{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $LDLIBRARY" >&5
|
||||||
$as_echo "$LDLIBRARY" >&6; }
|
$as_echo "$LDLIBRARY" >&6; }
|
||||||
|
|
||||||
|
|
|
@ -1492,13 +1492,18 @@ then
|
||||||
dnl TODO: support other WASI runtimes
|
dnl TODO: support other WASI runtimes
|
||||||
dnl wasmtime starts the proces with "/" as CWD. For OOT builds add the
|
dnl wasmtime starts the proces with "/" as CWD. For OOT builds add the
|
||||||
dnl directory containing _sysconfigdata to PYTHONPATH.
|
dnl directory containing _sysconfigdata to PYTHONPATH.
|
||||||
[WASI/*], [HOSTRUNNER='wasmtime run --env PYTHONPATH=$$(realpath --relative-to $(abs_srcdir) $(abs_builddir))/$$(cat pybuilddir.txt) --mapdir /::$(srcdir) --'],
|
[WASI/*], [HOSTRUNNER='wasmtime run --env PYTHONPATH=/$(shell realpath --relative-to $(abs_srcdir) $(abs_builddir))/$(shell cat pybuilddir.txt) --mapdir /::$(srcdir) --'],
|
||||||
[HOSTRUNNER='']
|
[HOSTRUNNER='']
|
||||||
)
|
)
|
||||||
fi
|
fi
|
||||||
AC_SUBST([HOSTRUNNER])
|
AC_SUBST([HOSTRUNNER])
|
||||||
AC_MSG_RESULT([$HOSTRUNNER])
|
AC_MSG_RESULT([$HOSTRUNNER])
|
||||||
|
|
||||||
|
if test -n "$HOSTRUNNER"; then
|
||||||
|
dnl Pass hostrunner variable as env var in order to expand shell expressions.
|
||||||
|
PYTHON_FOR_BUILD="_PYTHON_HOSTRUNNER='$HOSTRUNNER' $PYTHON_FOR_BUILD"
|
||||||
|
fi
|
||||||
|
|
||||||
AC_MSG_RESULT($LDLIBRARY)
|
AC_MSG_RESULT($LDLIBRARY)
|
||||||
|
|
||||||
# LIBRARY_DEPS, LINK_PYTHON_OBJS and LINK_PYTHON_DEPS variable
|
# LIBRARY_DEPS, LINK_PYTHON_OBJS and LINK_PYTHON_DEPS variable
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue