gh-84461: Use HOSTRUNNER to run regression tests (GH-93694)

Co-authored-by: Brett Cannon <brett@python.org>
This commit is contained in:
Christian Heimes 2022-06-11 08:42:23 +02:00 committed by GitHub
parent 4c496f1f11
commit dc5e02b2f4
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
4 changed files with 55 additions and 6 deletions

View file

@ -0,0 +1,2 @@
``run_tests.py`` now handles cross compiling env vars correctly and pass
``HOSTRUNNER`` to regression tests.

View file

@ -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
View file

@ -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; }

View file

@ -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