diff options
author | Jan Gelety <jgelety@cisco.com> | 2017-10-17 15:31:05 +0200 |
---|---|---|
committer | Jan Gelety <jgelety@cisco.com> | 2017-11-10 11:37:38 +0000 |
commit | 7bfb36dfd9284bbca10881e31e14108c7d468b7c (patch) | |
tree | 2f02f2969bbd945863b741033e12c098107f1a17 /resources/libraries/python/VhostUser.py | |
parent | 3e231e67a7a88f14d147e74c7612f45670c999d6 (diff) |
CSIT-843: Update actual topology in case of new/updated/deleted interface
Change-Id: I6adfe86bd0b9cdf3d194a1b871e52481c333d8e7
Signed-off-by: Jan Gelety <jgelety@cisco.com>
Diffstat (limited to 'resources/libraries/python/VhostUser.py')
-rw-r--r-- | resources/libraries/python/VhostUser.py | 24 |
1 files changed, 17 insertions, 7 deletions
diff --git a/resources/libraries/python/VhostUser.py b/resources/libraries/python/VhostUser.py index 680d4ae300..2e0ed1eada 100644 --- a/resources/libraries/python/VhostUser.py +++ b/resources/libraries/python/VhostUser.py @@ -14,7 +14,8 @@ """Vhost-user interfaces library.""" from resources.libraries.python.VatExecutor import VatExecutor, VatTerminal -from resources.libraries.python.topology import NodeType +from resources.libraries.python.topology import NodeType, Topology +from resources.libraries.python.InterfaceUtil import InterfaceUtil class VhostUser(object): @@ -28,13 +29,22 @@ class VhostUser(object): :param socket: Vhost-user interface socket path. :type node: dict :type socket: str - :return: SW interface index. + :returns: SW interface index. :rtype: int + :raises RuntimeError: If Vhost-user interface creation failed. """ - out = VatExecutor.cmd_from_template(node, "create_vhost_user_if.vat", + out = VatExecutor.cmd_from_template(node, 'create_vhost_user_if.vat', sock=socket) if out[0].get('retval') == 0: - return out[0].get('sw_if_index') + sw_if_idx = int(out[0].get('sw_if_index')) + if_key = Topology.add_new_port(node, 'vhost') + Topology.update_interface_sw_if_index(node, if_key, sw_if_idx) + ifc_name = InterfaceUtil.vpp_get_interface_name(node, sw_if_idx) + Topology.update_interface_name(node, if_key, ifc_name) + ifc_mac = InterfaceUtil.vpp_get_interface_mac(node, sw_if_idx) + Topology.update_interface_mac_address(node, if_key, ifc_mac) + Topology.update_interface_vhost_socket(node, if_key, socket) + return sw_if_idx else: raise RuntimeError('Create Vhost-user interface failed on node ' '"{}"'.format(node['host'])) @@ -47,7 +57,7 @@ class VhostUser(object): :param socket: Vhost-user interface socket path. :type node: dict :type socket: str - :return: Interface name or None if not found. + :returns: Interface name or None if not found. :rtype: str """ for interface in node['interfaces'].values(): @@ -64,7 +74,7 @@ class VhostUser(object): :param sw_if_index: Idx of the specific interface. :type node: dict :type sw_if_index: str - :return: l2_address of the given interface. + :returns: l2_address of the given interface. :rtype: str """ @@ -83,7 +93,7 @@ class VhostUser(object): :param node: VPP node to get interface data from. :type node: dict - :return: nothing + :returns: nothing """ vat = VatExecutor() vat.execute_script("show_vhost.vat", node, json_out=False) |