Coverage for tests/test_obs_test.py: 30%

51 statements  

« prev     ^ index     » next       coverage.py v7.1.0, created at 2023-02-05 18:08 -0800

1# This file is part of obs_test. 

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/>. 

21# 

22import os 

23import sys 

24import unittest 

25 

26import lsst.afw.geom 

27import lsst.utils.tests 

28from lsst.utils import getPackageDir 

29from lsst.geom import arcseconds, Extent2I 

30import lsst.obs.base.tests 

31import lsst.obs.test 

32 

33 

34class TestObsTest(lsst.obs.base.tests.ObsTests, lsst.utils.tests.TestCase): 

35 """Run standard obs_base unit tests. 

36 """ 

37 def setUp(self): 

38 product_dir = getPackageDir('obs_test') 

39 data_dir = os.path.join(product_dir, 'data', 'input') 

40 

41 butler = lsst.daf.persistence.Butler(root=data_dir) 

42 mapper = lsst.obs.test.TestMapper(root=data_dir) 

43 dataIds = {'raw': {'visit': 1, 'filter': 'g'}, 

44 'bias': {'visit': 1}, 

45 'flat': {'visit': 1}, 

46 'dark': unittest.SkipTest 

47 } 

48 self.setUp_tests(butler, mapper, dataIds) 

49 

50 ccdExposureId_bits = 41 

51 exposureIds = {'raw': 1, 'bias': 1, 'flat': 1} 

52 filters = {'raw': 'g', 'bias': '_unknown_', 'flat': 'g'} 

53 exptimes = {'raw': 15.0, 'bias': 0.0, 'flat': 0.0} 

54 detectorIds = {'raw': 0, 'bias': 0, 'flat': 0} 

55 detector_names = {'raw': '0', 'bias': '0', 'flat': '0'} 

56 detector_serials = {'raw': '0000011', 'bias': '0000011', 'flat': '0000011'} 

57 dimensions = {'raw': Extent2I(1026, 2000), 

58 'bias': Extent2I(1018, 2000), 

59 'flat': Extent2I(1018, 2000) 

60 } 

61 sky_origin = (79.24521968, -9.702295415) 

62 raw_subsets = (({'level': 'sensor', 'filter': 'g'}, 2), 

63 ({'level': 'sensor', 'visit': 1}, 1), 

64 ({'level': 'filter', 'visit': 1}, 1), 

65 ({'level': 'visit', 'filter': 'g'}, 2) 

66 ) 

67 linearizer_type = unittest.SkipTest 

68 

69 path_to_raw = os.path.join(data_dir, "raw", "raw_v1_fg.fits.gz") 

70 raw_header_wcs = lsst.afw.geom.makeSkyWcs(lsst.afw.fits.readMetadata(path_to_raw)) 

71 

72 self.setUp_butler_get(ccdExposureId_bits=ccdExposureId_bits, 

73 exposureIds=exposureIds, 

74 filters=filters, 

75 exptimes=exptimes, 

76 detectorIds=detectorIds, 

77 detector_names=detector_names, 

78 detector_serials=detector_serials, 

79 dimensions=dimensions, 

80 sky_origin=sky_origin, 

81 raw_subsets=raw_subsets, 

82 linearizer_type=linearizer_type, 

83 raw_header_wcs=raw_header_wcs 

84 ) 

85 

86 keys = set(('filter', 'name', 'patch', 'tract', 'visit', 'pixel_id', 'subfilter', 

87 'fgcmcycle', 'numSubfilters', 'label', 'detector', 'expId', 'subdir', 

88 'dayObs', 'seqNum')) 

89 query_format = ["visit", "filter"] 

90 queryMetadata = (({'visit': 1}, [(1, 'g')]), 

91 ({'visit': 2}, [(2, 'g')]), 

92 ({'visit': 3}, [(3, 'r')]), 

93 ({'filter': 'g'}, [(1, 'g'), (2, 'g')]), 

94 ({'filter': 'r'}, [(3, 'r')]), 

95 ) 

96 map_python_type = 'lsst.afw.image.DecoratedImageU' 

97 map_cpp_type = 'DecoratedImageU' 

98 map_storage_name = 'FitsStorage' 

99 metadata_output_path = os.path.join('processCcd_metadata', 'v1_fg.yaml') 

100 raw_filename = 'raw_v1_fg.fits.gz' 

101 default_level = 'visit' 

102 raw_levels = (('skyTile', set(['filter'])), 

103 ('filter', set(['filter', 'visit'])), 

104 ('visit', set(['filter', 'visit'])) 

105 ) 

106 self.setUp_mapper(output=data_dir, 

107 path_to_raw=path_to_raw, 

108 keys=keys, 

109 query_format=query_format, 

110 queryMetadata=queryMetadata, 

111 metadata_output_path=metadata_output_path, 

112 map_python_type=map_python_type, 

113 map_cpp_type=map_cpp_type, 

114 map_storage_name=map_storage_name, 

115 raw_filename=raw_filename, 

116 default_level=default_level, 

117 raw_levels=raw_levels, 

118 ) 

119 

120 self.setUp_camera(camera_name='test', 

121 n_detectors=1, 

122 first_detector_name='0', 

123 plate_scale=20 * arcseconds, 

124 ) 

125 

126 super(TestObsTest, self).setUp() 

127 

128 

129class MemoryTester(lsst.utils.tests.MemoryTestCase): 

130 pass 

131 

132 

133def setup_module(module): 

134 lsst.utils.tests.init() 

135 

136 

137if __name__ == '__main__': 137 ↛ 138line 137 didn't jump to line 138, because the condition on line 137 was never true

138 setup_module(sys.modules[__name__]) 

139 unittest.main()