diff options
author | Jan Gelety <jgelety@cisco.com> | 2018-05-11 10:36:41 +0200 |
---|---|---|
committer | Jan Gelety <jgelety@cisco.com> | 2018-05-31 06:41:15 +0000 |
commit | b5782684055409315412d94d1de2e5f78cffac4d (patch) | |
tree | 9b7bd941d3cdb35ad2c0fd861cb156c767606443 /resources/libraries/python/VatJsonUtil.py | |
parent | 0eeaf6eeeac256a8dfba297c57247b261912d2ca (diff) |
DPDK link bonding: xor mode
CSIT-1073
CSIT-1074
CSIT-1077
Change-Id: I248e079021c30988210fd792b32d5afdca71aadb
Signed-off-by: Jan Gelety <jgelety@cisco.com>
Diffstat (limited to 'resources/libraries/python/VatJsonUtil.py')
-rw-r--r-- | resources/libraries/python/VatJsonUtil.py | 36 |
1 files changed, 34 insertions, 2 deletions
diff --git a/resources/libraries/python/VatJsonUtil.py b/resources/libraries/python/VatJsonUtil.py index 4db4eb641a..8414838715 100644 --- a/resources/libraries/python/VatJsonUtil.py +++ b/resources/libraries/python/VatJsonUtil.py @@ -148,8 +148,9 @@ class VatJsonUtil(object): try: if interface['sw_if_index'] == sw_if_index: interface_name = interface['interface_name'] - logger.debug('Interface with name {} has sw_if_index {}.' - .format(interface_name, sw_if_index)) + logger.debug('Interface with sw_if_index {idx} has name' + ' {name}.'.format(idx=sw_if_index, + name=interface_name)) return interface_name except KeyError: pass @@ -157,6 +158,37 @@ class VatJsonUtil(object): .format(sw_if_index)) @staticmethod + def get_interface_mac_from_json(interface_dump_json, sw_if_index): + """Get interface MAC address from given JSON output by sw_if_index. + + :param interface_dump_json: JSON output from dump_interface_list VAT + command. + :param sw_if_index: SW interface index. + :type interface_dump_json: str + :type sw_if_index: int + :returns: Interface MAC address. + :rtype: str + :raises ValueError: If interface not found in interface_dump_json. + """ + logger.trace(interface_dump_json) + interface_list = JsonParser().parse_data(interface_dump_json) + for interface in interface_list: + try: + if interface['sw_if_index'] == sw_if_index: + mac_from_json = interface['l2_address'][:6] \ + if 'l2_address' in interface.keys() else '' + mac_address = ':'.join('{:02x}'.format(item) + for item in mac_from_json) + logger.debug('Interface with sw_if_index {idx} has MAC' + ' address {addr}.'.format(idx=sw_if_index, + addr=mac_address)) + return mac_address + except KeyError: + pass + raise ValueError('Interface with sw_if_index {idx} not found.' + .format(idx=sw_if_index)) + + @staticmethod def verify_vat_retval(vat_out, exp_retval=0, err_msg='VAT cmd failed'): """Verify return value of VAT command. |