From daef0cb7f43a2a77cbd3479ff5ee24d7e5b9cc00 Mon Sep 17 00:00:00 2001 From: Ronnie Dutta <61982285+MetRonnie@users.noreply.github.com> Date: Thu, 12 Nov 2020 20:20:10 +0000 Subject: [PATCH 1/4] globalcfg: [suite logging] -> [scheduler][logging] --- cylc/flow/cfgspec/globalcfg.py | 23 ++++++++++++----------- cylc/flow/loggingutil.py | 7 ++++--- tests/functional/logging/03-roll.t | 7 ++++--- 3 files changed, 20 insertions(+), 17 deletions(-) diff --git a/cylc/flow/cfgspec/globalcfg.py b/cylc/flow/cfgspec/globalcfg.py index db68cb496c4..9d03c220c7e 100644 --- a/cylc/flow/cfgspec/globalcfg.py +++ b/cylc/flow/cfgspec/globalcfg.py @@ -171,17 +171,18 @@ The interval with which this plugin is run. ''') - with Conf('suite logging', desc=''' - The suite event log, held under the suite run directory, is maintained - as a rolling archive. Logs are rolled over (backed up and started anew) - when they reach a configurable limit size. - '''): - Conf('rolling archive length', VDR.V_INTEGER, 5, desc=''' - How many rolled logs to retain in the archive. - ''') - Conf('maximum size in bytes', VDR.V_INTEGER, 1000000, desc=''' - Suite event logs are rolled over when they reach this file size. - ''') + with Conf('logging', desc=''' + The workflow event log, held under the suite run directory, is + maintained as a rolling archive. Logs are rolled over (backed up + and started anew) when they reach a configurable limit size. + '''): + Conf('rolling archive length', VDR.V_INTEGER, 5, desc=''' + How many rolled logs to retain in the archive. + ''') + Conf('maximum size in bytes', VDR.V_INTEGER, 1000000, desc=''' + Suite event logs are rolled over when they reach this + file size. + ''') with Conf('editors', desc=''' Choose your favourite text editor for editing suite configurations. diff --git a/cylc/flow/loggingutil.py b/cylc/flow/loggingutil.py index def108a912e..8a3a0794cbf 100644 --- a/cylc/flow/loggingutil.py +++ b/cylc/flow/loggingutil.py @@ -114,7 +114,6 @@ class TimestampRotatingFileHandler(logging.FileHandler): FILE_HEADER_FLAG = 'cylc_log_file_header' FILE_NUM = 'cylc_log_num' - GLBL_KEY = 'suite logging' MIN_BYTES = 1024 def __init__(self, log_file_path, no_detach=False, timestamp=True): @@ -141,7 +140,8 @@ def should_rollover(self, record): """Should rollover?""" if self.stamp is None or self.stream is None: return True - max_bytes = glbl_cfg().get([self.GLBL_KEY, 'maximum size in bytes']) + max_bytes = glbl_cfg().get( + ['scheduler', 'logging', 'maximum size in bytes']) if max_bytes < self.MIN_BYTES: # No silly value max_bytes = self.MIN_BYTES msg = "%s\n" % self.format(record) @@ -168,7 +168,8 @@ def do_rollover(self): os.unlink(self.baseFilename) os.symlink(os.path.basename(filename), self.baseFilename) # Housekeep log files - arch_len = glbl_cfg().get([self.GLBL_KEY, 'rolling archive length']) + arch_len = glbl_cfg().get( + ['scheduler', 'logging', 'rolling archive length']) if arch_len: log_files = glob(self.baseFilename + '.*') log_files.sort() diff --git a/tests/functional/logging/03-roll.t b/tests/functional/logging/03-roll.t index 9506cfebdef..c843371da55 100755 --- a/tests/functional/logging/03-roll.t +++ b/tests/functional/logging/03-roll.t @@ -35,9 +35,10 @@ init_suite "${TEST_NAME_BASE}" <<'__FLOW_CONFIG__' __FLOW_CONFIG__ create_test_global_config '' ' -[suite logging] - rolling archive length = 8 - maximum size in bytes = 2048' +[scheduler] + [[logging]] + rolling archive length = 8 + maximum size in bytes = 2048' run_ok "${TEST_NAME_BASE}-validate" \ cylc validate "${SUITE_NAME}" suite_run_ok "${TEST_NAME_BASE}-run" \ From 723e109c29711ac84890812459a2680fd539c090 Mon Sep 17 00:00:00 2001 From: Ronnie Dutta <61982285+MetRonnie@users.noreply.github.com> Date: Thu, 12 Nov 2020 20:25:10 +0000 Subject: [PATCH 2/4] globalcfg: "run directory rolling archive length" moved to [scheduler] --- cylc/flow/cfgspec/globalcfg.py | 9 +++++---- cylc/flow/pathutil.py | 2 +- tests/unit/test_pathutil.py | 3 ++- 3 files changed, 8 insertions(+), 6 deletions(-) diff --git a/cylc/flow/cfgspec/globalcfg.py b/cylc/flow/cfgspec/globalcfg.py index 9d03c220c7e..40c410ec276 100644 --- a/cylc/flow/cfgspec/globalcfg.py +++ b/cylc/flow/cfgspec/globalcfg.py @@ -90,9 +90,6 @@ The default is set quite high to avoid killing important processes when the system is under load. ''') - Conf('run directory rolling archive length', VDR.V_INTEGER, -1, desc=''' - The number of old run directory trees to retain at start-up. - ''') with Conf('scheduler', desc=''' Default values for entries in :cylc:conf:`flow.cylc[scheduler]` @@ -100,7 +97,11 @@ ``flow.cylc`` file. '''): Conf('UTC mode', VDR.V_BOOLEAN, False, desc=''' - Default for :cylc:conf:`flow.cylc[scheduler]UTC mode`. + Default for :cylc:conf:`flow.cylc[scheduler]UTC mode`. + ''') + Conf('run directory rolling archive length', VDR.V_INTEGER, -1, + desc=''' + The number of old run directory trees to retain at start-up. ''') with Conf('events', desc=''' diff --git a/cylc/flow/pathutil.py b/cylc/flow/pathutil.py index dc336611fdf..45f38fe994c 100644 --- a/cylc/flow/pathutil.py +++ b/cylc/flow/pathutil.py @@ -112,7 +112,7 @@ def make_suite_run_tree(suite): """Create all top-level cylc-run output dirs on the suite host.""" cfg = glbl_cfg().get() # Roll archive - archlen = cfg['run directory rolling archive length'] + archlen = cfg['scheduler']['run directory rolling archive length'] dir_ = os.path.expandvars(get_suite_run_dir(suite)) for i in range(archlen, -1, -1): # archlen...0 if i > 0: diff --git a/tests/unit/test_pathutil.py b/tests/unit/test_pathutil.py index 16c0211dcec..73c5214d007 100644 --- a/tests/unit/test_pathutil.py +++ b/tests/unit/test_pathutil.py @@ -162,7 +162,8 @@ def test_get_suite_run_names(self, mocked_platform): ) def test_make_suite_run_tree(caplog, tmpdir, mock_glbl_cfg, subdir): glbl_conf_str = f''' - run directory rolling archive length = 1 + [scheduler] + run directory rolling archive length = 1 [platforms] [[localhost]] run directory = {tmpdir} From 19d114deef112c12226e8d964baccd5b733b28b9 Mon Sep 17 00:00:00 2001 From: Ronnie Dutta <61982285+MetRonnie@users.noreply.github.com> Date: Thu, 12 Nov 2020 20:35:28 +0000 Subject: [PATCH 3/4] globalcfg: process pool * -> [scheduler]process pool --- cylc/flow/cfgspec/globalcfg.py | 30 +++++++++---------- cylc/flow/subprocpool.py | 5 ++-- etc/bin/run-functional-tests | 2 +- tests/flakyfunctional/events/44-timeout.t | 4 ++- .../job-submission/18-check-chunking.t | 3 +- .../job-submission/19-chatty.t | 3 +- tests/functional/events/47-long-output.t | 4 ++- tests/functional/job-submission/16-timeout.t | 3 +- 8 files changed, 30 insertions(+), 24 deletions(-) diff --git a/cylc/flow/cfgspec/globalcfg.py b/cylc/flow/cfgspec/globalcfg.py index 40c410ec276..6e40858b6c2 100644 --- a/cylc/flow/cfgspec/globalcfg.py +++ b/cylc/flow/cfgspec/globalcfg.py @@ -75,22 +75,6 @@ Prior to Cylc 8, ``global.cylc`` was named ``global.rc``, but that name is no longer supported. ''') as SPEC: - - # suite - Conf('process pool size', VDR.V_INTEGER, 4, desc=''' - Maximum number of concurrent processes used to execute external job - submission, event handlers, and job poll and kill commands - see - :ref:`Managing External Command Execution`. - ''') - Conf('process pool timeout', VDR.V_INTERVAL, DurationFloat(600), desc=''' - Interval after which long-running commands in the process pool will be - killed - see :ref:`Managing External Command Execution`. - - .. note:: - The default is set quite high to avoid killing important - processes when the system is under load. - ''') - with Conf('scheduler', desc=''' Default values for entries in :cylc:conf:`flow.cylc[scheduler]` section. This should not be confused with scheduling in the @@ -99,6 +83,20 @@ Conf('UTC mode', VDR.V_BOOLEAN, False, desc=''' Default for :cylc:conf:`flow.cylc[scheduler]UTC mode`. ''') + Conf('process pool size', VDR.V_INTEGER, 4, desc=''' + Maximum number of concurrent processes used to execute external job + submission, event handlers, and job poll and kill commands - see + :ref:`Managing External Command Execution`. + ''') + Conf('process pool timeout', VDR.V_INTERVAL, DurationFloat(600), + desc=''' + Interval after which long-running commands in the process pool + will be killed - see :ref:`Managing External Command Execution`. + + .. note:: + The default is set quite high to avoid killing important + processes when the system is under load. + ''') Conf('run directory rolling archive length', VDR.V_INTEGER, -1, desc=''' The number of old run directory trees to retain at start-up. diff --git a/cylc/flow/subprocpool.py b/cylc/flow/subprocpool.py index 8f987bc84da..845781cc8b8 100644 --- a/cylc/flow/subprocpool.py +++ b/cylc/flow/subprocpool.py @@ -120,8 +120,9 @@ class SubProcPool: RET_CODE_SUITE_STOPPING = 999 def __init__(self): - self.size = glbl_cfg().get(['process pool size']) - self.proc_pool_timeout = glbl_cfg().get(['process pool timeout']) + self.size = glbl_cfg().get(['scheduler', 'process pool size']) + self.proc_pool_timeout = glbl_cfg().get( + ['scheduler', 'process pool timeout']) self.closed = False # Close queue self.stopping = False # No more job submit if True # .stopping may be set by an API command in a different thread diff --git a/etc/bin/run-functional-tests b/etc/bin/run-functional-tests index 0a29db2e0e7..a66dc576b7a 100755 --- a/etc/bin/run-functional-tests +++ b/etc/bin/run-functional-tests @@ -24,7 +24,7 @@ Run the Cylc test battery, in /tests. Options and arguments are appended to "prove -j \$NPROC -s -r \${@:-tests/f}". NPROC is the number of concurrent processes to run, which defaults to the -global config "process pool size" setting. +global config "[scheduler]process pool size" setting. The tests ignore normal site/user global config and instead use: ~/.cylc/flow//global-tests.cylc diff --git a/tests/flakyfunctional/events/44-timeout.t b/tests/flakyfunctional/events/44-timeout.t index 92faf3d1115..ff2f70b570a 100755 --- a/tests/flakyfunctional/events/44-timeout.t +++ b/tests/flakyfunctional/events/44-timeout.t @@ -23,7 +23,9 @@ set_test_number 4 create_test_global_config " -process pool timeout = PT10S" "" +[scheduler] + process pool timeout = PT10S +" install_suite "${TEST_NAME_BASE}" "${TEST_NAME_BASE}" diff --git a/tests/flakyfunctional/job-submission/18-check-chunking.t b/tests/flakyfunctional/job-submission/18-check-chunking.t index 92b04a2363c..26a14e75570 100644 --- a/tests/flakyfunctional/job-submission/18-check-chunking.t +++ b/tests/flakyfunctional/job-submission/18-check-chunking.t @@ -21,7 +21,8 @@ set_test_number 3 create_test_global_config ' -process pool size = 1 +[scheduler] + process pool size = 1 ' '' init_suite "${TEST_NAME_BASE}" <<'__FLOW_CONFIG__' diff --git a/tests/flakyfunctional/job-submission/19-chatty.t b/tests/flakyfunctional/job-submission/19-chatty.t index d7d028bbd70..77876f7cdc6 100755 --- a/tests/flakyfunctional/job-submission/19-chatty.t +++ b/tests/flakyfunctional/job-submission/19-chatty.t @@ -22,7 +22,8 @@ export REQUIRE_PLATFORM='batch:at' set_test_number 15 create_test_global_config " -process pool timeout = PT10S" " +[scheduler] + process pool timeout = PT10S [platforms] [[$CYLC_TEST_PLATFORM]] batch submit command template = talkingnonsense %(job)s diff --git a/tests/functional/events/47-long-output.t b/tests/functional/events/47-long-output.t index 8a078b51839..4ea348a539f 100755 --- a/tests/functional/events/47-long-output.t +++ b/tests/functional/events/47-long-output.t @@ -25,7 +25,9 @@ fi set_test_number 10 create_test_global_config " -process pool timeout = PT10S" "" +[scheduler] + process pool timeout = PT10S +" "" # Long STDOUT output diff --git a/tests/functional/job-submission/16-timeout.t b/tests/functional/job-submission/16-timeout.t index 9776e3e55cc..c2af223fa0a 100755 --- a/tests/functional/job-submission/16-timeout.t +++ b/tests/functional/job-submission/16-timeout.t @@ -21,7 +21,8 @@ export REQUIRE_PLATFORM='batch:at comms:tcp' set_test_number 4 create_test_global_config " -process pool timeout = PT10S +[scheduler] + process pool timeout = PT10S " " [platforms] [[$CYLC_TEST_PLATFORM]] From c621e9f766ecfc52373690938cce287226b5420f Mon Sep 17 00:00:00 2001 From: Ronnie Dutta <61982285+MetRonnie@users.noreply.github.com> Date: Fri, 13 Nov 2020 10:05:18 +0000 Subject: [PATCH 4/4] Tests: Tidy create_test_global_config calls As global config no longer contains top-level settings --- tests/flakyfunctional/events/44-timeout.t | 2 +- .../job-submission/18-check-chunking.t | 14 +++++++------- tests/flakyfunctional/job-submission/19-chatty.t | 2 +- tests/functional/events/47-long-output.t | 4 ++-- tests/functional/job-submission/16-timeout.t | 3 +-- tests/functional/lib/bash/test_header | 4 ++-- tests/functional/logging/03-roll.t | 3 ++- 7 files changed, 16 insertions(+), 16 deletions(-) diff --git a/tests/flakyfunctional/events/44-timeout.t b/tests/flakyfunctional/events/44-timeout.t index ff2f70b570a..b971f1102d0 100755 --- a/tests/flakyfunctional/events/44-timeout.t +++ b/tests/flakyfunctional/events/44-timeout.t @@ -22,7 +22,7 @@ set_test_number 4 -create_test_global_config " +create_test_global_config "" " [scheduler] process pool timeout = PT10S " diff --git a/tests/flakyfunctional/job-submission/18-check-chunking.t b/tests/flakyfunctional/job-submission/18-check-chunking.t index 26a14e75570..bfe1ab89ac8 100644 --- a/tests/flakyfunctional/job-submission/18-check-chunking.t +++ b/tests/flakyfunctional/job-submission/18-check-chunking.t @@ -20,10 +20,10 @@ . "$(dirname "$0")/test_header" set_test_number 3 -create_test_global_config ' +create_test_global_config '' ' [scheduler] process pool size = 1 -' '' +' init_suite "${TEST_NAME_BASE}" <<'__FLOW_CONFIG__' [scheduler] @@ -40,12 +40,12 @@ init_suite "${TEST_NAME_BASE}" <<'__FLOW_CONFIG__' [[t1

]] # Reduce the load on many jobs sending the "started" message init-script = """ -sleep $((RANDOM % 10)) -""" + sleep $((RANDOM % 10)) + """ script = """ -wait -sleep $((RANDOM % 5)) -""" + wait + sleep $((RANDOM % 5)) + """ __FLOW_CONFIG__ diff --git a/tests/flakyfunctional/job-submission/19-chatty.t b/tests/flakyfunctional/job-submission/19-chatty.t index 77876f7cdc6..948113b8346 100755 --- a/tests/flakyfunctional/job-submission/19-chatty.t +++ b/tests/flakyfunctional/job-submission/19-chatty.t @@ -21,7 +21,7 @@ export REQUIRE_PLATFORM='batch:at' . "$(dirname "$0")/test_header" set_test_number 15 -create_test_global_config " +create_test_global_config "" " [scheduler] process pool timeout = PT10S [platforms] diff --git a/tests/functional/events/47-long-output.t b/tests/functional/events/47-long-output.t index 4ea348a539f..5d499005565 100755 --- a/tests/functional/events/47-long-output.t +++ b/tests/functional/events/47-long-output.t @@ -24,10 +24,10 @@ fi set_test_number 10 -create_test_global_config " +create_test_global_config "" " [scheduler] process pool timeout = PT10S -" "" +" # Long STDOUT output diff --git a/tests/functional/job-submission/16-timeout.t b/tests/functional/job-submission/16-timeout.t index c2af223fa0a..73e9c2743a8 100755 --- a/tests/functional/job-submission/16-timeout.t +++ b/tests/functional/job-submission/16-timeout.t @@ -20,10 +20,9 @@ export REQUIRE_PLATFORM='batch:at comms:tcp' . "$(dirname "$0")/test_header" set_test_number 4 -create_test_global_config " +create_test_global_config "" " [scheduler] process pool timeout = PT10S -" " [platforms] [[$CYLC_TEST_PLATFORM]] batch submit command template = sleep 30 diff --git a/tests/functional/lib/bash/test_header b/tests/functional/lib/bash/test_header index 527ad835cce..ebb4c606d1b 100644 --- a/tests/functional/lib/bash/test_header +++ b/tests/functional/lib/bash/test_header @@ -121,8 +121,8 @@ # Expect 2 OK tests. # create_test_global_config [PRE [POST]] # Create a new global config file $PWD/etc from global-tests.cylc -# with PRE and POST pre- and ap-pended (PRE for top level items with no -# section heading). PRE and POST are strings. +# with PRE and POST pre- and ap-pended (PRE for e.g. jinja2 shebang). +# PRE and POST are strings. # localhost_fqdn # Get the FQDN of the current host using the same mechanism Cylc uses. # get_fqdn [TARGET] diff --git a/tests/functional/logging/03-roll.t b/tests/functional/logging/03-roll.t index c843371da55..f67eeb31504 100755 --- a/tests/functional/logging/03-roll.t +++ b/tests/functional/logging/03-roll.t @@ -38,7 +38,8 @@ create_test_global_config '' ' [scheduler] [[logging]] rolling archive length = 8 - maximum size in bytes = 2048' + maximum size in bytes = 2048 +' run_ok "${TEST_NAME_BASE}-validate" \ cylc validate "${SUITE_NAME}" suite_run_ok "${TEST_NAME_BASE}-run" \