Coverage for python/lsst/ctrl/mpexec/cli/opt/optionGroups.py : 66%

Hot-keys on this page
r m x p toggle line displays
j k next/prev highlighted chunk
0 (zero) top of page
1 (one) first highlighted chunk
1# This file is part of ctrl_mpexec.
2#
3# Developed for the LSST Data Management System.
4# This product includes software developed by the LSST Project
5# (https://www.lsst.org).
6# See the COPYRIGHT file at the top-level directory of this distribution
7# for details of code ownership.
8#
9# This program is free software: you can redistribute it and/or modify
10# it under the terms of the GNU General Public License as published by
11# the Free Software Foundation, either version 3 of the License, or
12# (at your option) any later version.
13#
14# This program is distributed in the hope that it will be useful,
15# but WITHOUT ANY WARRANTY; without even the implied warranty of
16# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
17# GNU General Public License for more details.
18#
19# You should have received a copy of the GNU General Public License
20# along with this program. If not, see <http://www.gnu.org/licenses/>.
23__all__ = ("butler_options", "execution_options", "meta_info_options", "pipeline_build_options",
24 "qgraph_options", "run_options")
27import click
29from lsst.daf.butler.cli.utils import option_section, unwrap
30import lsst.obs.base.cli.opt as obsBaseOpts
31import lsst.daf.butler.cli.opt as dafButlerOpts
32from . import options as ctrlMpExecOpts
34instrumentOptionHelp = ("Add an instrument which will be used to load config overrides when defining a "
35 "pipeline. This must be the fully qualified class name.")
38class OptionGroup:
39 """Base class for an option group decorator. Requires the option group
40 subclass to have a property called `decorator`."""
42 def __call__(self, f):
43 for decorator in reversed(self.decorators):
44 f = decorator(f)
45 return f
48class pipeline_build_options(OptionGroup): # noqa: N801
49 """Decorator to add options to a command function for building a pipeline.
50 """
52 def __init__(self):
53 self.decorators = [
54 option_section(sectionText="Pipeline build options:"),
55 ctrlMpExecOpts.pipeline_option(),
56 ctrlMpExecOpts.task_option(),
57 ctrlMpExecOpts.delete_option(metavar="LABEL"),
58 dafButlerOpts.config_option(metavar="LABEL:NAME=VALUE", multiple=True),
59 dafButlerOpts.config_file_option(help=unwrap("""Configuration override file(s), applies to a task
60 with a given label."""),
61 metavar="LABEL:FILE",
62 multiple=True),
63 ctrlMpExecOpts.order_pipeline_option(),
64 ctrlMpExecOpts.save_pipeline_option(),
65 ctrlMpExecOpts.pipeline_dot_option(),
66 obsBaseOpts.instrument_option(help=instrumentOptionHelp, metavar="instrument", multiple=True)]
69class qgraph_options(OptionGroup): # noqa: N801
70 """Decorator to add options to a command function for creating a quantum
71 graph."""
73 def __init__(self):
74 self.decorators = [
75 option_section(sectionText="Quantum graph building options:"),
76 ctrlMpExecOpts.qgraph_option(),
77 ctrlMpExecOpts.qgraph_id_option(),
78 ctrlMpExecOpts.qgraph_node_id_option(),
79 ctrlMpExecOpts.skip_existing_option(),
80 ctrlMpExecOpts.save_qgraph_option(),
81 ctrlMpExecOpts.save_single_quanta_option(),
82 ctrlMpExecOpts.qgraph_dot_option()]
85class butler_options(OptionGroup): # noqa: N801
86 """Decorator to add options to a command function for configuring a butler.
87 """
89 def __init__(self):
90 self.decorators = [
91 option_section(sectionText="Data repository and selection options:"),
92 ctrlMpExecOpts.butler_config_option(),
93 ctrlMpExecOpts.input_option(),
94 ctrlMpExecOpts.output_option(),
95 ctrlMpExecOpts.output_run_option(),
96 ctrlMpExecOpts.extend_run_option(),
97 ctrlMpExecOpts.replace_run_option(),
98 ctrlMpExecOpts.prune_replaced_option(),
99 ctrlMpExecOpts.data_query_option()]
102class execution_options(OptionGroup): # noqa: N801
103 """Decorator to add options to a command function for executing a pipeline.
104 """
106 def __init__(self):
107 self.decorators = [
108 option_section(sectionText="Execution options:"),
109 ctrlMpExecOpts.clobber_partial_outputs_option(),
110 ctrlMpExecOpts.do_raise_option(),
111 ctrlMpExecOpts.profile_option(),
112 dafButlerOpts.processes_option(),
113 ctrlMpExecOpts.start_method_option(),
114 ctrlMpExecOpts.timeout_option(),
115 ctrlMpExecOpts.fail_fast_option(),
116 ctrlMpExecOpts.graph_fixup_option()]
119class meta_info_options(OptionGroup): # noqa: N801
120 """Decorator to add options to a command function for managing pipeline
121 meta information."""
123 def __init__(self):
124 self.decorators = [
125 option_section(sectionText="Meta-information output options:"),
126 ctrlMpExecOpts.skip_init_writes_option(),
127 ctrlMpExecOpts.init_only_option(),
128 ctrlMpExecOpts.register_dataset_types_option(),
129 ctrlMpExecOpts.no_versions_option()]
132class run_options(OptionGroup): # noqa: N801
133 """Decorator to add the run options to the run command."""
135 def __init__(self):
136 self.decorators = [
137 click.pass_context,
138 ctrlMpExecOpts.debug_option(),
139 ctrlMpExecOpts.show_option(),
140 pipeline_build_options(),
141 qgraph_options(),
142 butler_options(),
143 execution_options(),
144 meta_info_options(),
145 option_section(sectionText=""),
146 dafButlerOpts.options_file_option(),
147 ]