diff options
author | Ross Brattain <ross.b.brattain@intel.com> | 2017-05-16 04:36:31 +0000 |
---|---|---|
committer | Gerrit Code Review <gerrit@opnfv.org> | 2017-05-16 04:36:31 +0000 |
commit | 87559e992c1f68559950b258146a530c49db9df0 (patch) | |
tree | 97fdc458522bfd182531ace2409642ed0b64ff7b /tests/unit/benchmark/scenarios/availability | |
parent | d002db9a10fed7cdba2cc43a8c064864250994ce (diff) | |
parent | 747a3260fef52fb5f7da337bc149ec202a05be6e (diff) |
Merge "Add a new monitor type: MultiMonitor that can run any number of other monitors at the same time."
Diffstat (limited to 'tests/unit/benchmark/scenarios/availability')
-rw-r--r-- | tests/unit/benchmark/scenarios/availability/test_monitor_multi.py | 61 |
1 files changed, 61 insertions, 0 deletions
diff --git a/tests/unit/benchmark/scenarios/availability/test_monitor_multi.py b/tests/unit/benchmark/scenarios/availability/test_monitor_multi.py new file mode 100644 index 000000000..9539f27d0 --- /dev/null +++ b/tests/unit/benchmark/scenarios/availability/test_monitor_multi.py @@ -0,0 +1,61 @@ +#!/usr/bin/env python + +############################################################################## +# Copyright (c) 2016 Huan Li and others +# lihuansse@tongji.edu.cn +# All rights reserved. This program and the accompanying materials +# are made available under the terms of the Apache License, Version 2.0 +# which accompanies this distribution, and is available at +# http://www.apache.org/licenses/LICENSE-2.0 +############################################################################## + +# Unittest for yardstick.benchmark.scenarios.availability.monitor +# .monitor_multi + +from __future__ import absolute_import +import mock +import unittest +from yardstick.benchmark.scenarios.availability.monitor import monitor_multi + +@mock.patch('yardstick.benchmark.scenarios.availability.monitor.' + 'monitor_general.ssh') +@mock.patch('yardstick.benchmark.scenarios.availability.monitor.' + 'monitor_general.open') +class MultiMonitorServiceTestCase(unittest.TestCase): + + def setUp(self): + host = { + "ip": "10.20.0.5", + "user": "root", + "key_filename": "/root/.ssh/id_rsa" + } + self.context = {"node1": host} + self.monitor_cfg = { + 'monitor_type': 'general-monitor', + 'monitor_number': 3, + 'key': 'service-status', + 'monitor_key': 'service-status', + 'host': 'node1', + 'monitor_time': 3, + 'parameter': {'serviceName': 'haproxy'}, + 'sla': {'max_outage_time': 1} + } + + def test__monitor_multi_all_successful(self, mock_open, mock_ssh): + ins = monitor_multi.MultiMonitor(self.monitor_cfg, self.context); + + mock_ssh.SSH().execute.return_value = (0, "running", '') + + ins.start_monitor(); + ins.wait_monitor(); + ins.verify_SLA() + + def test__monitor_multi_all_fail(self, mock_open, mock_ssh): + ins = monitor_multi.MultiMonitor(self.monitor_cfg, self.context); + + mock_ssh.SSH().execute.return_value = (1, "failed", '') + + ins.start_monitor(); + ins.wait_monitor(); + ins.verify_SLA() + |