Coverage for tests/test_cliCmdReport.py: 39%
36 statements
« prev ^ index » next coverage.py v7.5.0, created at 2024-05-01 03:36 -0700
« prev ^ index » next coverage.py v7.5.0, created at 2024-05-01 03:36 -0700
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# (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 software is dual licensed under the GNU General Public License and also
10# under a 3-clause BSD license. Recipients may choose which of these licenses
11# to use; please see the files gpl-3.0.txt and/or bsd_license.txt,
12# respectively. If you choose the GPL option then the following text applies
13# (but note that there is still no warranty even if you opt for BSD instead):
14#
15# This program is free software: you can redistribute it and/or modify
16# it under the terms of the GNU General Public License as published by
17# the Free Software Foundation, either version 3 of the License, or
18# (at your option) any later version.
19#
20# This program is distributed in the hope that it will be useful,
21# but WITHOUT ANY WARRANTY; without even the implied warranty of
22# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
23# GNU General Public License for more details.
24#
25# You should have received a copy of the GNU General Public License
26# along with this program. If not, see <http://www.gnu.org/licenses/>.
28"""Unit tests for ctrl_mpexec CLI update-graph-run subcommand."""
30import os
31import unittest
33import yaml
34from lsst.ctrl.mpexec.cli.pipetask import cli as pipetask_cli
35from lsst.daf.butler.cli.utils import LogCliRunner, clickResultMsg
36from lsst.daf.butler.tests.utils import makeTestTempDir, removeTestTempDir
37from lsst.pipe.base.tests.simpleQGraph import makeSimpleQGraph
38from lsst.pipe.base.tests.util import check_output_run
39from yaml.loader import SafeLoader
41TESTDIR = os.path.abspath(os.path.dirname(__file__))
44class ReportTest(unittest.TestCase):
45 """Test executing "pipetask report" command."""
47 def setUp(self) -> None:
48 self.runner = LogCliRunner()
49 self.root = makeTestTempDir(TESTDIR)
51 def tearDown(self) -> None:
52 removeTestTempDir(self.root)
54 def test_report(self):
55 """Test for making a report on the produced and missing expected
56 datasets in a quantum graph.
57 """
58 metadata = {"output_run": "run"}
59 butler, qgraph = makeSimpleQGraph(
60 run="run",
61 root=self.root,
62 metadata=metadata,
63 )
64 # Check that we can get the proper run collection from the qgraph
65 self.assertEqual(check_output_run(qgraph, "run"), [])
67 graph_uri = os.path.join(self.root, "graph.qgraph")
68 qgraph.saveUri(graph_uri)
70 test_filename = os.path.join(self.root, "report_test.yaml")
72 result = self.runner.invoke(
73 pipetask_cli,
74 ["report", self.root, graph_uri, "--full-output-filename", test_filename, "--no-logs"],
75 input="no",
76 )
77 # Check that we can read from the command line
78 self.assertEqual(result.exit_code, 0, clickResultMsg(result))
80 # Check that we can open and read the file produced by make_reports
81 with open(test_filename) as f:
82 report_output_dict = yaml.load(f, Loader=SafeLoader)
83 self.assertIsNotNone(report_output_dict["task0"])
84 self.assertIsNotNone(report_output_dict["task0"]["failed_quanta"])
86 result_hr = self.runner.invoke(
87 pipetask_cli,
88 ["report", self.root, graph_uri, "--no-logs", "--show-errors"],
89 input="no",
90 )
92 # Check that we can read from the command line
93 self.assertEqual(result_hr.exit_code, 0, clickResultMsg(result_hr))
95 # Check that we get string output
96 self.assertIsInstance(result_hr.stdout, str)
98 # Check that task0 and the failed quanta for task0 exist in the string
99 self.assertIn("task0", result_hr.stdout)
100 self.assertIn("Failed Quanta", result_hr.stdout)
101 self.assertIn("{'data_id': {'instrument': 'INSTR', 'detector': 0}}", result_hr.stdout)
104if __name__ == "__main__":
105 unittest.main()