Skip to content
Fetching contributors…
Cannot retrieve contributors at this time
executable file 65 lines (53 sloc) 2.45 KB
#!/usr/bin/env python
# Copyright (C) 2009-2010:
# Gabes Jean, naparuba@gmail.com
# Gerhard Lausser, Gerhard.Lausser@consol.de
#
# This file is part of Shinken.
#
# Shinken is free software: you can redistribute it and/or modify
# it under the terms of the GNU Affero General Public License as published by
# the Free Software Foundation, either version 3 of the License, or
# (at your option) any later version.
#
# Shinken is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU Affero General Public License for more details.
#
# You should have received a copy of the GNU Affero General Public License
# along with Shinken. If not, see <http://www.gnu.org/licenses/>.
#
# This file is used to test reading and processing of config files
#
from shinken_test import *
class TestNoNotificationPeriod(ShinkenTest):
def setUp(self):
self.setup_with_file('etc/nagios_no_notification_period.cfg')
# no notification period should do a 24x7 like period
# so a None, but always valid in create_notification
def test_no_notification_period(self):
print "Get the hosts and services"
now = time.time()
host = self.sched.hosts.find_by_name("test_host_0")
host.checks_in_progress = []
host.act_depend_of = [] # ignore the router
router = self.sched.hosts.find_by_name("test_router_0")
router.checks_in_progress = []
router.act_depend_of = [] # ignore the router
svc = self.sched.services.find_srv_by_name_and_hostname("test_host_0", "test_ok_0")
svc.checks_in_progress = []
svc.act_depend_of = [] # no hostchecks on critical checkresults
self.scheduler_loop(2, [[host, 0, 'UP | value1=1 value2=2'], [router, 0, 'UP | rtt=10'], [svc, 0, 'OK | value1=0 value2=0']])
self.assert_(host.state == 'UP')
self.assert_(host.state_type == 'HARD')
# Now get bad :)
self.scheduler_loop(2, [[svc, 2, 'BAD | value1=0 value2=0']])
self.assert_(svc.notification_period is None)
self.assert_(self.any_log_match('SERVICE NOTIFICATION.*;CRITICAL'))
# Now for the host :)
self.scheduler_loop(5, [[host, 2, 'BAD | value1=0 value2=0']])
self.assert_(host.notification_period is None)
self.assert_(self.any_log_match('HOST NOTIFICATION.*;DOWN'))
if __name__ == '__main__':
unittest.main()
Something went wrong with that request. Please try again.