Skip to content
Fetching contributors…
Cannot retrieve contributors at this time
executable file 70 lines (55 sloc) 2.65 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 TestNoEventHandlerDuringDowntime(ShinkenTest):
def setUp(self):
self.setup_with_file('etc/nagios_no_event_handler_during_downtime.cfg')
def test_no_event_handler_during_downtime(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 = time.time()
# downtime valid for the next 2 minutes
cmd = "[%lu] SCHEDULE_SVC_DOWNTIME;test_host_0;test_ok_0;%d;%d;1;0;%d;lausser;blablub" % (now, now, now + 3600, 3600)
self.sched.run_external_command(cmd)
# Make a loop to activate the downtime
self.scheduler_loop(1, [])
# We check so the downtime is really active
self.assert_(self.any_log_match('SERVICE DOWNTIME ALERT.*;STARTED'))
self.scheduler_loop(2, [[host, 0, 'UP | value1=1 value2=2'], [router, 0, 'UP | rtt=10'], [svc, 2, 'OK | value1=0 valu\
e2=0']])
# There should be NO event handlers during a downtime!
self.assert_(not self.any_log_match('SERVICE EVENT HANDLER.*;CRITICAL'))
if __name__ == '__main__':
unittest.main()
Something went wrong with that request. Please try again.