Coverage for tests/test_pipelines.py: 33%
40 statements
« prev ^ index » next coverage.py v7.4.4, created at 2024-04-20 04:20 -0700
« prev ^ index » next coverage.py v7.4.4, created at 2024-04-20 04:20 -0700
1# This file is part of ap_pipe.
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 glob
23import os.path
24import tempfile
25import unittest
27# need to import pyproj to prevent file handle leakage
28import pyproj # noqa: F401
30import lsst.daf.butler.tests as butlerTests
31import lsst.pipe.base
32from lsst.pipe.base.tests.pipelineStepTester import PipelineStepTester # Can't use fully-qualified name
33import lsst.utils
34import lsst.utils.tests
37class PipelineDefintionsTestSuite(lsst.utils.tests.TestCase):
38 """Tests of the self-consistency of our pipeline definitions.
39 """
40 def setUp(self):
41 self.path = os.path.join(lsst.utils.getPackageDir("ap_pipe"), "pipelines")
43 def test_graph_build(self):
44 """Test that each pipeline definition file in `_ingredients/` can be
45 used to build a graph.
46 """
47 files = glob.glob(os.path.join(self.path, "_ingredients/*.yaml"))
48 for file in files:
49 if "ApTemplate" in file:
50 # Our ApTemplate definition cannot be tested here because it
51 # depends on drp_tasks, which we cannot make a dependency here.
52 continue
53 with self.subTest(file):
54 pipeline = lsst.pipe.base.Pipeline.from_uri(file)
55 if "apPipe" in pipeline.subsets:
56 pipeline.addConfigOverride("diaPipe", "apdb.db_url", "sqlite://")
57 # If this fails, it will produce a useful error message.
58 pipeline.to_graph()
60 def test_datasets(self):
61 files = glob.glob(os.path.join(self.path, "_ingredients/*.yaml"))
62 for file in files:
63 if "ApTemplate" in file:
64 # Our ApTemplate definition cannot be tested here because it
65 # depends on drp_tasks, which we cannot make a dependency here.
66 continue
67 with self.subTest(file):
68 tester = PipelineStepTester(
69 filename=file,
70 step_suffixes=[""], # Test full pipeline
71 initial_dataset_types=[("ps1_pv3_3pi_20170110", {"htm7"}, "SimpleCatalog", False),
72 ("gaia_dr2_20200414", {"htm7"}, "SimpleCatalog", False),
73 ("gaia_dr3_20230707", {"htm7"}, "SimpleCatalog", False),
74 ],
75 expected_inputs={
76 # ISR
77 "raw", "camera", "crosstalk", "crosstalkSources", "bias", "dark", "flat", "ptc",
78 "fringe", "straylightData", "bfKernel", "newBFKernel", "defects", "linearizer",
79 "opticsTransmission", "filterTransmission", "atmosphereTransmission",
80 "illumMaskedImage", "deferredChargeCalib",
81 # Everything else
82 "skyMap", "gaia_dr3_20230707", "gaia_dr2_20200414", "ps1_pv3_3pi_20170110",
83 "goodSeeingCoadd", "pretrainedModelPackage",
84 },
85 # Pipeline outputs highly in flux, don't test
86 expected_outputs=set(),
87 pipeline_patches={"diaPipe:apdb.db_url": "sqlite://",
88 },
89 )
90 # Tester modifies Butler registry, so need a fresh repo every time
91 with tempfile.TemporaryDirectory() as tempRepo:
92 butler = butlerTests.makeTestRepo(tempRepo)
93 tester.run(butler, self)
96class MemoryTester(lsst.utils.tests.MemoryTestCase):
97 pass
100def setup_module(module):
101 lsst.utils.tests.init()
104if __name__ == "__main__": 104 ↛ 105line 104 didn't jump to line 105, because the condition on line 104 was never true
105 lsst.utils.tests.init()
106 unittest.main()