-
Notifications
You must be signed in to change notification settings - Fork 94
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Co-authored-by: Oliver Sanders <[email protected]>
- Loading branch information
1 parent
ea7fd7e
commit 42898a5
Showing
35 changed files
with
440 additions
and
345 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,141 @@ | ||
# THIS FILE IS PART OF THE CYLC WORKFLOW ENGINE. | ||
# Copyright (C) NIWA & British Crown (Met Office) & Contributors. | ||
|
||
# This program is free software: you can redistribute it and/or modify | ||
# it under the terms of the GNU General Public License as published by | ||
# the Free Software Foundation, either version 3 of the License, or | ||
# (at your option) any later version. | ||
# | ||
# This program is distributed in the hope that it will be useful, | ||
# but WITHOUT ANY WARRANTY; without even the implied warranty of | ||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | ||
# GNU General Public License for more details. | ||
# | ||
# You should have received a copy of the GNU General Public License | ||
# along with this program. If not, see <http://www.gnu.org/licenses/>. | ||
|
||
from enum import Enum | ||
from typing import TYPE_CHECKING, Callable, Optional, Tuple | ||
|
||
if TYPE_CHECKING: | ||
from optparse import Values | ||
from cylc.flow.task_job_mgr import TaskJobManager | ||
from cylc.flow.task_proxy import TaskProxy | ||
|
||
# The interface for submitting jobs | ||
SubmissionInterface = Callable[ | ||
[ # Args: | ||
# the task job manager instance | ||
'TaskJobManager', | ||
# the task to submit | ||
'TaskProxy', | ||
# the task's runtime config (with broadcasts applied) | ||
dict, | ||
# the workflow ID | ||
str, | ||
# the current time as (float_unix_time, str_ISO8601) | ||
Tuple[float, str] | ||
], | ||
# Return False if the job requires live-mode submission | ||
# (dummy mode does this), else return True. | ||
bool | ||
] | ||
|
||
|
||
class RunMode(Enum): | ||
"""The possible run modes of a task/workflow.""" | ||
|
||
LIVE = 'live' | ||
"""Task will run normally.""" | ||
|
||
SIMULATION = 'simulation' | ||
"""Simulates job submission with configurable exection time | ||
and succeeded/failed outcomes(but does not submit real jobs).""" | ||
|
||
DUMMY = 'dummy' | ||
"""Submits real jobs with empty scripts.""" | ||
|
||
SKIP = 'skip' | ||
"""Skips job submission; sets required outputs (by default) or | ||
configured outputs.""" | ||
|
||
def describe(self): | ||
"""Return user friendly description of run mode. | ||
For use by configuration spec documenter. | ||
""" | ||
if self == self.LIVE: | ||
return "Task will run normally." | ||
if self == self.SKIP: | ||
return ( | ||
"Skips job submission; sets required outputs" | ||
" (by default) or configured outputs.") | ||
if self == self.DUMMY: | ||
return "Submits real jobs with empty scripts." | ||
if self == self.SIMULATION: | ||
return ( | ||
"Simulates job submission with configurable" | ||
" exection time and succeeded/failed outcomes" | ||
"(but does not submit real jobs).") | ||
raise KeyError(f'No description for {self}.') | ||
|
||
@staticmethod | ||
def get(options: 'Values') -> str: | ||
"""Return the workflow run mode from the options.""" | ||
if hasattr(options, 'run_mode') and options.run_mode: | ||
return options.run_mode | ||
else: | ||
return RunMode.LIVE.value | ||
|
||
def get_submit_method(self) -> 'Optional[SubmissionInterface]': | ||
"""Return the job submission method for this run mode. | ||
This returns None for live-mode jobs as these use a | ||
different code pathway for job submission. | ||
""" | ||
if self == RunMode.DUMMY: | ||
from cylc.flow.run_modes.dummy import ( | ||
submit_task_job as dummy_submit_task_job) | ||
return dummy_submit_task_job | ||
elif self == RunMode.SIMULATION: | ||
from cylc.flow.run_modes.simulation import ( | ||
submit_task_job as simulation_submit_task_job) | ||
return simulation_submit_task_job | ||
elif self == RunMode.SKIP: | ||
from cylc.flow.run_modes.skip import ( | ||
submit_task_job as skip_submit_task_job) | ||
return skip_submit_task_job | ||
return None | ||
|
||
|
||
def disable_task_event_handlers(itask: 'TaskProxy'): | ||
"""Should we disable event handlers for this task? | ||
No event handlers in simulation mode, or in skip mode | ||
if we don't deliberately enable them: | ||
""" | ||
mode = itask.run_mode | ||
return ( | ||
mode == RunMode.SIMULATION.value | ||
or ( | ||
mode == RunMode.SKIP.value | ||
and itask.platform.get( | ||
'disable task event handlers', False) | ||
) | ||
) | ||
|
||
|
||
# Modes available for running a whole workflow: | ||
WORKFLOW_RUN_MODES = frozenset(i.value for i in { | ||
RunMode.LIVE, RunMode.DUMMY, RunMode.SIMULATION}) | ||
|
||
# Modes which can be set in task config: | ||
TASK_CONFIG_RUN_MODES = frozenset( | ||
i.value for i in (RunMode.LIVE, RunMode.SKIP)) | ||
# And those only available to the workflow: | ||
WORKFLOW_ONLY_MODES = frozenset( | ||
i.value for i in RunMode) - TASK_CONFIG_RUN_MODES | ||
|
||
# Modes which completely ignore the standard submission path: | ||
JOBLESS_MODES = frozenset(i.value for i in { | ||
RunMode.SKIP, RunMode.SIMULATION}) |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.