Coverage for python/lsst/obs/base/cli/cmd/commands.py : 94%

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 obs_base.
2#
3# Developed for the LSST Data Management System.
4# This product includes software developed by the LSST Project
5# (http://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/>.
22import click
24from lsst.daf.butler.cli.opt import repo_argument, config_option, config_file_option, run_option
25from lsst.daf.butler.cli.utils import cli_handle_exception, split_commas
26from ..opt import instrument_option, transfer_option
27from ... import script
30@click.command()
31@repo_argument(required=True,
32 help="REPO is the URI or path to the gen3 repository. Will be created if it does not already "
33 "exist")
34@instrument_option(required=True,
35 help="The fully-qualified name of the gen3 Instrument subclass for this camera.")
36@click.option("--gen2root", required=True,
37 help="Root path of the gen 2 repo to be converted.")
38@click.option("--skymap-name",
39 help="Name of the new gen3 skymap (e.g. 'discrete/ci_hsc').")
40@click.option("--skymap-config",
41 help="Path to skymap config file defining the new gen3 skymap.")
42@click.option("--calibs",
43 help="Path to the gen 2 calibration repo. It can be absolute or relative to gen2root.")
44@click.option("--reruns", multiple=True, callback=split_commas,
45 help="List of gen 2 reruns to convert.")
46@transfer_option(help="Mode to use to transfer files into the new repository.")
47@config_file_option(help="Path to a `ConvertRepoConfig` override to be included after the Instrument config "
48 "overrides are applied.")
49def convert(*args, **kwargs):
50 """Convert a Butler gen 2 repository into a gen 3 repository."""
51 cli_handle_exception(script.convert, *args, **kwargs)
54@click.command()
55@repo_argument(required=True)
56@config_option()
57@config_file_option()
58@run_option(required=True)
59@click.option("-d", "--dir", "directory",
60 help="The path to the directory containing the raws to ingest.")
61@click.option("-f", "--file", help="The name of a file containing raws to ingest.")
62@transfer_option()
63@click.option("--ingest-task", default="lsst.obs.base.RawIngestTask", help="The fully qualified class name "
64 "of the ingest task to use.")
65def ingest_raws(*args, **kwargs):
66 cli_handle_exception(script.ingestRaws, *args, **kwargs)
69@click.command()
70@repo_argument(required=True)
71@instrument_option(required=True, help="The fully-qualified name of an Instrument subclass.")
72def register_instrument(*args, **kwargs):
73 """Add an instrument to the data repository.
74 """
75 cli_handle_exception(script.registerInstrument, *args, **kwargs)
78@click.command()
79@repo_argument(required=True)
80@instrument_option(required=True)
81@run_option(required=True)
82def write_curated_calibrations(*args, **kwargs):
83 """Add an instrument's curated calibrations to the data repository.
84 """
85 cli_handle_exception(script.writeCuratedCalibrations, *args, **kwargs)