From 1b984c19d57099752f6249ac430a980de21d1dad Mon Sep 17 00:00:00 2001 From: Soren Rasmussen Date: Fri, 26 Jul 2024 15:36:44 -0600 Subject: [PATCH] Printing formatted string for each experiment to making searching CI output easy --- scm/src/run_scm.py | 53 ++++++++++++++++++++++++++++++++++++++++------ 1 file changed, 46 insertions(+), 7 deletions(-) diff --git a/scm/src/run_scm.py b/scm/src/run_scm.py index c0febaa48..f58e2a059 100755 --- a/scm/src/run_scm.py +++ b/scm/src/run_scm.py @@ -767,11 +767,19 @@ def copy_outdir(exp_dir): shutil.rmtree(home_output_dir) shutil.copytree(exp_dir, home_output_dir) -def print_error_report(error_logs, total_count): - case_l = len(max(error_logs[:,0], key=len)) - suite_l = len(max(error_logs[:,1], key=len)) - namelist_l = len(max(error_logs[:,2], key=len)) - status_l = len(max(error_logs[:,3], key=len)) + +def print_report_line(case_s, suite, namelist, max_str_lens): + case_l = max_str_lens.case + suite_l = max_str_lens.suite + namelist_l = max_str_lens.namelist + print(f"| {case_s:<{case_l}} | {suite:<{suite_l}} | {namelist:<{namelist_l}} |") + + +def print_error_report(error_logs, total_count, max_str_lens): + case_l = max_str_lens.case + suite_l = max_str_lens.suite + namelist_l = max_str_lens.namelist + status_l = max_str_lens.status # error_log contains header, subtracting 1 from error error_count = error_logs.shape[0] - 1 passing_count = total_count - error_count @@ -791,6 +799,32 @@ def print_error_report(error_logs, total_count): print(f"[{error_count}/{total_count}] failed cases, [{passing_count}/{total_count}] passing cases") +class MaxStrLengths: + def __init__(self, max_case_len, max_suite_len, + max_namelist_len, max_status_len): + self.case = max_case_len + self.suite = max_suite_len + self.namelist = max_namelist_len + self.status = max_status_len + + +def find_max_str_lengths(run_list): + max_case_len = 0 + max_suite_len = 0 + max_status_len = len('status') + + # Loop through the list of dictionaries to find the longest lengths + for item in run_list: + max_case_len = max(max_case_len, len(item['case'])) + max_suite_len = max(max_suite_len, len(item['suite'])) + + # add 6, e.g. diff between len('SCM_HRRR_gf') and len('input_HRRR_gf.nml') + max_namelist_len = max_suite_len + 6 + max_str_lens = MaxStrLengths(max_case_len, max_suite_len, + max_namelist_len, max_status_len) + return max_str_lens + + def main(): (file, case, sdf, namelist, tracers, use_gdb, runtime, runtime_mult, docker, \ verbose, levels, npz_type, vert_coord_file, case_data_dir, n_itt_out, \ @@ -847,15 +881,19 @@ def main(): if (namelist != None): run_list[0]["namelist"] = namelist if (tracers != None): run_list[0]["tracers"] = tracers - # Loop through all input "run dictionaires" + + # setup variables error_logs = [["Failed Case", "Suite", "Namelist", "Status"]] + max_str_lens = find_max_str_lengths(run_list) failed_case = False irun = 0 + + # Loop through all input "run dictionaires" for run in run_list: # # Is this a "supported" SCM configuration? - # (e.g Do we have defualt namelist and tracer files for this suite?) + # (e.g Do we have default namelist and tracer files for this suite?) # If supported, copy default configuration, modify below if necessary. # active_suite = None @@ -902,6 +940,7 @@ def main(): # # Run the SCM case # + print_report_line(run["case"], run["suite"], active_suite.namelist, max_str_lens) logging.info('Executing process {0} of {1}: case={2}, suite={3}, namelist={4}'.format( irun, len(run_list), run["case"], run["suite"], active_suite.namelist)) #