Merge "KVMFORNFV: To avoid livemigration result update to json"
[yardstick.git] / tests / unit / benchmark / scenarios / compute / test_qemumigrate.py
1 #!/usr/bin/env python
2
3 ##############################################################################
4 # Copyright (c) 2015 Huawei Technologies Co.,Ltd and other.
5 #
6 # All rights reserved. This program and the accompanying materials
7 # are made available under the terms of the Apache License, Version 2.0
8 # which accompanies this distribution, and is available at
9 # http://www.apache.org/licenses/LICENSE-2.0
10 ##############################################################################
11
12 # Unittest for yardstick.benchmark.scenarios.compute.qemu_migrate.QemuMigrate
13
14 from __future__ import absolute_import
15
16 import unittest
17
18 import mock
19
20 from yardstick.benchmark.scenarios.compute import qemu_migrate
21
22
23 @mock.patch('yardstick.benchmark.scenarios.compute.qemu_migrate.ssh')
24 class QemuMigrateTestCase(unittest.TestCase):
25
26     def setUp(self):
27         self.scenario_cfg = {
28             "host": "kvm.LF",
29             "setup_options": {
30                 "rpm_dir": "/opt/rpm",
31                 "script_dir": "/opt/scripts",
32                 "image_dir": "/opt/image",
33                 "host_setup_seqs": [
34                     "host-setup0.sh",
35                     "host-setup1.sh",
36                     "setup-ovsdpdk.sh",
37                     "host-install-qemu.sh",
38                     "host-run-qemu4lm.sh"
39                 ]
40             },
41             "sla": {
42                 "action": "monitor",
43                 "max_totaltime": 10,
44                 "max_downtime": 0.10,
45                 "max_setuptime": 0.50
46             },
47             "options": {
48                 "smp": 99,
49                 "migrate_to_port": 4444,
50                 "incoming_ip": 0,
51                 "qmp_src_path": "/tmp/qmp-sock-src",
52                 "qmp_dst_path": "/tmp/qmp-sock-dst",
53                 "max_down_time": "0.10"
54             }
55         }
56         self.context_cfg = {
57             "host": {
58                 "ip": "10.229.43.154",
59                 "key_filename": "/yardstick/resources/files/yardstick_key",
60                 "role": "BareMetal",
61                 "name": "kvm.LF",
62                 "user": "root"
63             }
64         }
65
66     def test_qemu_migrate_successful_setup(self, mock_ssh):
67
68         q = qemu_migrate.QemuMigrate(self.scenario_cfg, self.context_cfg)
69         mock_ssh.SSH.from_node().execute.return_value = (0, '', '')
70
71         q.setup()
72         self.assertIsNotNone(q.host)
73         self.assertEqual(q.setup_done, True)
74
75     def test_qemu_migrate_successful_no_sla(self, mock_ssh):
76         result = {}
77         self.scenario_cfg.pop("sla", None)
78         q = qemu_migrate.QemuMigrate(self.scenario_cfg, self.context_cfg)
79         mock_ssh.SSH.from_node().execute.return_value = (0, '', '')
80         q.setup()
81
82         sample_output = '{"totaltime": 15, "downtime": 2, "setuptime": 1}'
83         mock_ssh.SSH.from_node().execute.return_value = (0, sample_output, '')
84
85         q.run(result)
86         expected_result = {}
87         self.assertEqual(result, expected_result)
88
89     def test_qemu_migrate_successful_sla(self, mock_ssh):
90         result = {}
91         self.scenario_cfg.update({"sla": {
92             "action": "monitor",
93             "max_totaltime": 15,
94             "max_downtime": 2,
95             "max_setuptime": 1
96         }
97         })
98         q = qemu_migrate.QemuMigrate(self.scenario_cfg, self.context_cfg)
99         mock_ssh.SSH.from_node().execute.return_value = (0, '', '')
100         q.setup()
101
102         sample_output = '{"totaltime": 15, "downtime": 2, "setuptime": 1}'
103         mock_ssh.SSH.from_node().execute.return_value = (0, sample_output, '')
104
105         q.run(result)
106         expected_result = {}
107         self.assertEqual(result, expected_result)
108
109     def test_qemu_migrate_unsuccessful_sla_totaltime(self, mock_ssh):
110
111         result = {}
112         self.scenario_cfg.update({"sla": {"max_totaltime": 10}})
113         q = qemu_migrate.QemuMigrate(self.scenario_cfg, self.context_cfg)
114         mock_ssh.SSH.from_node().execute.return_value = (0, '', '')
115         q.setup()
116
117         sample_output = '{"totaltime": 15, "downtime": 2, "setuptime": 1}'
118
119         mock_ssh.SSH.from_node().execute.return_value = (0, sample_output, '')
120         with self.assertRaises(AssertionError):
121           q.run(result)
122
123     def test_qemu_migrate_unsuccessful_sla_downtime(self, mock_ssh):
124
125         result = {}
126         self.scenario_cfg.update({"sla": {"max_downtime": 0.10}})
127         q = qemu_migrate.QemuMigrate(self.scenario_cfg, self.context_cfg)
128         mock_ssh.SSH.from_node().execute.return_value = (0, '', '')
129         q.setup()
130
131         sample_output = '{"totaltime": 15, "downtime": 2, "setuptime": 1}'
132
133         mock_ssh.SSH.from_node().execute.return_value = (0, sample_output, '')
134         with self.assertRaises(AssertionError):
135           q.run(result)
136
137     def test_qemu_migrate_unsuccessful_sla_setuptime(self, mock_ssh):
138
139         result = {}
140         self.scenario_cfg.update({"sla": {"max_setuptime": 0.50}})
141         q = qemu_migrate.QemuMigrate(self.scenario_cfg, self.context_cfg)
142         mock_ssh.SSH.from_node().execute.return_value = (0, '', '')
143         q.setup()
144
145         sample_output = '{"totaltime": 15, "downtime": 2, "setuptime": 1}'
146
147         mock_ssh.SSH.from_node().execute.return_value = (0, sample_output, '')
148         with self.assertRaises(AssertionError):
149           q.run(result)
150
151     def test_qemu_migrate_unsuccessful_script_error(self, mock_ssh):
152
153         result = {}
154         self.scenario_cfg.update({"sla": {"max_totaltime": 10}})
155         q = qemu_migrate.QemuMigrate(self.scenario_cfg, self.context_cfg)
156         mock_ssh.SSH.from_node().execute.return_value = (0, '', '')
157         q.setup()
158
159         mock_ssh.SSH.from_node().execute.return_value = (1, '', 'FOOBAR')
160         with self.assertRaises(RuntimeError):
161           q.run(result)
162
163 def main():
164     unittest.main()
165
166 if __name__ == '__main__':
167     main()