matflow.Submission#
- class matflow.Submission(index, jobscripts, workflow=None, at_submit_metadata=None, JS_parallelism=None, environments=None)#
Bases:
Submission
A collection of jobscripts to be submitted to a scheduler.
- Parameters:
index (int) – The index of this submission.
jobscripts (list[Jobscript]) – The jobscripts in the submission.
workflow (Workflow) – The workflow this is part of.
submission_parts (dict) – Description of submission parts.
JS_parallelism (bool) – Whether to exploit jobscript parallelism.
environments (EnvironmentsList) – The execution environments to use.
Methods
Cancel the active jobs for this submission's jobscripts.
Make an instance of this class from JSON (or YAML) data.
Get jobscripts that are active on this machine, and their active states.
The app log file name.
The file path to the app log, for the specified submission.
The path to the app log directory for this submission, for the specified submission.
The path to the app standard output and error stream files directory, for the specified submission.
The path to the directory containing command files, for the specified submission.
Get the end time of a given submission part.
Get the name of the jobscript functions file for the specified shell.
Get the path of the jobscript functions file for the specified shell.
The path to the directory containing the shell functions that are invoked within jobscripts and commmand files, for the specified submission.
The path to the jobscript files directory, for the specified submission.
The path to the directory containing jobscript run IDs, for the specified submission.
The path to the directory containing script indices for combined-script jobscripts only, for the specified submission.
The path to the jobscript standard output and error files directory, for the specified submission.
The path to the directory containing process ID files (Windows only), for the specified submission.
The directory path to files associated with the specified submission.
Return jobscript process IDs.
Return jobscript scheduler job IDs.
The path to the directory containing action scripts, for the specified submission.
Get the start time of a given submission part.
The path to the temporary files directory, for the specified submission.
Get unique schedulers and which of this submission's jobscripts they correspond to.
Get unique schedulers and which of the passed jobscripts they correspond to.
Get unique shells and which jobscripts they correspond to.
Print a table listing jobscripts and associated information.
Print a table listing the jobscripts associated with the specified (or all) tasks for the specified submission.
Generate and submit the jobscripts of this submission.
Serialize this object as a dictionary.
Serialize this object as an object structure that can be trivially converted to JSON.
Attributes
All EARs in this submission, grouped by element.
Whether to exploit jobscript parallelism.
The IDs of all EARs in this submission.
All EARs in this submission.
The path to the app log directory for this submission for this submission.
The path to the app standard output and error stream files directory, for the this submission.
The path to the directory containing command files, for this submission.
Get the final non-None end time over all submission parts.
The execution environments to use.
The index of this submission.
Return whether each jobscript of this submission uses a scheduler or not.
All associated jobscript indices.
The jobscripts in this submission.
The path to the directory containing the shell functions that are invoked within jobscripts and commmand files, for this submission.
The path to the jobscript files directory, for this submission.
The path to the directory containing jobscript run IDs, for this submission.
The path to the directory containing script indices for combined-script jobscripts only, for this submission.
The path to the jobscript standard output and error files directory, for this submission.
The path to the directory containing process ID files (Windows only), for this submission.
Whether this submision requires an app log directory.
Whether this submision requires a directory for combined-script script ID files.
Whether this submission needs a submit to be done.
Whether this submision requires a directory for process ID files (Windows only).
Jobscript indices that have not yet been successfully submitted.
The path to the directory containing action scripts.
The path to the directory containing action scripts, for this submission.
Get the first non-None start time over all submission parts.
The status of this submission.
Jobscript indices that have been successfully submitted.
The path to the temporary files directory for this submission.
The workflow this is part of.
- APP_STD_DIR_NAME = 'app_std'#
- COMMANDS_DIR_NAME = 'commands'#
- property EARs_by_elements: Mapping[int, Mapping[int, Sequence[ElementActionRun]]]#
All EARs in this submission, grouped by element.
- JS_DIR_NAME = 'jobscripts'#
- JS_FUNCS_DIR_NAME = 'js_funcs'#
- JS_RUN_IDS_DIR_NAME = 'js_run_ids'#
- JS_SCRIPT_INDICES_DIR_NAME = 'js_script_indices'#
- JS_STD_DIR_NAME = 'js_std'#
- JS_WIN_PIDS_DIR_NAME = 'js_pids'#
- property JS_parallelism: bool | Literal['direct', 'scheduled'] | None#
Whether to exploit jobscript parallelism.
- LOG_DIR_NAME = 'app_logs'#
- SCRIPTS_DIR_NAME = 'scripts'#
- TMP_DIR_NAME = 'tmp'#
- WORKFLOW_APP_ALIAS = 'wkflow_app'#
- property all_EARs: Iterable[ElementActionRun]#
All EARs in this submission.
- property all_EARs_IDs_by_jobscript: list[numpy.ndarray]#
- property all_EARs_by_jobscript: list[list[ElementActionRun]]#
- property app_log_path: Path#
The path to the app log directory for this submission for this submission.
- property app_std_path: Path#
The path to the app standard output and error stream files directory, for the this submission.
- cancel()#
Cancel the active jobs for this submission’s jobscripts.
- Return type:
None
- property commands_path: Path#
The path to the directory containing command files, for this submission.
- property environments: EnvironmentsList#
The execution environments to use.
- classmethod from_json_like(json_like, shared_data=None)#
Make an instance of this class from JSON (or YAML) data.
- get_active_jobscripts(as_json=False)#
Get jobscripts that are active on this machine, and their active states.
- static get_app_log_file_name(run_ID)#
The app log file name.
- classmethod get_app_log_file_path(submissions_path, sub_idx, run_ID)#
The file path to the app log, for the specified submission.
- classmethod get_app_log_path(submissions_path, sub_idx)#
The path to the app log directory for this submission, for the specified submission.
- classmethod get_app_std_path(submissions_path, sub_idx)#
The path to the app standard output and error stream files directory, for the specified submission.
- classmethod get_commands_path(submissions_path, sub_idx)#
The path to the directory containing command files, for the specified submission.
- get_end_time(submit_time)#
Get the end time of a given submission part.
- Parameters:
submit_time (str) –
- Return type:
datetime | None
- get_jobscript_functions_name(shell, shell_idx)#
Get the name of the jobscript functions file for the specified shell.
- get_jobscript_functions_path(shell, shell_idx)#
Get the path of the jobscript functions file for the specified shell.
- Parameters:
shell (Shell) –
shell_idx (int) –
- Return type:
Path
- classmethod get_js_funcs_path(submissions_path, sub_idx)#
The path to the directory containing the shell functions that are invoked within jobscripts and commmand files, for the specified submission.
- classmethod get_js_path(submissions_path, sub_idx)#
The path to the jobscript files directory, for the specified submission.
- classmethod get_js_run_ids_path(submissions_path, sub_idx)#
The path to the directory containing jobscript run IDs, for the specified submission.
- classmethod get_js_script_indices_path(submissions_path, sub_idx)#
The path to the directory containing script indices for combined-script jobscripts only, for the specified submission.
- classmethod get_js_std_path(submissions_path, sub_idx)#
The path to the jobscript standard output and error files directory, for the specified submission.
- classmethod get_js_win_pids_path(submissions_path, sub_idx)#
The path to the directory containing process ID files (Windows only), for the specified submission.
- classmethod get_path(submissions_path, sub_idx)#
The directory path to files associated with the specified submission.
- classmethod get_scripts_path(submissions_path, sub_idx)#
The path to the directory containing action scripts, for the specified submission.
- get_start_time(submit_time)#
Get the start time of a given submission part.
- Parameters:
submit_time (str) –
- Return type:
datetime | None
- classmethod get_tmp_path(submissions_path, sub_idx)#
The path to the temporary files directory, for the specified submission.
- get_unique_schedulers()#
Get unique schedulers and which of this submission’s jobscripts they correspond to.
- Returns:
Mapping where keys are a sequence of jobscript index descriptors and the values are the scheduler to use for that jobscript. A jobscript index descriptor is a pair of the submission index and the main jobscript index.
- Return type:
scheduler_mapping
- static get_unique_schedulers_of_jobscripts(jobscripts)#
Get unique schedulers and which of the passed jobscripts they correspond to.
Uniqueness is determined only by the QueuedScheduler.unique_properties tuple.
- Parameters:
- Returns:
Mapping where keys are a sequence of jobscript index descriptors and the values are the scheduler to use for that jobscript. A jobscript index descriptor is a pair of the submission index and the main jobscript index.
- Return type:
scheduler_mapping
- get_unique_shells()#
Get unique shells and which jobscripts they correspond to.
- property is_scheduled: tuple[bool, ...]#
Return whether each jobscript of this submission uses a scheduler or not.
- property js_funcs_path: Path#
The path to the directory containing the shell functions that are invoked within jobscripts and commmand files, for this submission.
- property js_run_ids_path: Path#
The path to the directory containing jobscript run IDs, for this submission.
- property js_script_indices_path: Path#
The path to the directory containing script indices for combined-script jobscripts only, for this submission.
- property js_std_path: Path#
The path to the jobscript standard output and error files directory, for this submission.
- property js_win_pids_path: Path#
The path to the directory containing process ID files (Windows only), for this submission.
- list_jobscripts(max_js=None, jobscripts=None, width=None)#
Print a table listing jobscripts and associated information.
- list_task_jobscripts(task_names=None, max_js=None, width=None)#
Print a table listing the jobscripts associated with the specified (or all) tasks for the specified submission.
- property needs_script_indices_dir: bool#
Whether this submision requires a directory for combined-script script ID files.
- property needs_win_pids_dir: bool#
Whether this submision requires a directory for process ID files (Windows only).
- property outstanding_jobscripts: tuple[int, ...]#
Jobscript indices that have not yet been successfully submitted.
- property scripts_path: Path#
The path to the directory containing action scripts, for this submission.
- property status: SubmissionStatus#
The status of this submission.
- submit(status, ignore_errors=False, print_stdout=False, add_to_known=True)#
Generate and submit the jobscripts of this submission.
- property submitted_jobscripts: tuple[int, ...]#
Jobscript indices that have been successfully submitted.
- to_json_like(dct=None, shared_data=None, exclude=(), path=None)#
Serialize this object as an object structure that can be trivially converted to JSON. Note that YAML can also be produced from the result of this method; it just requires a different final serialization step.