Coverage for tests/test_cliCmdQueryCollections.py : 49%

Hot-keys on this page
r m x p toggle line displays
j k next/prev highlighted chunk
0 (zero) top of page
1 (one) first highlighted chunk
1# This file is part of daf_butler.
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/>.
22"""Unit tests for daf_butler CLI query-collections command.
23"""
25import unittest
26import yaml
28from lsst.daf.butler import Butler, CollectionType
29from lsst.daf.butler.cli.butler import cli
30from lsst.daf.butler.cli.cmd import query_collections
31from lsst.daf.butler.cli.utils import LogCliRunner
32from lsst.daf.butler.tests import CliCmdTestBase
35class QueryCollectionsCmdTest(CliCmdTestBase, unittest.TestCase):
37 @staticmethod
38 def defaultExpected():
39 return dict(repo=None,
40 collection_type=tuple(CollectionType.__members__.values()),
41 flatten_chains=False,
42 glob=(),
43 include_chains=None)
45 @staticmethod
46 def command():
47 return query_collections
49 def test_minimal(self):
50 """Test only the required parameters, and omit the optional parameters.
51 """
52 self.run_test(["query-collections", "here"],
53 self.makeExpected(repo="here"))
55 def test_all(self):
56 """Test all parameters"""
57 self.run_test(["query-collections", "here", "foo*",
58 "--collection-type", "TAGGED",
59 "--collection-type", "RUN",
60 "--flatten-chains",
61 "--include-chains"],
62 self.makeExpected(repo="here",
63 glob=("foo*",),
64 collection_type=(CollectionType.TAGGED, CollectionType.RUN),
65 flatten_chains=True,
66 include_chains=True))
69class QueryCollectionsScriptTest(unittest.TestCase):
71 def testGetCollections(self):
72 run = "ingest/run"
73 tag = "tag"
74 runner = LogCliRunner()
75 with runner.isolated_filesystem():
76 butlerCfg = Butler.makeRepo("here")
77 # the purpose of this call is to create some collections
78 _ = Butler(butlerCfg, run=run, tags=[tag], collections=[tag])
80 # Verify collections that were created are found by
81 # query-collections.
82 result = runner.invoke(cli, ["query-collections", "here"])
83 self.assertEqual({"collections": [run, tag]}, yaml.safe_load(result.output))
85 # Verify that with a glob argument, that only collections whose
86 # name matches with the specified pattern are returned.
87 result = runner.invoke(cli, ["query-collections", "here", "t*"])
88 self.assertEqual({"collections": [tag]}, yaml.safe_load(result.output))
90 # Verify that with a collection type argument, only collections of
91 # that type are returned.
92 result = runner.invoke(cli, ["query-collections", "here", "--collection-type", "RUN"])
93 self.assertEqual({"collections": [run]}, yaml.safe_load(result.output))
96if __name__ == "__main__": 96 ↛ 97line 96 didn't jump to line 97, because the condition on line 96 was never true
97 unittest.main()