From d334f399a68240f10a583cd9d393d7bd703fb447 Mon Sep 17 00:00:00 2001 From: Jim Edwards Date: Tue, 16 Aug 2016 12:27:33 -0600 Subject: [PATCH 1/6] moved config_tests.xml to cime_config directory, reorder tests in scripts_regression tests --- {scripts/Testing/Testcases => cime_config}/config_tests.xml | 0 1 file changed, 0 insertions(+), 0 deletions(-) rename {scripts/Testing/Testcases => cime_config}/config_tests.xml (100%) diff --git a/scripts/Testing/Testcases/config_tests.xml b/cime_config/config_tests.xml similarity index 100% rename from scripts/Testing/Testcases/config_tests.xml rename to cime_config/config_tests.xml From 1ff6c2bdaba68c58b3a0d6f4ef6e7e335689be00 Mon Sep 17 00:00:00 2001 From: Jim Edwards Date: Tue, 16 Aug 2016 12:27:46 -0600 Subject: [PATCH 2/6] moved config_tests.xml to cime_config directory, reorder tests in scripts_regression tests --- cime_config/cesm/config_files.xml | 2 +- .../python/tests/scripts_regression_tests.py | 30 +++++++++---------- 2 files changed, 16 insertions(+), 16 deletions(-) diff --git a/cime_config/cesm/config_files.xml b/cime_config/cesm/config_files.xml index bcbb55130d0..1e9c4afb1b6 100644 --- a/cime_config/cesm/config_files.xml +++ b/cime_config/cesm/config_files.xml @@ -66,7 +66,7 @@ char - $CIMEROOT/scripts/Testing/Testcases/config_tests.xml + $CIMEROOT/cime_config/config_tests.xml test env_test.xml file containing system test descriptions diff --git a/utils/python/tests/scripts_regression_tests.py b/utils/python/tests/scripts_regression_tests.py index 606d7be63a4..7a332986cbf 100755 --- a/utils/python/tests/scripts_regression_tests.py +++ b/utils/python/tests/scripts_regression_tests.py @@ -113,7 +113,7 @@ def setup_proxy(): return False ############################################################################### -class B_TestCreateNewcase(unittest.TestCase): +class J_TestCreateNewcase(unittest.TestCase): ############################################################################### def setUp(self): self._testroot = MACHINE.get_value("CESMSCRATCHROOT") @@ -162,7 +162,7 @@ def tearDown(self): elif do_teardown: shutil.rmtree(tfile) ############################################################################### -class D_TestWaitForTests(unittest.TestCase): +class M_TestWaitForTests(unittest.TestCase): ############################################################################### ########################################################################### @@ -417,7 +417,7 @@ def tearDown(self): os.remove(file_to_clean) ############################################################################### -class C_TestCreateTest(TestCreateTestCommon): +class N_TestCreateTest(TestCreateTestCommon): ############################################################################### ########################################################################### @@ -472,7 +472,7 @@ def test_create_test_rebless_namelist(self): self.simple_test(True, "-c -n -b %s -t %s-%s" % (self._baseline_name, self._baseline_name, CIME.utils.get_utc_timestamp())) ############################################################################### -class E_TestTestScheduler(TestCreateTestCommon): +class O_TestTestScheduler(TestCreateTestCommon): ############################################################################### ########################################################################### @@ -609,7 +609,7 @@ def test_b_full(self): self.assertEqual(ts.get_status(MEMLEAK_PHASE), TEST_PASS_STATUS) ############################################################################### -class TestJenkinsGenericJob(TestCreateTestCommon): +class P_TestJenkinsGenericJob(TestCreateTestCommon): ############################################################################### ########################################################################### @@ -705,7 +705,7 @@ def test_jenkins_generic_job_kill(self): assert_dashboard_has_build(self, build_name) ############################################################################### -class TestBlessTestResults(TestCreateTestCommon): +class Q_TestBlessTestResults(TestCreateTestCommon): ############################################################################### _test_name = "TESTRUNDIFF_Mmpi-serial.f19_g16_rx1.A" @@ -761,7 +761,7 @@ def test_bless_test_results(self): ############################################################################### @unittest.skip("Disabling this test until we figure out how to integrate ACME tests and CIME xml files.") -class TestUpdateACMETests(unittest.TestCase): +class R_TestUpdateACMETests(unittest.TestCase): ############################################################################### ########################################################################### @@ -868,7 +868,7 @@ def test_full_system(self): self.assertTrue(test_time > 0, msg="test time was zero for %s" % test_status) ############################################################################### -class TestCimeCase(TestCreateTestCommon): +class K_TestCimeCase(TestCreateTestCommon): ############################################################################### ########################################################################### @@ -910,7 +910,7 @@ def test_cime_case(self): self.assertEqual(case.get_value("PIO_TYPENAME"), "netcdf") ############################################################################### -class TestSingleSubmit(TestCreateTestCommon): +class X_TestSingleSubmit(TestCreateTestCommon): ############################################################################### ########################################################################### @@ -933,7 +933,7 @@ def test_single_submit(self): msg="COMMAND SHOULD HAVE WORKED\nwait_for_tests output:\n%s\n\nerrput:\n%s\n\ncode: %d" % (output, errput, stat)) ############################################################################### -class TestSaveTimings(TestCreateTestCommon): +class L_TestSaveTimings(TestCreateTestCommon): ############################################################################### ########################################################################### @@ -954,7 +954,7 @@ def test_save_timings(self): msg="COMMAND SHOULD HAVE WORKED\nwait_for_tests output:\n%s\n\nerrput:\n%s\n\ncode: %d" % (output, errput, stat)) ############################################################################### -class TestXMLQuery(unittest.TestCase): +class C_TestXMLQuery(unittest.TestCase): # Testing command line scripts ############################################################################### @@ -1037,7 +1037,7 @@ def test_subgroup(self): self.assertEqual(searchObj.group() , group_out) ############################################################################### -class CheckCode(unittest.TestCase): +class B_CheckCode(unittest.TestCase): ############################################################################### ########################################################################### @@ -1283,7 +1283,7 @@ def assert_variable_matches(self, var_name, regex, env=None, var=None): ############################################################################### -class TestMacrosBasic(unittest.TestCase): +class G_TestMacrosBasic(unittest.TestCase): ############################################################################### """Basic infrastructure tests. @@ -1317,7 +1317,7 @@ def test_script_rejects_bad_build_system(self): ############################################################################### -class TestMakeMacros(unittest.TestCase): +class H_TestMakeMacros(unittest.TestCase): ############################################################################### """Makefile macros tests. @@ -1592,7 +1592,7 @@ def test_variable_insertion_with_machine_specific_setting(self): ############################################################################### @unittest.skipIf(FAST_ONLY, "Skipping slow CMake tests.") -class TestCMakeMacros(TestMakeMacros): +class I_TestCMakeMacros(H_TestMakeMacros): ############################################################################### """CMake macros tests. From 518552b363a3cf3661e34a6508365878333ff433 Mon Sep 17 00:00:00 2001 From: Jim Edwards Date: Tue, 16 Aug 2016 12:51:27 -0600 Subject: [PATCH 3/6] add support for special queue on yellowstone --- cime_config/cesm/machines/config_batch.xml | 3 ++- utils/python/CIME/XML/env_batch.py | 12 ++++++++---- 2 files changed, 10 insertions(+), 5 deletions(-) diff --git a/cime_config/cesm/machines/config_batch.xml b/cime_config/cesm/machines/config_batch.xml index 12c31b06e3b..0d2fe946825 100644 --- a/cime_config/cesm/machines/config_batch.xml +++ b/cime_config/cesm/machines/config_batch.xml @@ -424,7 +424,8 @@ - caldera + hpss + caldera regular capability diff --git a/utils/python/CIME/XML/env_batch.py b/utils/python/CIME/XML/env_batch.py index 846bec7c1ca..477c1ad3509 100644 --- a/utils/python/CIME/XML/env_batch.py +++ b/utils/python/CIME/XML/env_batch.py @@ -276,7 +276,7 @@ def set_job_defaults(self, bjobs, pesize=None, walltime=None, force_queue=None): else: task_count = int(task_count) - queue = force_queue if force_queue is not None else self.select_best_queue(task_count) + queue = force_queue if force_queue is not None else self.select_best_queue(task_count, job) self.set_value("JOB_QUEUE", queue, subgroup=job) walltime = self.get_max_walltime(queue) if walltime is None else walltime @@ -464,7 +464,7 @@ def get_job_id(self, output): jobid = re.search(jobid_pattern, output).group(1) return jobid - def select_best_queue(self, num_pes): + def select_best_queue(self, num_pes, job=None): # Make sure to check default queue first. all_queues = [] all_queues.append( self.get_default_queue()) @@ -473,9 +473,13 @@ def select_best_queue(self, num_pes): if queue is not None: jobmin = queue.get("jobmin") jobmax = queue.get("jobmax") + jobname = queue.get("jobname") + if jobname is not None: + if job == jobname: + return queue.text # if the fullsum is between the min and max # jobs, then use this queue. - if jobmin is not None and jobmax is not None and num_pes >= int(jobmin) and num_pes <= int(jobmax): - return queue.text + elif jobmin is not None and jobmax is not None and num_pes >= int(jobmin) and num_pes <= int(jobmax): + return queue.text return None def get_max_walltime(self, queue): From b78608a4caebe2ceb6f65bd661500125079cfd78 Mon Sep 17 00:00:00 2001 From: Jim Edwards Date: Tue, 16 Aug 2016 13:03:41 -0600 Subject: [PATCH 4/6] fix indent --- utils/python/CIME/XML/env_batch.py | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/utils/python/CIME/XML/env_batch.py b/utils/python/CIME/XML/env_batch.py index 477c1ad3509..581610d0184 100644 --- a/utils/python/CIME/XML/env_batch.py +++ b/utils/python/CIME/XML/env_batch.py @@ -330,6 +330,8 @@ def get_submit_args(self, case, job): if name is None: submitargs+=" %s"%flag else: + if name.startswith("$"): + name = name[:1] val = case.get_value(name,subgroup=job) if val is None: val = case.get_resolved_value(name) @@ -479,7 +481,7 @@ def select_best_queue(self, num_pes, job=None): return queue.text # if the fullsum is between the min and max # jobs, then use this queue. elif jobmin is not None and jobmax is not None and num_pes >= int(jobmin) and num_pes <= int(jobmax): - return queue.text + return queue.text return None def get_max_walltime(self, queue): From 23ebbfda859e8348bb8af82da3a6767aeab84b1f Mon Sep 17 00:00:00 2001 From: Jim Edwards Date: Tue, 16 Aug 2016 13:27:31 -0600 Subject: [PATCH 5/6] add timestamp to testcase names --- utils/python/CIME/XML/env_batch.py | 2 +- utils/python/tests/scripts_regression_tests.py | 14 +++++++------- 2 files changed, 8 insertions(+), 8 deletions(-) diff --git a/utils/python/CIME/XML/env_batch.py b/utils/python/CIME/XML/env_batch.py index 581610d0184..be78beadba4 100644 --- a/utils/python/CIME/XML/env_batch.py +++ b/utils/python/CIME/XML/env_batch.py @@ -331,7 +331,7 @@ def get_submit_args(self, case, job): submitargs+=" %s"%flag else: if name.startswith("$"): - name = name[:1] + name = name[1:] val = case.get_value(name,subgroup=job) if val is None: val = case.get_resolved_value(name) diff --git a/utils/python/tests/scripts_regression_tests.py b/utils/python/tests/scripts_regression_tests.py index 7a332986cbf..62c516494e9 100755 --- a/utils/python/tests/scripts_regression_tests.py +++ b/utils/python/tests/scripts_regression_tests.py @@ -121,7 +121,7 @@ def setUp(self): self._do_teardown = [] def test_createnewcase(self): - testdir = os.path.join(self._testroot, 'scripts_regression_tests.testcreatenewcase') + testdir = os.path.join(self._testroot, 'scripts_regression_tests.testcreatenewcase.%s'% CIME.utils.get_utc_timestamp()) if os.path.exists(testdir): shutil.rmtree(testdir) self._testdirs.append(testdir) @@ -137,7 +137,7 @@ def test_createnewcase(self): self._do_teardown.append(testdir) def test_user_mods(self): - testdir = os.path.join(self._testroot, 'scripts_regression_tests.testusermods') + testdir = os.path.join(self._testroot, 'scripts_regression_tests.testusermods.%s'% CIME.utils.get_utc_timestamp()) if os.path.exists(testdir): shutil.rmtree(testdir) self._testdirs.append(testdir) @@ -169,10 +169,10 @@ class M_TestWaitForTests(unittest.TestCase): def setUp(self): ########################################################################### self._testroot = MACHINE.get_value("CESMSCRATCHROOT") - self._testdir_all_pass = os.path.join(self._testroot, 'scripts_regression_tests.testdir_all_pass') - self._testdir_with_fail = os.path.join(self._testroot, 'scripts_regression_tests.testdir_with_fail') - self._testdir_unfinished = os.path.join(self._testroot, 'scripts_regression_tests.testdir_unfinished') - self._testdir_unfinished2 = os.path.join(self._testroot, 'scripts_regression_tests.testdir_unfinished2') + self._testdir_all_pass = os.path.join(self._testroot, 'scripts_regression_tests.testdir_all_pass.%s'% CIME.utils.get_utc_timestamp()) + self._testdir_with_fail = os.path.join(self._testroot, 'scripts_regression_tests.testdir_with_fail.%s'% CIME.utils.get_utc_timestamp()) + self._testdir_unfinished = os.path.join(self._testroot, 'scripts_regression_tests.testdir_unfinished.%s'% CIME.utils.get_utc_timestamp()) + self._testdir_unfinished2 = os.path.join(self._testroot, 'scripts_regression_tests.testdir_unfinished2.%s'% CIME.utils.get_utc_timestamp()) testdirs = [self._testdir_all_pass, self._testdir_with_fail, self._testdir_unfinished, self._testdir_unfinished2] for testdir in testdirs: if os.path.exists(testdir): @@ -964,7 +964,7 @@ def setUp(self): self._testdirs = [] self._do_teardown = [] - testdir = os.path.join(self._testroot, 'scripts_regression_tests.testscripts') + testdir = os.path.join(self._testroot, 'scripts_regression_tests.testscripts.%s'% CIME.utils.get_utc_timestamp()) machine = 'melvin' if os.path.exists(testdir): shutil.rmtree(testdir) From b4bf40a49e695b6981b2962d9daada160c9c7194 Mon Sep 17 00:00:00 2001 From: Jim Edwards Date: Tue, 16 Aug 2016 14:17:20 -0600 Subject: [PATCH 6/6] location of config_tests.xml --- cime_config/acme/config_files.xml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/cime_config/acme/config_files.xml b/cime_config/acme/config_files.xml index 81746dac89a..747f0c8a03e 100644 --- a/cime_config/acme/config_files.xml +++ b/cime_config/acme/config_files.xml @@ -66,7 +66,7 @@ char - $CIMEROOT/scripts/Testing/Testcases/config_tests.xml + $CIMEROOT/cime_config/config_tests.xml test env_test.xml file containing system test descriptions