hpcflow.sdk.app.App#
- class hpcflow.sdk.app.App(*args, **kwargs)#
Bases:
BaseApp
Class from which to instantiate downstream app objects (e.g. MatFlow).
Methods
Clear the known-submissions file of all submissions.
Delete the contents of the user runtime directory.
Copy a builtin demo workflow to the specified location.
Retrieve a list of schedulers that are supported in principle by this operating system.
Return the full path to the config file, without loading the config.
Context manager to get a (temporary) file path to an included demo workflow template.
Get a dict mapping parameter types to task schemas that input/output each parameter.
Get an arbitrary scheduler object.
Return a list of demo workflow templates included in the app.
Load a WorkflowTemplate object from a builtin demo template file.
Load all template component data, warning by default if already loaded.
Return a decorator for retrying functions on permission and OS errors that might be associated with cloud-storage desktop sync.
Retrieve existing workflows that might be running.
Reload all template component data, warning by default if not already loaded.
Reset the config file to defaults, and reload the config.
Set workflows in the known-submissions file to the non-running state.
Print the contents of a builtin demo workflow template file.
Attributes
Return True if any template component (e.g.
We segregate by hostname to account for the case where multiple machines might use the same shared file system
Retrieve a temporary directory.
- clear_known_submissions_file()#
Clear the known-submissions file of all submissions. This shouldn’t be needed normally.
- clear_user_runtime_dir()#
Delete the contents of the user runtime directory.
- property command_files: CommandFilesList#
- configure_env(name, setup=None, executables=None, use_current_env=False, env_source_file=None)#
- copy_demo_workflow(name, dst=None, doc=True)#
Copy a builtin demo workflow to the specified location.
- Parameters:
name (str) – The name of the demo workflow to copy
dst (PathLike | None) – Directory or full file path to copy the demo workflow to. If not specified, the current working directory will be used.
doc (bool) – If False, the copied workflow template file will not include the doc attribute (if originally present).
- Return type:
- property envs: EnvironmentsList#
- get_OS_supported_schedulers()#
Retrieve a list of schedulers that are supported in principle by this operating system.
This does not necessarily mean all the returned schedulers are available on this system.
- get_config_path(config_dir=None)#
Return the full path to the config file, without loading the config.
- get_demo_workflow_template_file(name, doc=True, delete=True)#
Context manager to get a (temporary) file path to an included demo workflow template.
- get_parameter_task_schema_map()#
Get a dict mapping parameter types to task schemas that input/output each parameter.
- get_scheduler(scheduler_name, os_name, scheduler_args=None)#
Get an arbitrary scheduler object.
- property is_template_components_loaded: bool#
Return True if any template component (e.g. parameters) has been loaded.
- property known_subs_file_name#
- property known_subs_file_path#
- list_demo_workflows()#
Return a list of demo workflow templates included in the app.
- load_config(config_dir=None, config_key=None, **overrides)#
- Return type:
None
- load_demo_workflow(name)#
Load a WorkflowTemplate object from a builtin demo template file.
- Parameters:
name (str) –
- Return type:
WorkflowTemplate
- load_template_components(warn=True)#
Load all template component data, warning by default if already loaded.
- Return type:
None
- property parameters: ParametersList#
- perm_error_retry()#
Return a decorator for retrying functions on permission and OS errors that might be associated with cloud-storage desktop sync. engine operations.
- read_known_submissions_file()#
Retrieve existing workflows that might be running.
- reload_config(config_dir=None, config_key=None, **overrides)#
- Return type:
None
- reload_template_components(warn=True)#
Reload all template component data, warning by default if not already loaded.
- Return type:
None
- reset_config(config_dir=None, config_key=None, **overrides)#
Reset the config file to defaults, and reload the config.
- Return type:
None
- property run_time_info: RunTimeInfo#
- property scheduler_lookup#
- property scripts#
- set_inactive_in_known_subs_file(inactive_IDs)#
Set workflows in the known-submissions file to the non-running state.
Note we aim for atomicity to help with the scenario where a new workflow submission is adding itself to the file at the same time as we have decided an existing workflow should no longer be part of this file. Ideally, such a scenario should not arise because both operations should only ever be interactively initiated by the single user (Workflow.submit and App.get_known_submissions). If this operation is atomic, then at least the known-submissions file should be left in a usable (but inaccurate) state.
- show_demo_workflow(name, syntax=True, doc=False)#
Print the contents of a builtin demo workflow template file.
- property task_schemas: TaskSchemasList#
- property template_components: Dict[str, ObjectList]#
- template_components_from_json_like(json_like)#
- Return type:
None
- unload_config()#