From 36a78104b27e1a41a4b9db476a2e5580f83ed5c3 Mon Sep 17 00:00:00 2001 From: Dmitry Vodoypanov Date: Thu, 25 Jul 2024 06:42:37 -0700 Subject: [PATCH 1/3] Add option to execute tests on already built binaries This patch adds new option `--run-only` to `run_conformance_tests.py` to be able to execute tests on already built binaries. --- run_conformance_tests.py | 29 ++++++++++++++++++++++------- 1 file changed, 22 insertions(+), 7 deletions(-) diff --git a/run_conformance_tests.py b/run_conformance_tests.py index 880e543e0..481190bcb 100755 --- a/run_conformance_tests.py +++ b/run_conformance_tests.py @@ -83,16 +83,26 @@ def handle_args(argv): help='Test the reduced feature set instead of the full feature set.', required=False, action='store_true') + parser.add_argument( + '--run-only', + help='Whether to perform only testing for already compiled tests.', + required=False, + action='store_true') args = parser.parse_args(argv) full_conformance = 'OFF' if args.fast else 'ON' test_deprecated_features = 'OFF' if args.disable_deprecated_features else 'ON' full_feature_set = 'OFF' if args.reduced_feature_set else 'ON' + if (args.build_only and args.run_only): + print('Fatal error: --build-only and --run-only can not be enabled ' + 'together in the single script run.') + exit(-1) + return (args.cmake_exe, args.build_system_name, args.build_system_call, full_conformance, test_deprecated_features, args.exclude_categories, args.implementation_name, args.additional_cmake_args, args.device, - args.additional_ctest_args, args.build_only, + args.additional_ctest_args, args.build_only, args.run_only, full_feature_set) @@ -160,19 +170,24 @@ def subprocess_call(parameter_list): def configure_and_run_tests(cmake_call, build_system_call, build_only, - ctest_call): + run_only, ctest_call): """ Configures the tests with cmake to produce a ninja.build file. Runs the generated ninja file. Runs ctest, overwriting any cached results. """ - build_system_call = build_system_call.split() + error_code = 0 + + if (not run_only): + build_system_call = build_system_call.split() + + subprocess_call(cmake_call) + error_code = subprocess_call(build_system_call) - subprocess_call(cmake_call) - error_code = subprocess_call(build_system_call) if (not build_only): error_code = subprocess_call(ctest_call) + return error_code @@ -276,7 +291,7 @@ def main(argv=sys.argv[1:]): (cmake_exe, build_system_name, build_system_call, full_conformance, test_deprecated_features, exclude_categories, implementation_name, additional_cmake_args, device, additional_ctest_args, - build_only, full_feature_set) = handle_args(argv) + build_only, run_only, full_feature_set) = handle_args(argv) # Generate a cmake call in a form accepted by subprocess.call() cmake_call = generate_cmake_call(cmake_exe, build_system_name, @@ -295,7 +310,7 @@ def main(argv=sys.argv[1:]): # Configure the build system with cmake, run the build, and run the tests. error_code = configure_and_run_tests(cmake_call, build_system_call, - build_only, ctest_call) + build_only, run_only, ctest_call) if build_only: return error_code From ead430a11c26b1bf6e6cefc313c7357d21f7dbe4 Mon Sep 17 00:00:00 2001 From: Dmitry Vodopyanov Date: Fri, 2 Aug 2024 21:41:05 +0200 Subject: [PATCH 2/3] Update run_conformance_tests.py Co-authored-by: Alexey Bader --- run_conformance_tests.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/run_conformance_tests.py b/run_conformance_tests.py index 481190bcb..d314c1666 100755 --- a/run_conformance_tests.py +++ b/run_conformance_tests.py @@ -85,7 +85,7 @@ def handle_args(argv): action='store_true') parser.add_argument( '--run-only', - help='Whether to perform only testing for already compiled tests.', + help='Skip build step and perform only testing for already compiled tests.', required=False, action='store_true') args = parser.parse_args(argv) From 110601e0dfed7d1e7c2aa799335a585f7050d8ce Mon Sep 17 00:00:00 2001 From: Dmitry Vodopyanov Date: Wed, 7 Aug 2024 12:20:47 +0200 Subject: [PATCH 3/3] Update run_conformance_tests.py Co-authored-by: Ronan Keryell --- run_conformance_tests.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/run_conformance_tests.py b/run_conformance_tests.py index d314c1666..c694d4ac3 100755 --- a/run_conformance_tests.py +++ b/run_conformance_tests.py @@ -96,7 +96,7 @@ def handle_args(argv): if (args.build_only and args.run_only): print('Fatal error: --build-only and --run-only can not be enabled ' - 'together in the single script run.') + 'together in a single script run.') exit(-1) return (args.cmake_exe, args.build_system_name, args.build_system_call,