From 46f0aedb32b25b99c52d6046c30b8f85f1424514 Mon Sep 17 00:00:00 2001 From: Bruce Forstall Date: Thu, 18 Nov 2021 15:25:12 -0800 Subject: [PATCH 1/2] Improve superpmi-asmdiffs AzDO pipeline robustness 1. When git fetching origin/main, use `--depth=500` to try to ensure there is enough context to allow finding a JIT change in the history. 2. Add some error checking in pipeline setup so failures in setting up the pipeline should fail the jobs early. --- .../scripts/superpmi_asmdiffs_setup.py | 21 ++++++++++++++++--- 1 file changed, 18 insertions(+), 3 deletions(-) diff --git a/src/coreclr/scripts/superpmi_asmdiffs_setup.py b/src/coreclr/scripts/superpmi_asmdiffs_setup.py index 6602708e67335..0342db7b56a0d 100644 --- a/src/coreclr/scripts/superpmi_asmdiffs_setup.py +++ b/src/coreclr/scripts/superpmi_asmdiffs_setup.py @@ -115,6 +115,9 @@ def main(main_args): Args: main_args ([type]): Arguments to the script + + Returns: + 0 on success, otherwise a failure code """ # Set up logging. @@ -152,6 +155,7 @@ def main(main_args): git_exe_tool = os.path.join(git_directory, "cmd", "git.exe") if not os.path.isfile(git_exe_tool): print('Error: `git` not found at {}'.format(git_exe_tool)) + return 1 ######## Get SuperPMI python scripts @@ -167,18 +171,22 @@ def main(main_args): os.makedirs(base_jit_directory) print("Fetching history of `main` branch so we can find the baseline JIT") - run_command(["git", "fetch", "origin", "main"], source_directory, _exit_on_fail=True) + run_command(["git", "fetch", "--depth=500", "origin", "main"], source_directory, _exit_on_fail=True) # Note: we only support downloading Windows versions of the JIT currently. To support downloading # non-Windows JITs on a Windows machine, pass `-host_os ` to jitrollingbuild.py. - print("Running jitrollingbuild.py download to get baseline") + print("Running jitrollingbuild.py download to get baseline JIT") + jit_rolling_build_script = os.path.join(superpmi_scripts_directory, "jitrollingbuild.py") _, _, return_code = run_command([ python_path, - os.path.join(superpmi_scripts_directory, "jitrollingbuild.py"), + jit_rolling_build_script, "download", "-arch", arch, "-target_dir", base_jit_directory], source_directory) + if return_code != 0: + print('{} failed with {}'.format(jit_rolling_build_script, return_code)) + return return_code ######## Get diff JIT @@ -238,6 +246,11 @@ def main(main_args): # Details: https://bugs.python.org/issue26660 print('Ignoring PermissionError: {0}'.format(pe_error)) + jit_analyze_tool = os.path.join(jit_analyze_build_directory, "jit-analyze.exe") + if not os.path.isfile(jit_analyze_tool): + print('Error: {} not found'.format(jit_analyze_tool)) + return 1 + ######## Set pipeline variables helix_source_prefix = "official" @@ -249,6 +262,8 @@ def main(main_args): set_pipeline_variable("Creator", creator) set_pipeline_variable("HelixSourcePrefix", helix_source_prefix) + return 0 + if __name__ == "__main__": args = parser.parse_args() From 8b6cba38a39745378b6ab9f703ad223db78c3eae Mon Sep 17 00:00:00 2001 From: Bruce Forstall Date: Thu, 18 Nov 2021 17:39:35 -0800 Subject: [PATCH 2/2] Remove unneeded `success` variable from jitrollingbuild.py --- src/coreclr/scripts/jitrollingbuild.py | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/src/coreclr/scripts/jitrollingbuild.py b/src/coreclr/scripts/jitrollingbuild.py index d120fa49d27ca..100aff85c3522 100644 --- a/src/coreclr/scripts/jitrollingbuild.py +++ b/src/coreclr/scripts/jitrollingbuild.py @@ -750,7 +750,6 @@ def main(args): return 1 coreclr_args = setup_args(args) - success = True if coreclr_args.mode == "upload": upload_command(coreclr_args) @@ -764,7 +763,8 @@ def main(args): else: raise NotImplementedError(coreclr_args.mode) - return 0 if success else 1 + # Note that if there is any failure, an exception is raised and the process exit code is then `1` + return 0 ################################################################################ # __main__