+ logger.trace(f"Interface {ifc} not found by MAC {if_mac}")
+ ifc[u"vpp_sw_index"] = None
+ continue
+ ifc[u"name"] = interface_dict[u"interface_name"]
+ ifc[u"vpp_sw_index"] = interface_dict[u"sw_if_index"]
+ ifc[u"mtu"] = interface_dict[u"mtu"]
+
+ @staticmethod
+ def get_interface_sw_index_from_json(interface_dump_json, interface_name):
+ """Get sw_if_index from given JSON output by interface name.
+
+ :param interface_dump_json: JSON output from dump_interface_list VAT
+ command.
+ :param interface_name: Interface name.
+ :type interface_dump_json: str
+ :type interface_name: str
+ :returns: SW interface index.
+ :rtype: int
+ :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[u"interface_name"] == interface_name:
+ index = interface[u"sw_if_index"]
+ logger.debug(
+ f"Interface with name {interface_name} "
+ f"has sw_if_index {index}."
+ )
+ return index
+ except KeyError:
+ pass
+ raise ValueError(f"Interface with name {interface_name} not found.")
+
+ @staticmethod
+ def get_interface_name_from_json(interface_dump_json, sw_if_index):
+ """Get interface name 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 name.
+ :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[u"sw_if_index"] == sw_if_index:
+ interface_name = interface[u"interface_name"]
+ logger.debug(
+ f"Interface with sw_if_index {sw_if_index} "
+ f"has name {interface_name}."
+ )
+ return interface_name
+ except KeyError:
+ pass
+ raise ValueError(f"Interface with sw_if_index {sw_if_index} not found.")
+
+ @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[u"sw_if_index"] == sw_if_index:
+ mac_from_json = interface[u"l2_address"][:6] \
+ if u"l2_address" in list(interface.keys()) else u""
+ mac_address = u":".join(
+ f"{item:02x}" for item in mac_from_json
+ )
+ logger.debug(
+ f"Interface with sw_if_index {sw_if_index} "
+ f"has MAC address {mac_address}."
+ )
+ return mac_address
+ except KeyError:
+ pass
+ raise ValueError(f"Interface with sw_if_index {sw_if_index} not found.")
+
+ @staticmethod
+ def verify_vat_retval(vat_out, exp_retval=0, err_msg=u"VAT cmd failed"):
+ """Verify return value of VAT command.
+
+ VAT command JSON output should be object (dict in python) or array. We
+ are looking for something like this: { "retval": 0 }. Verification is
+ skipped if VAT output does not contain return value element or root
+ elemet is array.
+
+ :param vat_out: VAT command output in python representation of JSON.
+ :param exp_retval: Expected return value (default 0).
+ :err_msg: Message to be displayed in case of error (optional).
+ :type vat_out: dict or list
+ :type exp_retval: int
+ :type err_msg: str
+ :raises RuntimeError: If VAT command return value is incorrect.
+ """
+ if isinstance(vat_out, dict):
+ retval = vat_out.get(u"retval")
+ if retval is not None:
+ if retval != exp_retval:
+ raise RuntimeError(err_msg)