Coverage for tests/test_ping.py: 34%
29 statements
« prev ^ index » next coverage.py v7.3.0, created at 2023-09-02 09:44 +0000
« prev ^ index » next coverage.py v7.3.0, created at 2023-09-02 09:44 +0000
1# This file is part of ctrl_bps.
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"""Unit tests for ping.py"""
22import logging
23import unittest
25from lsst.ctrl.bps.ping import ping
28class TestPing(unittest.TestCase):
29 """Tests for ping."""
31 def setUp(self):
32 self.logger = logging.getLogger("test_ping")
33 self.logger.setLevel(logging.INFO)
35 def tearDown(self):
36 self.logger.setLevel(logging.NOTSET)
38 def testSuccess(self):
39 status, msg = ping("wms_test_utils.WmsServiceSuccess", None)
40 self.assertEqual(status, 0)
41 self.assertEqual(msg, "")
43 def testFailed(self):
44 with self.assertLogs(level=logging.WARNING) as cm:
45 status, msg = ping("wms_test_utils.WmsServiceFailure", None)
46 self.assertNotEqual(status, 0)
47 self.assertEqual(msg, "Couldn't contact service X")
48 self.assertRegex(cm.records[0].getMessage(), "service failure")
50 def testPassThru(self):
51 with self.assertLogs(level=logging.INFO) as cm:
52 pass_thru = "EXTRA_VALUES"
53 status, msg = ping("wms_test_utils.WmsServicePassThru", pass_thru)
54 self.assertEqual(status, 0)
55 self.assertEqual(msg, pass_thru)
56 self.assertRegex(cm.records[0].getMessage(), pass_thru)
59if __name__ == "__main__": 59 ↛ 60line 59 didn't jump to line 60, because the condition on line 59 was never true
60 unittest.main()