blob: 0a3d2d02fce0d4c04e91f493f25917491ea7f1a1 [file] [log] [blame]
Hanna Arhipovae6ed8e42019-05-15 16:27:08 +03001import pytest
2import json
3import utils
4import os
5
6
7def test_mtu(local_salt_client, nodes_in_group):
8 testname = os.path.basename(__file__).split('.')[0]
9 config = utils.get_configuration()
10 skipped_ifaces = config.get(testname)["skipped_ifaces"] or \
11 ["bonding_masters", "lo", "veth", "tap", "cali", "qv", "qb", "br-int", "vxlan"]
12 total = {}
13 network_info = local_salt_client.cmd(
14 tgt="L@"+','.join(nodes_in_group),
15 param='ls /sys/class/net/',
16 expr_form='compound')
17
18 kvm_nodes = local_salt_client.test_ping(tgt='salt:control').keys()
19
20 if len(network_info.keys()) < 2:
21 pytest.skip("Nothing to compare - only 1 node")
22
23 for node, ifaces_info in network_info.iteritems():
24 if isinstance(ifaces_info, bool):
25 print ("{} node is skipped".format(node))
26 continue
27 if node in kvm_nodes:
28 kvm_info = local_salt_client.cmd(tgt=node,
29 param="virsh list | "
30 "awk '{print $2}' | "
31 "xargs -n1 virsh domiflist | "
32 "grep -v br-pxe | grep br- | "
33 "awk '{print $1}'")
34 ifaces_info = kvm_info.get(node)
35 node_ifaces = ifaces_info.split('\n')
36 ifaces = {}
37 for iface in node_ifaces:
38 for skipped_iface in skipped_ifaces:
39 if skipped_iface in iface:
40 break
41 else:
42 iface_mtu = local_salt_client.cmd(tgt=node,
43 param='cat /sys/class/'
44 'net/{}/mtu'.format(iface))
45 ifaces[iface] = iface_mtu.get(node)
46 total[node] = ifaces
47
48 nodes = []
49 mtu_data = []
50 my_set = set()
51
52 for node in total:
53 nodes.append(node)
54 my_set.update(total[node].keys())
55 for interf in my_set:
56 diff = []
57 row = []
58 for node in nodes:
59 if interf in total[node].keys():
60 diff.append(total[node][interf])
61 row.append("{}: {}".format(node, total[node][interf]))
62 else:
63 # skip node with no virbr0 or virbr0-nic interfaces
64 if interf not in ['virbr0', 'virbr0-nic']:
65 row.append("{}: No interface".format(node))
66 if diff.count(diff[0]) < len(nodes):
67 row.sort()
68 row.insert(0, interf)
69 mtu_data.append(row)
70 assert len(mtu_data) == 0, \
71 "Several problems found: {0}".format(
72 json.dumps(mtu_data, indent=4))