LSSTApplications  21.0.0+1b62c9342b,21.0.0+45a059f35e,21.0.0-1-ga51b5d4+ceb9cf20a3,21.0.0-17-gf9a0284+9e5b25d042,21.0.0-2-g103fe59+513edb8842,21.0.0-2-g1367e85+d9bb5204cb,21.0.0-2-g2909d54+45a059f35e,21.0.0-2-g45278ab+1b62c9342b,21.0.0-2-g4bc9b9f+36532ac5d2,21.0.0-2-g5242d73+d9bb5204cb,21.0.0-2-g54e2caa+ffbb918bba,21.0.0-2-g66bcc37+0525a04256,21.0.0-2-g7f82c8f+8938dec807,21.0.0-2-g8dde007+7bfb5851c8,21.0.0-2-g8f08a60+73884b2cf5,21.0.0-2-g973f35b+f93e1880fd,21.0.0-2-ga326454+8938dec807,21.0.0-2-ga63a54e+deb0f059c3,21.0.0-2-ga885a99+9a92674037,21.0.0-2-gc738bc1+5ce50b2a03,21.0.0-2-gde069b7+5a8f2956b8,21.0.0-2-ge17e5af+d9bb5204cb,21.0.0-2-ge712728+d5c34dc911,21.0.0-2-gecfae73+8bdf007ced,21.0.0-2-gfc62afb+d9bb5204cb,21.0.0-21-g006371a9+c7749adc24,21.0.0-3-g4c5b185+4e2de95c30,21.0.0-3-g6d51c4a+0525a04256,21.0.0-3-gaa929c8+fca53d2b73,21.0.0-3-gd222c45+afc8332dbe,21.0.0-3-gd5de2f2+0525a04256,21.0.0-4-g3300ddd+1b62c9342b,21.0.0-4-g8a80011+808ce5273f,21.0.0-5-gb7080ec+2fa830a448,21.0.0-5-gcff38f6+03a88541ab,21.0.0-6-gd3283ba+fca53d2b73,21.0.0-8-g19111d86+898b2b281f,21.0.0-8-gd9c33f4a0+b58bb1f4d6,w.2021.03
LSSTDataManagementBasePackage
tests.py
Go to the documentation of this file.
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 # (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 <https://www.gnu.org/licenses/>.
21 
22 """
23 Test aggregator for obs_* packages.
24 
25 The intention is for each obs package to have a single test class that inherits
26 from this collector class, thus "automatically" getting all new tests. If those
27 tests require setup that isn't defined in a given obs package, that obs package
28 will be broken until updated. This is intentional, as a way to prevent obs
29 packages from falling behind out of neglect.
30 """
31 
32 from lsst.log import Log
33 
34 from . import butler_tests
35 from . import mapper_tests
36 from . import camera_tests
37 
38 __all__ = ["ObsTests"]
39 
40 
43  """Aggregator class for all of the obs_* test classes.
44 
45  Inherit from this class, then lsst.utils.tests.TestCase, in that order.
46 
47  Example subclass:
48 
49  .. code-block:: python
50 
51  class TestObs(lsst.obs.base.tests.ObsTests, lsst.utils.tests.TestCase):
52  def setUp(self):
53  self.setUp_tests(...)
54  self.setUp_butler_get(...)
55  self.setUp_mapper(...)
56  self.setUp_camera(...)
57  """
58 
59  def setUp_tests(self, butler, mapper, dataIds):
60  """Set up the necessary shared variables used by multiple tests.
61 
62  Parameters
63  ----------
64  butler: lsst.daf.persistence.Butler
65  A butler object, instantiated on the testdata repository for the
66  obs package being tested.
67  mapper: lsst.obs.CameraMapper
68  A CameraMapper object for your camera, instantiated on the testdata
69  repository the obs package being tested.
70  dataIds: dict
71  dictionary of (exposure name): (dataId of that exposure in the
72  testdata repository), with unittest.SkipTest as the value for any
73  exposures you do not have/do not want to test. It must contain a
74  valid 'raw' dataId, in addition to 'bias','flat','dark', which may
75  be set to SkipTest. For example::
76 
77  self.dataIds = {'raw': {'visit': 1, 'filter': 'g'},
78  'bias': {'visit': 1},
79  'flat': {'visit': 1},
80  'dark': unittest.SkipTest
81  }
82  """
83  self.butler = butler
84  self.mapper = mapper
85  self.dataIds = dataIds
86  self.log = Log.getLogger('ObsTests')
87 
88  def tearDown(self):
89  del self.butler
90  del self.mapper
91  super(ObsTests, self).tearDown()
lsst.obs.base.tests.ObsTests.butler
butler
Definition: tests.py:83
lsst.obs.base.tests.ObsTests
Definition: tests.py:42
lsst.obs.base.camera_tests.CameraTests
Definition: camera_tests.py:32
lsst.obs.base.tests.ObsTests.dataIds
dataIds
Definition: tests.py:85
lsst.obs.base.butler_tests.ButlerGetTests
Definition: butler_tests.py:30
lsst.obs.base.mapper_tests.MapperTests
Definition: mapper_tests.py:35
lsst.obs.base.tests.ObsTests.log
log
Definition: tests.py:86
lsst::log
Definition: Log.h:706
lsst.obs.base.tests.ObsTests.mapper
mapper
Definition: tests.py:84
lsst.obs.base.tests.ObsTests.setUp_tests
def setUp_tests(self, butler, mapper, dataIds)
Definition: tests.py:59
lsst.obs.base.tests.ObsTests.tearDown
def tearDown(self)
Definition: tests.py:88