1 # Copyright (c) 2016-2017 Intel Corporation
3 # Licensed under the Apache License, Version 2.0 (the "License");
4 # you may not use this file except in compliance with the License.
5 # You may obtain a copy of the License at
7 # http://www.apache.org/licenses/LICENSE-2.0
9 # Unless required by applicable law or agreed to in writing, software
10 # distributed under the License is distributed on an "AS IS" BASIS,
11 # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12 # See the License for the specific language governing permissions and
13 # limitations under the License.
15 from __future__ import absolute_import
21 from yardstick.network_services.nfvi.resource import ResourceProfile
22 from yardstick.network_services.nfvi import resource, collectd
25 class TestResourceProfile(unittest.TestCase):
26 VNFD = {'vnfd:vnfd-catalog':
28 [{'short-name': 'VpeVnf',
31 [{'network': '172.16.100.20',
32 'netmask': '255.255.255.0',
33 'gateway': '172.16.100.20',
35 {'network': '172.16.40.20',
36 'netmask': '255.255.255.0',
37 'gateway': '172.16.40.20',
39 'description': 'VPE approximation using DPDK',
40 'name': 'vpevnf-baremetal',
42 [{'network': '0064:ff9b:0:0:0:0:9810:6414',
44 'gateway': '0064:ff9b:0:0:0:0:9810:6414',
46 {'network': '0064:ff9b:0:0:0:0:9810:2814',
48 'gateway': '0064:ff9b:0:0:0:0:9810:2814',
50 'id': 'vpevnf-baremetal',
52 [{'virtual-interface':
53 {'dst_mac': '3c:fd:fe:9e:64:38',
54 'vpci': '0000:05:00.0',
55 'local_ip': '172.16.100.19',
56 'type': 'PCI-PASSTHROUGH',
57 'netmask': '255.255.255.0',
59 'bandwidth': '10 Gbps',
60 'dst_ip': '172.16.100.20',
61 'local_mac': '3c:fd:fe:a1:2b:80'},
62 'vnfd-connection-point-ref': 'xe0',
65 {'dst_mac': '00:1e:67:d0:60:5c',
66 'vpci': '0000:05:00.1',
67 'local_ip': '172.16.40.19',
68 'type': 'PCI-PASSTHROUGH',
69 'netmask': '255.255.255.0',
71 'bandwidth': '10 Gbps',
72 'dst_ip': '172.16.40.20',
73 'local_mac': '3c:fd:fe:a1:2b:81'},
74 'vnfd-connection-point-ref': 'xe1',
76 'description': 'Vpe approximation using DPDK',
78 {'vdu-id': 'vpevnf-baremetal',
84 {'kpi': ['packets_in', 'packets_fwd', 'packets_dropped']},
85 'connection-point': [{'type': 'VPORT', 'name': 'xe0'},
86 {'type': 'VPORT', 'name': 'xe1'}],
87 'id': 'VpeApproxVnf', 'name': 'VPEVnfSsh'}]}}
90 with mock.patch("yardstick.ssh.AutoConnectSSH") as ssh:
91 self.ssh_mock = mock.Mock(autospec=ssh.SSH)
92 self.ssh_mock.execute = \
93 mock.Mock(return_value=(0, "", ""))
94 ssh.from_node.return_value = self.ssh_mock
96 mgmt = self.VNFD['vnfd:vnfd-catalog']['vnfd'][0]['mgmt-interface']
98 # self.VNFD['vnfd:vnfd-catalog']['vnfd'][0]['vdu'][0]['external-interface']
100 self.VNFD['vnfd:vnfd-catalog']['vnfd'][0]['vdu'][0]['external-interface']
101 self.resource_profile = \
102 ResourceProfile(mgmt, port_names, [1, 2, 3])
103 self.resource_profile.connection = self.ssh_mock
105 def test___init__(self):
106 self.assertEqual(True, self.resource_profile.enable)
108 def test_check_if_sa_running(self):
109 self.assertEqual(self.resource_profile.check_if_sa_running("collectd"),
112 def test_check_if_sa_running_excetion(self):
113 with mock.patch.object(self.resource_profile.connection, "execute") as mock_execute:
114 mock_execute.side_effect = OSError(errno.ECONNRESET, "error")
115 self.assertEqual(self.resource_profile.check_if_sa_running("collectd"), (1, None))
117 def test_get_cpu_data(self):
118 reskey = ["", "cpufreq", "cpufreq-0"]
120 val = self.resource_profile.get_cpu_data(reskey[1], reskey[2], value)
121 self.assertIsNotNone(val)
123 def test_get_cpu_data_error(self):
124 reskey = ["", "", ""]
126 val = self.resource_profile.get_cpu_data(reskey[0], reskey[1], value)
127 self.assertEqual(val, ('error', 'Invalid', '', ''))
129 def test__start_collectd(self):
131 self.resource_profile._start_collectd(self.ssh_mock, "/opt/nsb_bin"))
133 def test__prepare_collectd_conf(self):
135 self.resource_profile._prepare_collectd_conf("/opt/nsb_bin"))
137 def test__setup_intel_pmu(self):
139 self.resource_profile._setup_intel_pmu(self.ssh_mock, "/opt/nsb_bin"))
141 def test__setup_ovs_stats(self):
143 self.resource_profile._setup_ovs_stats(self.ssh_mock))
145 @mock.patch("yardstick.network_services.nfvi.resource.open")
146 @mock.patch("yardstick.network_services.nfvi.resource.os")
147 def test__provide_config_file(self, mock_open, mock_os):
148 loadplugin = range(5)
149 port_names = range(5)
152 "loadplugin": loadplugin,
153 "port_names": port_names,
155 self.resource_profile._provide_config_file("/opt/nsb_bin", "collectd.conf", kwargs)
156 self.ssh_mock.execute.assert_called_once()
158 @mock.patch("yardstick.network_services.nfvi.resource.open")
159 def test_initiate_systemagent(self, mock_open):
160 self.resource_profile._start_collectd = mock.Mock()
162 self.resource_profile.initiate_systemagent("/opt/nsb_bin"))
164 @mock.patch("yardstick.network_services.nfvi.resource.open")
165 def test_initiate_systemagent_raise(self, mock_open):
166 self.resource_profile._start_collectd = mock.Mock(side_effect=RuntimeError)
167 with self.assertRaises(RuntimeError):
168 self.resource_profile.initiate_systemagent("/opt/nsb_bin")
170 def test__parse_hugepages(self):
171 reskey = ["cpu", "cpuFreq"]
172 value = "timestamp:12345"
173 res = self.resource_profile.parse_hugepages(reskey, value)
174 self.assertEqual({'cpu/cpuFreq': '12345'}, res)
176 def test__parse_dpdkstat(self):
177 reskey = ["dpdk0", "0"]
179 res = self.resource_profile.parse_dpdkstat(reskey, value)
180 self.assertEqual({'dpdk0/0': '12345'}, res)
182 def test__parse_virt(self):
183 reskey = ["vm0", "cpu"]
185 res = self.resource_profile.parse_virt(reskey, value)
186 self.assertEqual({'vm0/cpu': '45'}, res)
188 def test__parse_ovs_stats(self):
189 reskey = ["ovs", "stats"]
191 res = self.resource_profile.parse_ovs_stats(reskey, value)
192 self.assertEqual({'ovs/stats': '45'}, res)
194 def test_parse_collectd_result(self):
195 res = self.resource_profile.parse_collectd_result({})
196 expected_result = {'cpu': {}, 'dpdkstat': {}, 'hugepages': {},
197 'memory': {}, 'ovs_stats': {}, 'timestamp': '',
199 self.assertDictEqual(res, expected_result)
201 def test_parse_collectd_result_cpu(self):
202 metric = {"nsb_stats/cpu/0/ipc": "101"}
203 self.resource_profile.get_cpu_data = mock.Mock(return_value=[1,
207 res = self.resource_profile.parse_collectd_result(metric)
208 expected_result = {'cpu': {1: {'ipc': '1234'}}, 'dpdkstat': {}, 'hugepages': {},
209 'memory': {}, 'ovs_stats': {}, 'timestamp': '',
211 self.assertDictEqual(res, expected_result)
213 def test_parse_collectd_result_memory(self):
214 metric = {"nsb_stats/memory/bw": "101"}
215 res = self.resource_profile.parse_collectd_result(metric)
216 expected_result = {'cpu': {}, 'dpdkstat': {}, 'hugepages': {},
217 'memory': {'bw': '101'}, 'ovs_stats': {}, 'timestamp': '',
219 self.assertDictEqual(res, expected_result)
221 def test_parse_collectd_result_hugepage(self):
223 metric = {b"nsb_stats/hugepages/free": b"101"}
224 self.resource_profile.parse_hugepages = mock.Mock(return_value={"free": "101"})
225 res = self.resource_profile.parse_collectd_result(metric)
226 expected_result = {'cpu': {}, 'dpdkstat': {}, 'hugepages': {'free': '101'},
227 'memory': {}, 'ovs_stats': {}, 'timestamp': '',
229 self.assertDictEqual(res, expected_result)
231 def test_parse_collectd_result_dpdk_virt_ovs(self):
232 metric = {b"nsb_stats/dpdkstat/tx": b"101",
233 b"nsb_stats/ovs_stats/tx": b"101",
234 b"nsb_stats/virt/virt/memory": b"101"}
235 self.resource_profile.parse_dpdkstat = \
236 mock.Mock(return_value={"tx": "101"})
237 self.resource_profile.parse_virt = \
238 mock.Mock(return_value={"memory": "101"})
239 self.resource_profile.parse_ovs_stats = \
240 mock.Mock(return_value={"tx": "101"})
241 res = self.resource_profile.parse_collectd_result(metric)
242 expected_result = {'cpu': {}, 'dpdkstat': {'tx': '101'}, 'hugepages': {},
243 'memory': {}, 'ovs_stats': {'tx': '101'}, 'timestamp': '',
244 'virt': {'memory': '101'}}
245 self.assertDictEqual(res, expected_result)
247 def test_amqp_process_for_nfvi_kpi(self):
248 self.resource_profile.amqp_client = \
249 mock.MagicMock(side_effect=[None, mock.MagicMock()])
250 self.resource_profile.run_collectd_amqp = \
251 mock.Mock(return_value=0)
252 res = self.resource_profile.amqp_process_for_nfvi_kpi()
253 self.assertEqual(None, res)
255 def test_amqp_collect_nfvi_kpi(self):
256 self.resource_profile.amqp_client = \
257 mock.MagicMock(side_effect=[None, mock.MagicMock()])
258 self.resource_profile.run_collectd_amqp = \
259 mock.Mock(return_value=0)
260 self.resource_profile.parse_collectd_result = mock.Mock()
261 res = self.resource_profile.amqp_collect_nfvi_kpi()
262 self.assertIsNotNone(res)
264 def test_run_collectd_amqp(self):
265 resource.AmqpConsumer = mock.Mock(autospec=collectd)
266 self.assertIsNone(self.resource_profile.run_collectd_amqp())
268 def test_start(self):
269 self.assertIsNone(self.resource_profile.start())
272 self.assertIsNone(self.resource_profile.stop())
275 self.resource_profile.amqp_client = mock.MagicMock()
276 self.assertIsNone(self.resource_profile.stop())
278 if __name__ == '__main__':