diff options
author | Tibor Frank <tifrank@cisco.com> | 2016-05-02 18:19:04 +0200 |
---|---|---|
committer | Tibor Frank <tifrank@cisco.com> | 2016-05-09 10:04:17 +0200 |
commit | f32168ef95c3b68567ccd57e098d74ad9a536edd (patch) | |
tree | e4eaba9fb428685c14c9f011a521521a172e9ccb /resources | |
parent | e91261e76664aa94b515e3e6923a5d4e2ac883a0 (diff) |
Interface VxLAN test
JIRA: CSIT-45
- add test: Honeycomb modifies interface configuration - VxLAN
- add keywords used in these tests to set and verify configuration
- add method and vat template for dumping an interface's configured VxLAN
- fixed requirements.txt
Change-Id: I6d6c360a4d478a0e40eecf7c0235969e7c06f7a9
Signed-off-by: Tibor Frank <tifrank@cisco.com>
Signed-off-by: C.J. Collier <cjcollier@linuxfoundation.org>
Diffstat (limited to 'resources')
-rw-r--r-- | resources/libraries/python/InterfaceUtil.py | 26 | ||||
-rw-r--r-- | resources/libraries/robot/honeycomb/interfaces.robot | 65 | ||||
-rw-r--r-- | resources/templates/vat/vxlan_dump.vat | 1 |
3 files changed, 92 insertions, 0 deletions
diff --git a/resources/libraries/python/InterfaceUtil.py b/resources/libraries/python/InterfaceUtil.py index ec2ef69dfc..35194f2487 100644 --- a/resources/libraries/python/InterfaceUtil.py +++ b/resources/libraries/python/InterfaceUtil.py @@ -494,6 +494,32 @@ class InterfaceUtil(object): .format(node)) @staticmethod + def vxlan_dump(node, interface): + """Get VxLAN data for the given interface. + + :param node: VPP node to get interface data from. + :param interface: Numeric index or name string of a specific interface. + :type node: dict + :type interface: int or str + :return: Dictionary containing data for the given VxLAN. + :rtype dict + """ + + if isinstance(interface, basestring): + sw_if_index = Topology.get_interface_sw_index(node, interface) + else: + sw_if_index = interface + + with VatTerminal(node) as vat: + response = vat.vat_terminal_exec_cmd_from_template( + "vxlan_dump.vat", sw_if_index=sw_if_index) + + for vxlan in response[0]: + if vxlan["sw_if_index"] == sw_if_index: + return vxlan + return {} + + @staticmethod def create_subinterface(node, interface, sub_id, outer_vlan_id, inner_vlan_id, type_subif): """Create sub-interface on node. diff --git a/resources/libraries/robot/honeycomb/interfaces.robot b/resources/libraries/robot/honeycomb/interfaces.robot index 0768fd3021..f98cca0901 100644 --- a/resources/libraries/robot/honeycomb/interfaces.robot +++ b/resources/libraries/robot/honeycomb/interfaces.robot @@ -318,3 +318,68 @@ | | ${vat_data}= | InterfaceCLI.VPP get interface data | ${node} | ${interface} | | Should be equal | ${vat_data['mtu']} | ${mtu} | | Should be equal | ${vat_data['sub_inner_vlan_id']} | ${vrf-id} + +| Honeycomb sets interface VxLAN configuration +| | [Documentation] | Uses Honeycomb API to change VxLAN configuration \ +| | ... | of the specified interface. +| | ... +| | ... | *Arguments:* +| | ... | - node - information about a DUT node. Type: dictionary +| | ... | - interface - name of an interface on the specified node. Type: string +| | ... | - vxlan_settings - Configuration data for VxLAN. Type: dictionary +| | ... +| | ... | *Example:* +| | ... | \| Honeycomb sets interface VxLAN configuration \ +| | ... | \|${node} \| ${interface} \| &{vxlan_settings} \| +| | ... +| | [Arguments] | ${node} | ${interface} | &{vxlan_settings} +| | :FOR | ${items} | IN | @{vxlan_settings.items()} +| | | interfaceAPI.Configure interface vxlan | ${node} | ${interface} | @{items} + +| VxLAN configuration from Honeycomb should be +| | [Documentation] | Retrieves interface VxLAN configuration through Honeycomb\ +| | ... | and compares with state supplied in argument. +| | ... +| | ... | *Arguments:* +| | ... | - node - information about a DUT node. Type: dictionary +| | ... | - interface - name of an interface on the specified node. Type: string +| | ... | - vxlan_settings - Configuration data for VxLAN. Type: dictionary +| | ... +| | ... | *Example:* +| | ... +| | ... | \| VxLAN configuration from Honeycomb should be \ +| | ... | \| ${node} \| ${interface} \| &{vxlan_settings} \| +| | ... +| | [Arguments] | ${node} | ${interface} | &{vxlan_settings} +| | ${api_data}= | interfaceAPI.Get interface cfg data | ${node} | ${interface} +| | :FOR | ${items} | IN | @{vxlan_settings.items()} +| | | Should be equal as strings +| | ... | ${api_data['v3po:vxlan']['@{items}[0]']} | ${items[1]} +| | ${api_data}= | interfaceAPI.Get interface oper data | ${node} | ${interface} +| | :FOR | ${items} | IN | @{vxlan_settings.items()} +| | | Should be equal as strings +| | ... | ${api_data['v3po:vxlan']['@{items}[0]']} | ${items[1]} + +| VxLAN configuration from VAT should be +| | [Documentation] | Retrieves interface VxLAN configuration through VAT and\ +| | ... | compares with state supplied in argument. +| | ... +| | ... | *Arguments:* +| | ... | - node - information about a DUT node. Type: dictionary +| | ... | - interface - name of an interface on the specified node. Type: string +| | ... | - vxlan_settings - Configuration data for VxLAN. Type: dictionary +| | ... +| | ... | *Example:* +| | ... +| | ... | \| VxLAN configuration from Honeycomb should be \ +| | ... | \| ${node} \| ${interface} \| &{vxlan_settings} \| +| | ... +| | [Arguments] | ${node} | ${interface} | &{vxlan_settings} +| | ${vat_data}= | VxLAN Dump | ${node} | ${interface} +| | Should be equal as strings +| | ... | ${vat_data['dst_address']} | ${vxlan_settings['dst']} +| | Should be equal as strings +| | ... | ${vat_data['src_address']} | ${vxlan_settings['src']} +| | Should be equal as strings | ${vat_data['vni']} | ${vxlan_settings['vni']} +| | Should be equal as strings +| | ... | ${vat_data['encap-vrf-id']} | ${vxlan_settings['encap_vrf_id']} diff --git a/resources/templates/vat/vxlan_dump.vat b/resources/templates/vat/vxlan_dump.vat new file mode 100644 index 0000000000..0be6d9ff69 --- /dev/null +++ b/resources/templates/vat/vxlan_dump.vat @@ -0,0 +1 @@ +vxlan_tunnel_dump sw_if_index {sw_if_index}
\ No newline at end of file |