Coverage for tests / test_cliCmdDefineVisits.py: 64%

20 statements  

« prev     ^ index     » next       coverage.py v7.13.5, created at 2026-05-07 08:21 +0000

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

21 

22"""Unit tests for daf_butler CLI define-visits command.""" 

23 

24import unittest 

25 

26from lsst.daf.butler.tests import CliCmdTestBase 

27from lsst.obs.base.cli.cmd import define_visits 

28 

29 

30class DefineVisitsTest(CliCmdTestBase, unittest.TestCase): 

31 """Test the define-visits command-line tool.""" 

32 

33 mockFuncName = "lsst.obs.base.cli.cmd.commands.script.defineVisits" 

34 

35 @staticmethod 

36 def defaultExpected(): 

37 return {"config_file": None, "collections": ()} 

38 

39 @staticmethod 

40 def command(): 

41 return define_visits 

42 

43 def test_repoBasic(self): 

44 """Test the most basic required arguments.""" 

45 self.run_test( 

46 ["define-visits", "here", "a.b.c"], 

47 self.makeExpected( 

48 repo="here", 

49 instrument="a.b.c", 

50 where="", 

51 update_records=False, 

52 incremental=False, 

53 skip_conflicting=False, 

54 prefilter=False, 

55 check_detector_regions=False, 

56 ), 

57 ) 

58 

59 def test_all(self): 

60 """Test all the arguments.""" 

61 self.run_test( 

62 [ 

63 "define-visits", 

64 "here", 

65 "a.b.c", 

66 "--collections", 

67 "foo/bar,baz", 

68 "--config-file", 

69 "/path/to/config", 

70 "--collections", 

71 "boz", 

72 "--where", 

73 "x=y", 

74 "--incremental", 

75 "--update-records", 

76 "--skip-conflicting", 

77 ], 

78 self.makeExpected( 

79 repo="here", 

80 instrument="a.b.c", 

81 config_file="/path/to/config", 

82 # The list of collections must be in 

83 # exactly the same order as it is 

84 # passed in the list of arguments to 

85 # run_test. 

86 collections=("foo/bar", "baz", "boz"), 

87 where="x=y", 

88 update_records=True, 

89 incremental=True, 

90 skip_conflicting=True, 

91 prefilter=False, 

92 check_detector_regions=False, 

93 ), 

94 ) 

95 

96 def test_missing(self): 

97 """Test a missing argument.""" 

98 self.run_missing(["define-visits"], "Missing argument ['\"]REPO['\"]") 

99 self.run_missing(["define-visits", "here"], "Missing argument ['\"]INSTRUMENT['\"]") 

100 

101 

102if __name__ == "__main__": 102 ↛ 103line 102 didn't jump to line 103 because the condition on line 102 was never true

103 unittest.main()