aboutsummaryrefslogtreecommitdiffstats
path: root/resources/libraries
diff options
context:
space:
mode:
Diffstat (limited to 'resources/libraries')
-rw-r--r--resources/libraries/python/LispSetup.py408
-rw-r--r--resources/libraries/python/LispUtil.py257
-rw-r--r--resources/libraries/robot/lisp.robot349
3 files changed, 1014 insertions, 0 deletions
diff --git a/resources/libraries/python/LispSetup.py b/resources/libraries/python/LispSetup.py
new file mode 100644
index 0000000000..e0c86aae51
--- /dev/null
+++ b/resources/libraries/python/LispSetup.py
@@ -0,0 +1,408 @@
+# Copyright (c) 2016 Cisco and/or its affiliates.
+# Licensed under the Apache License, Version 2.0 (the "License");
+# you may not use this file except in compliance with the License.
+# You may obtain a copy of the License at:
+#
+# http://www.apache.org/licenses/LICENSE-2.0
+#
+# Unless required by applicable law or agreed to in writing, software
+# distributed under the License is distributed on an "AS IS" BASIS,
+# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+# See the License for the specific language governing permissions and
+# limitations under the License.
+
+"""Library to set up Lisp in topology."""
+
+from resources.libraries.python.topology import NodeType
+from resources.libraries.python.VatExecutor import VatExecutor
+
+
+class LispGpeIface(object):
+ """Class for Lisp gpe interface API."""
+
+ def __init__(self):
+ pass
+
+ @staticmethod
+ def vpp_lisp_gpe_iface(node, state):
+ """Set lisp gpe interface up or down on the VPP node in topology.
+
+ :param node: VPP node.
+ :param state: State of the gpe iface, up or down
+ :type node: dict
+ :type state: str
+ """
+
+ VatExecutor.cmd_from_template(node,
+ 'lisp/lisp_gpe_iface.vat',
+ state=state)
+
+
+class LispMapResolver(object):
+ """Class for Lisp map resolver API."""
+
+ def __init__(self):
+ pass
+
+ @staticmethod
+ def vpp_add_map_resolver(node, map_resolver_ip):
+ """Set lisp map resolver on the VPP node in topology.
+
+ :param node: VPP node.
+ :param map_resolver_ip: IP address of the map resolver.
+ :type node: dict
+ :type map_resolver_ip: str
+ """
+
+ VatExecutor.cmd_from_template(node,
+ 'lisp/add_lisp_map_resolver.vat',
+ address=map_resolver_ip)
+
+ @staticmethod
+ def vpp_del_map_resolver(node, map_resolver_ip):
+ """Unset lisp map resolver on the VPP node in topology.
+
+ :param node: VPP node.
+ :param map_resolver_ip: IP address of the map resolver.
+ :type node: dict
+ :type map_resolver_ip: str
+ """
+
+ VatExecutor.cmd_from_template(node,
+ 'lisp/del_lisp_map_resolver.vat',
+ address=map_resolver_ip)
+
+
+class LispLocalEid(object):
+ """Class for Lisp local eid API."""
+
+ def __init__(self):
+ pass
+
+ @staticmethod
+ def vpp_add_lisp_local_eid(node, locator_set_name, address, prefix_len):
+ """Set lisp eid addres on the VPP node in topology.
+
+ :param node: VPP node.
+ :param locator_set_name: Name of the locator_set.
+ :param address: Eid IP address.
+ :param prefix_len: prefix len of the eid IP address.
+ :type node: dict
+ :type locator_set_name: str
+ :type address: str
+ :type prefix_len: int
+ """
+
+ VatExecutor.cmd_from_template(node,
+ 'lisp/add_lisp_local_eid.vat',
+ eid_address=address,
+ eid_prefix=prefix_len,
+ locator_name=locator_set_name)
+
+ @staticmethod
+ def vpp_del_lisp_local_eid(node, locator_set_name, address, prefix_len):
+ """Set lisp eid addres on the VPP node in topology.
+
+ :param node: VPP node.
+ :param locator_set_name: Name of the locator_set.
+ :param address: Eid IP address.
+ :param prefix_len: prefix len of the eid IP address.
+ :type node: dict
+ :type locator_set_name: str
+ :type address: str
+ :type prefix_len: int
+ """
+
+ VatExecutor.cmd_from_template(node,
+ 'lisp/del_lisp_local_eid.vat',
+ eid_address=address,
+ eid_prefix=prefix_len,
+ locator_name=locator_set_name)
+
+
+class LispLocator(object):
+ """Class for the Lisp Locator API."""
+
+ def __init__(self):
+ pass
+
+ @staticmethod
+ def vpp_add_lisp_locator(node, locator_name, sw_if_index, priority, weight):
+ """Set lisp locator on the VPP node in topology.
+
+ :param node: VPP node.
+ :param locator_name: Name of the locator_set.
+ :param sw_if_index: sw_if_index if the interface.
+ :param priority: priority of the locator.
+ :param weight: weight of the locator.
+ :type node: dict
+ :type locator_name: str
+ :type sw_if_index: int
+ :type priority: int
+ :type weight: int
+ """
+
+ VatExecutor.cmd_from_template(node,
+ 'lisp/add_lisp_locator.vat',
+ lisp_name=locator_name,
+ sw_if_index=sw_if_index,
+ priority=priority,
+ weight=weight)
+
+ @staticmethod
+ def vpp_del_lisp_locator(node, locator_name, sw_if_index, priority, weight):
+ """Unset lisp locator on the VPP node in topology.
+
+ :param node: VPP node.
+ :param locator_name: Name of the locator_set.
+ :param sw_if_index: sw_if_index if the interface.
+ :param priority: priority of the locator.
+ :param weight: weight of the locator.
+ :type node: dict
+ :type locator_name: str
+ :type sw_if_index: int
+ :type priority: int
+ :type weight: int
+ """
+
+ VatExecutor.cmd_from_template(node,
+ 'lisp/del_lisp_locator.vat',
+ lisp_name=locator_name,
+ sw_if_index=sw_if_index,
+ priority=priority,
+ weight=weight)
+
+
+class LispLocatorSet(object):
+ """Class for Lisp Locator Set API."""
+
+ def __init__(self):
+ pass
+
+ @staticmethod
+ def vpp_add_lisp_locator_set(node, name):
+ """Add lisp locator_set on VPP.
+
+ :param node: VPP node.
+ :param name: VPP locator name.
+ :type node: dict
+ :type name: str
+ """
+
+ VatExecutor.cmd_from_template(node,
+ 'lisp/add_lisp_locator_set.vat',
+ lisp_name=name)
+
+ @staticmethod
+ def vpp_del_lisp_locator_set(node, name):
+ """Del lisp locator_set on VPP.
+
+ :param node: VPP node.
+ :param name: VPP locator name.
+ :type node: dict
+ :type name: str
+ """
+
+ VatExecutor.cmd_from_template(node,
+ 'lisp/del_lisp_locator_set.vat',
+ lisp_name=name)
+
+
+class LispSetup(object):
+ """Lisp setup in topology."""
+
+ def __init__(self):
+ pass
+
+ @staticmethod
+ def vpp_set_lisp_locator_set(node, locator_sets):
+ """Set lisp locator_sets on VPP node in topology.
+
+ There are two ways how set lisp locator_set.
+ One locator_set can contain multiple locators.
+ Add new locator_set with same name as it already save in vpp
+ will reset locator_set and his locator.
+ To not reset locator_set, use "normal" type of generate data,
+ where the locator_set is set just once.
+ To test reset locator_set use "reset" type of generate data,
+ where the locator_set will be set multiple times.
+
+ :param node: VPP node.
+ :param locator_sets: Dictionary containing information of locator_set.
+ :type node: dict
+ :type locator_sets: dict
+ """
+
+ if node['type'] != NodeType.DUT:
+ raise ValueError('Lisp locator set, node is not DUT')
+
+ lisp_locator_set = LispLocatorSet()
+ lisp_locator = LispLocator()
+ for locator_set_type, item in locator_sets.iteritems():
+ if locator_set_type == 'normal':
+ lsm_set = 1
+ elif locator_set_type == 'reset':
+ lsm_set = 0
+ else:
+ raise ValueError('Unknown locator_set_type value: '
+ '{}'.format(locator_set_type))
+
+ locator_set_list = []
+ for locator_set in item:
+ locator_name = locator_set.get('locator-set')
+ sw_if_index = locator_set.get('locator')
+ priority = locator_set.get('priority')
+ weight = locator_set.get('weight')
+ if lsm_set == 1:
+ if locator_name not in locator_set_list:
+ locator_set_list.append(locator_name)
+ lisp_locator_set.vpp_add_lisp_locator_set(node,
+ locator_name)
+ else:
+ lisp_locator_set.vpp_add_lisp_locator_set(node,
+ locator_name)
+ lisp_locator.vpp_add_lisp_locator(node,
+ locator_name,
+ sw_if_index,
+ priority,
+ weight)
+
+ @staticmethod
+ def vpp_unset_lisp_locator_set(node, locator_sets):
+ """Unset lisp locator_sets on VPP node in topology.
+
+ :param node: VPP node.
+ :param locator_sets: Dictionary containing information of locator_set.
+ :type node: dict
+ :type locator_sets: dict
+ """
+
+ if node['type'] != NodeType.DUT:
+ raise ValueError('Lisp locator set, node is not DUT')
+
+ lisp_locator = LispLocator()
+ lisp_locator_set = LispLocatorSet()
+ for locator_set_type, item in locator_sets.iteritems():
+ if locator_set_type == 'normal':
+ lsm_set = 1
+ elif locator_set_type == 'reset':
+ lsm_set = 0
+ else:
+ raise ValueError('Unknown locator_set_type value: '
+ '{}'.format(locator_set_type))
+
+ locator_set_list = []
+ for locator_set in item:
+ locator_set_name = locator_set.get('locator-set')
+ sw_if_index = locator_set.get('locator')
+ priority = locator_set.get('priority')
+ weight = locator_set.get('weight')
+ if lsm_set == 1:
+ if locator_set_name not in locator_set_list:
+ locator_set_list.append(locator_set_name)
+ else:
+ lisp_locator.vpp_del_lisp_locator(node,
+ locator_set_name,
+ sw_if_index,
+ priority,
+ weight)
+
+ for locator_set_name in locator_set_list:
+ lisp_locator_set.vpp_del_lisp_locator_set(node, locator_set_name)
+
+ @staticmethod
+ def vpp_set_lisp_eid_table(node, eid_table):
+ """Set lisp eid tables on VPP node in topology.
+
+ :param node: VPP node.
+ :param eid_table: Dictionary containing information of eid_table.
+ :type node: dict
+ :type eid_table: dict
+ """
+
+ if node['type'] != NodeType.DUT:
+ raise ValueError('Lisp locator set, node is not DUT')
+
+ lisp_locator_set = LispLocatorSet()
+ lisp_eid = LispLocalEid()
+ for eid in eid_table:
+ eid_address = eid.get('eid address')
+ eid_prefix_len = eid.get('eid prefix len')
+ locator_set_name = eid.get('locator-set')
+ lisp_locator_set.vpp_add_lisp_locator_set(node, locator_set_name)
+ lisp_eid.vpp_add_lisp_local_eid(node,
+ locator_set_name,
+ eid_address,
+ eid_prefix_len)
+
+ @staticmethod
+ def vpp_unset_lisp_eid_table(node, eid_table):
+ """Unset lisp eid tables on VPP node in topology.
+
+ :param node: VPP node.
+ :param eid_table: Dictionary containing information of eid_table.
+ :type node: dict
+ :type eid_table: dict
+ """
+
+ if node['type'] != NodeType.DUT:
+ raise ValueError('Lisp locator set, node is not DUT')
+
+ locator_set_list = []
+ lisp_locator_set = LispLocatorSet()
+ lisp_eid = LispLocalEid()
+ for eid in eid_table:
+ eid_address = eid.get('eid address')
+ eid_prefix_len = eid.get('eid prefix len')
+ locator_set_name = eid.get('locator-set')
+ if locator_set_name not in locator_set_list:
+ locator_set_list.append(locator_set_name)
+
+ lisp_eid.vpp_del_lisp_local_eid(node,
+ locator_set_name,
+ eid_address,
+ eid_prefix_len)
+
+ for locator_set_name in locator_set_list:
+ lisp_locator_set.vpp_del_lisp_locator_set(node, locator_set_name)
+
+ @staticmethod
+ def vpp_set_lisp_map_resolver(node, map_resolver):
+ """Set lisp map resolvers on VPP node in topology.
+
+ :param node: VPP node.
+ :param map_resolver: Dictionary containing information of map resolver.
+ :type node: dict
+ :type map_resolver: dict
+ """
+
+ lisp_map_res = LispMapResolver()
+ for map_ip in map_resolver:
+ lisp_map_res.vpp_add_map_resolver(node, map_ip.get('map resolver'))
+
+ @staticmethod
+ def vpp_unset_lisp_map_resolver(node, map_resolver):
+ """Unset lisp map resolvers on VPP node in topology.
+
+ :param node: VPP node.
+ :param map_resolver: Dictionary containing information of map resolver.
+ :type node: dict
+ :type map_resolver: dict
+ """
+
+ lisp_map_res = LispMapResolver()
+ for map_ip in map_resolver:
+ lisp_map_res.vpp_del_map_resolver(node, map_ip.get('map resolver'))
+
+ @staticmethod
+ def vpp_lisp_gpe_interface_status(node, state):
+ """Set lisp gpe interface status on VPP node in topology.
+
+ :param node: VPP node.
+ :param state: State of the gpe iface, up or down
+ :type node: dict
+ :type state: str
+ """
+
+ lgi = LispGpeIface()
+ lgi.vpp_lisp_gpe_iface(node, state)
diff --git a/resources/libraries/python/LispUtil.py b/resources/libraries/python/LispUtil.py
new file mode 100644
index 0000000000..17a46cd49c
--- /dev/null
+++ b/resources/libraries/python/LispUtil.py
@@ -0,0 +1,257 @@
+# Copyright (c) 2016 Cisco and/or its affiliates.
+# Licensed under the Apache License, Version 2.0 (the "License");
+# you may not use this file except in compliance with the License.
+# You may obtain a copy of the License at:
+#
+# http://www.apache.org/licenses/LICENSE-2.0
+#
+# Unless required by applicable law or agreed to in writing, software
+# distributed under the License is distributed on an "AS IS" BASIS,
+# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+# See the License for the specific language governing permissions and
+# limitations under the License.
+
+"""Lisp utilities library."""
+
+from resources.libraries.python.parsers.JsonParser import JsonParser
+from resources.libraries.python.topology import Topology
+from resources.libraries.python.VatExecutor import VatExecutor
+
+
+class LispUtil(object):
+ """Implements keywords for Lisp tests."""
+
+ def __init__(self):
+ pass
+
+ @staticmethod
+ def vpp_show_lisp_locator_set(node):
+ """Get lisp locator_set from VPP node.
+
+ :param node: VPP node.
+ :type node: dict
+ :return: Lisp locator_set data as python list.
+ :rtype: list
+ """
+
+ vat = VatExecutor()
+ vat.execute_script_json_out('lisp/show_lisp_locator_set.vat', node)
+ return JsonParser().parse_data(vat.get_script_stdout())
+
+ @staticmethod
+ def vpp_show_lisp_local_eid_table(node):
+ """Get lisp local eid table from VPP node.
+
+ :param node: VPP node.
+ :type node: dict
+ :return: Lisp eid table as python list.
+ :rtype: list
+ """
+
+ vat = VatExecutor()
+ vat.execute_script_json_out('lisp/show_lisp_local_eid_table.vat', node)
+ return JsonParser().parse_data(vat.get_script_stdout())
+
+ @staticmethod
+ def vpp_show_lisp_map_resolver(node):
+ """Get lisp map resolver from VPP node.
+
+ :param node: VPP node.
+ :type node: dict
+ :return: Lisp map resolver as python list.
+ :rtype: list
+ """
+
+ vat = VatExecutor()
+ vat.execute_script_json_out('lisp/show_lisp_map_resolver.vat', node)
+ return JsonParser().parse_data(vat.get_script_stdout())
+
+ @staticmethod
+ def lisp_should_be_equal(lisp_val1, lisp_val2):
+ """Fail if the lisp values are not equal.
+
+ :param lisp_val1: First lisp value.
+ :param lisp_val2: Second lisp value.
+ :type lisp_val1: list
+ :type lisp_val2: list
+ """
+
+ len1 = len(lisp_val1)
+ len2 = len(lisp_val2)
+ if len1 != len2:
+ raise RuntimeError('Values are not same. '
+ 'Value 1 {} \n'
+ 'Value 2 {}.'.format(lisp_val1,
+ lisp_val2))
+
+ for tmp in lisp_val1:
+ if tmp not in lisp_val2:
+ raise RuntimeError('Value {} is not find in vpp:\n'
+ '{}'.format(tmp, lisp_val2))
+
+ def lisp_locator_s_should_be_equal(self, locator_set1, locator_set2):
+ """Fail if the lisp values are not equal.
+
+ :param locator_set1: Generate lisp value.
+ :param locator_set2: Lisp value from VPP.
+ :type locator_set1: dict
+ :type locator_set2: list
+ """
+
+ reset_list = []
+ locator_set_list = []
+ for locator_set_type, item in locator_set1.iteritems():
+ if locator_set_type == 'normal':
+ self.lisp_should_be_equal(item, locator_set2)
+ elif locator_set_type == 'reset':
+ for locator_list in reversed(item):
+ name = locator_list.get('locator-set')
+ if name not in locator_set_list:
+ reset_list.insert(0, locator_list)
+ locator_set_list.append(name)
+ self.lisp_should_be_equal(reset_list, locator_set2)
+ else:
+ raise ValueError('Unknown locator_set_type value: '
+ '{}'.format(locator_set_type))
+
+ @staticmethod
+ def generate_lisp_locator_set_data(node, locator_set_number):
+ """Generate a list of lisp locator_set we want set to VPP and
+ then check if is set correct.
+
+ "normal" type of data set locator_set just once.
+
+ :param node: VPP node.
+ :param locator_set_number: Generate n locator_set.
+ :type node: dict
+ :type locator_set_number: str
+ :return: dict of lisp locator_set.
+ :rtype: dict
+ """
+
+ topo = Topology()
+
+ locator_set_list = []
+ i = 0
+ for num in range(0, int(locator_set_number)):
+ for interface in node['interfaces'].values():
+ link = interface.get('link')
+ i += 1
+ if link is None:
+ continue
+
+ if_name = topo.get_interface_by_link_name(node, link)
+ sw_if_index = topo.get_interface_sw_index(node, if_name)
+ if if_name is not None:
+ l_name = 'ls{0}'.format(num)
+ locator_set = {'locator-set': l_name,
+ 'locator': sw_if_index,
+ 'priority': i,
+ 'weight': i}
+ locator_set_list.append(locator_set)
+
+ loc_type = {'normal': locator_set_list}
+ return loc_type
+
+ @staticmethod
+ def generate_lisp_locator_set_reset_data(node, locator_set_number):
+ """Generate a list of lisp locator_set we want set to VPP and
+ then check if is set correct.
+
+ "reset" type of data set locator_set multiple times,
+ use to test reset locator_set in vpp.
+
+ :param node: VPP node.
+ :param locator_set_number: Generate n locator_set.
+ :type node: dict
+ :type locator_set_number: str
+ :return: dict of lisp locator_set.
+ :rtype: dict
+ """
+
+ topo = Topology()
+
+ locator_set_list = []
+ for num in range(0, int(locator_set_number)):
+ for interface in node['interfaces'].values():
+ link = interface.get('link')
+ if link is None:
+ continue
+
+ if_name = topo.get_interface_by_link_name(node, link)
+ sw_if_index = topo.get_interface_sw_index(node, if_name)
+ if if_name is not None:
+ l_name = 'ls{0}'.format(num)
+ locator_set = {'locator-set': l_name,
+ 'locator': sw_if_index,
+ 'priority': 1,
+ 'weight': 1}
+ locator_set_list.append(locator_set)
+
+ loc_type = {'reset': locator_set_list}
+ return loc_type
+
+ @staticmethod
+ def generate_lisp_local_eid_data(ipv4_num, ipv6_num):
+ """Generate a list of lisp local eid we want set to VPP and
+ then check if is set correct.
+
+ :param ipv4_num: Generate n ipv4 eid address.
+ :param ipv6_num: Generate n ipv6 eid address.
+ :type ipv4_num: str
+ :type ipv6_num: str
+ :return: list of lisp local eid.
+ :rtype: list
+ """
+
+ eid_table = []
+ for num in range(0, int(ipv4_num)):
+ addrr = '192.168.{}.1'.format(num)
+ eid = {'eid address': addrr,
+ 'eid prefix len': 24,
+ 'locator-set': 'ls1'}
+ eid_table.append(eid)
+
+ for num in range(0, int(ipv6_num)):
+ addrr = '10:{}::1'.format(num + 1)
+ eid = {'eid address': addrr,
+ 'eid prefix len': 32,
+ 'locator-set': 'ls1'}
+ eid_table.append(eid)
+
+ return eid_table
+
+ @staticmethod
+ def generate_lisp_map_resolver_data(ipv4_num, ipv6_num):
+ """Generate a list of lisp map resolvers we want set to VPP and
+ then check if is set correct.
+
+ :param ipv4_num: Generate n ipv4 map resolver address.
+ :param ipv6_num: Generate n ipv6 map resolver address.
+ :type ipv4_num: str
+ :type ipv6_num: str
+ :return: list of lisp map resolver.
+ :rtype: list
+ """
+
+ map_resolver = []
+ for i in range(0, int(ipv4_num)):
+ addr = '192.169.{}.1'.format(i)
+ resolver = {'map resolver': addr}
+ map_resolver.append(resolver)
+
+ for i in range(0, int(ipv6_num)):
+ addr = '12:{}::1'.format(i + 1)
+ resolver = {'map resolver': addr}
+ map_resolver.append(resolver)
+
+ return map_resolver
+
+ def lisp_is_empty(self, lisp_params):
+ """Check if the input param are empty.
+
+ :param lisp_params: Should be empty list.
+ :type lisp_params: list
+ """
+
+ self.lisp_should_be_equal([], lisp_params)
diff --git a/resources/libraries/robot/lisp.robot b/resources/libraries/robot/lisp.robot
new file mode 100644
index 0000000000..a5b69fc547
--- /dev/null
+++ b/resources/libraries/robot/lisp.robot
@@ -0,0 +1,349 @@
+# Copyright (c) 2016 Cisco and/or its affiliates.
+# Licensed under the Apache License, Version 2.0 (the "License");
+# you may not use this file except in compliance with the License.
+# You may obtain a copy of the License at:
+#
+# http://www.apache.org/licenses/LICENSE-2.0
+#
+# Unless required by applicable law or agreed to in writing, software
+# distributed under the License is distributed on an "AS IS" BASIS,
+# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+# See the License for the specific language governing permissions and
+# limitations under the License.
+
+*** Settings ***
+| Resource | resources/libraries/robot/default.robot
+| Resource | resources/libraries/robot/counters.robot
+| Library | resources.libraries.python.NodePath
+| Library | resources.libraries.python.LispSetup.LispSetup
+| Library | resources.libraries.python.LispUtil
+
+*** Keywords ***
+
+| Lisp locator_set data is prepared
+| | [Documentation] | Generate lisp locator_set data for test
+| | ... | the lisp locator_set and locator API.
+| | ...
+| | ... | *Arguments:*
+| | ... | - ${dut_node} - DUT node. Type: dictionary
+| | ... | - ${locator_set_number} - Number how many locator_set data
+| | ... | will be generated. Type: integer
+| | ...
+| | ... | *Return:*
+| | ... | - No value returned
+| | ...
+| | ... | _NOTE:_ This KW sets following test case variables:
+| | ... | - ${locator_set_values} - New generated locator_set data.
+| | ...
+| | ... | *Example:*
+| | ... | \| Given Lisp locator_set data is prepared \| ${nodes['DUT1']} \
+| | ... | \| ${locator_set_number} \|
+| | ...
+| | [Arguments] | ${dut_node} | ${locator_set_number}
+| | ${locator_set_values}= | Generate Lisp Locator Set Data |
+| | ... | ${dut_node} | ${locator_set_number}
+| | Set Test Variable | ${locator_set_values}
+
+| Lisp locator_set data is set
+| | [Documentation] | Set the lisp locator_set and locator on the VPP node.
+| | ...
+| | ... | *Arguments:*
+| | ... | - ${dut_node} - DUT node. Type: dictionary
+| | ...
+| | ... | *Return:*
+| | ... | - No value returned
+| | ...
+| | ... | _NOTE:_ This KW requires following test case variables:
+| | ... | - ${locator_set_values} - Generated locator_set data from
+| | ... | KW locator_set data is prepared,
+| | ... | which will be set on the VPP node.
+| | ...
+| | ... | *Example:*
+| | ... | \| When Lisp locator_set data is set \| ${nodes['DUT1']} \|
+| | ...
+| | [Arguments] | ${dut_node}
+| | Vpp Set Lisp Locator Set | ${dut_node} | ${locator_set_values}
+
+| Lisp locator_set is set correct
+| | [Documentation] | Test if the locator_set is set correct on the VPP node.
+| | ...
+| | ... | *Arguments:*
+| | ... | - ${dut_node} - DUT node. Type: dictionary
+| | ...
+| | ... | *Return:*
+| | ... | - No value returned
+| | ...
+| | ... | _NOTE:_ This KW requires following test case variables:
+| | ... | - ${locator_set_values} - Generated locator_set data from
+| | ... | KW locator_set data is prepared,
+| | ... | which were set to VPP node.
+| | ...
+| | ... | *Example:*
+| | ... | \| Then Lisp locator_set is set correct \| ${nodes['DUT1']} \|
+| | ...
+| | [Arguments] | ${dut_node}
+| | ${show_locator_set}= | Vpp Show Lisp Locator Set | ${dut_node}
+| | Lisp Locator S Should Be Equal
+| | ... | ${locator_set_values} | ${show_locator_set}
+
+| Delete all lisp locator_set from VPP
+| | [Documentation] | Delete all lisp locator_set on the VPP node.
+| | ...
+| | ... | *Arguments:*
+| | ... | - ${dut_node} - DUT node. Type: dictionary
+| | ...
+| | ... | *Return:*
+| | ... | - No value returned
+| | ...
+| | ... | _NOTE:_ This KW requires following test case variables:
+| | ... | - ${locator_set_values} - Generated locator_set data from
+| | ... | KW locator_set data is prepared,
+| | ... | which was set on the VPP node.
+| | ...
+| | ... | *Example:*
+| | ... | \| When Delete all lisp locator_set from VPP \
+| | ... | \| ${nodes['DUT1']} \|
+| | ...
+| | [Arguments] | ${dut_node}
+| | Vpp Unset Lisp Locator Set | ${dut_node} | ${locator_set_values}
+
+| Lisp locator_set should be unset
+| | [Documentation] | Test if all locator_set are unset from VPP node.
+| | ...
+| | ... | *Arguments:*
+| | ... | - ${dut_node} - DUT node. Type: dictionary
+| | ...
+| | ... | *Return:*
+| | ... | - No value returned
+| | ...
+| | ... | *Example:*
+| | ... | \| Then Lisp locator_set should be unset \| ${nodes['DUT1']} \|
+| | ...
+| | [Arguments] | ${dut_node}
+| | ${show_locator_set}= | Vpp Show Lisp Locator Set | ${dut_node}
+| | Lisp Is Empty | ${show_locator_set}
+
+| Lisp locator_set data use for test reset locator_set are prepared
+| | [Documentation] | Generate lisp special type of locator_set data.
+| | ... | This data will be use for test reset locator_set.
+| | ...
+| | ... | *Arguments:*
+| | ... | - ${dut_node} - DUT node. Type: dictionary
+| | ... | - ${locator_set_number} - Number how many locator_set data
+| | ... | it will generate. Type: int
+| | ...
+| | ... | *Return:*
+| | ... | - No value returned
+| | ...
+| | ... | _NOTE:_ This KW sets following test case variables:
+| | ... | - ${locator_set_values} - New generate locator_set data.
+| | ...
+| | ... | *Example:*
+| | ... | \| Given Lisp locator_set data use for test reset locator_set \
+| | ... | are prepared \| ${nodes['DUT1']} \| ${locator_set_number} \|
+| | ...
+| | [Arguments] | ${dut_node} | ${locator_set_number}
+| | ${locator_set_values}= | Generate Lisp Locator Set Reset Data |
+| | ... | ${dut_node} | ${locator_set_number}
+| | Set Test Variable | ${locator_set_values}
+
+| Lisp eid address is prepared
+| | [Documentation] | Generate lisp eid address for testing lisp eid API.
+| | ...
+| | ... | *Arguments:*
+| | ... | - ${dut_node} - DUT node. Type: dictionary
+| | ... | - ${eid_ipv4_num} - Number of generate ipv4 address. Type: int
+| | ... | - ${eid_ipv6_num} - Number of generate ipv6 address. Type: int
+| | ...
+| | ... | *Return:*
+| | ... | - No value returned
+| | ...
+| | ... | _NOTE:_ This KW sets following test case variables:
+| | ... | - ${set_eid} - New generate eid data.
+| | ...
+| | ... | *Example:*
+| | ... | \| Given Lisp eid address is prepared \| ${nodes['DUT1']} \
+| | ... | \| ${eid_ipv4_num} \| ${eid_ipv6_num} \|
+| | ...
+| | [Arguments] | ${dut_node} | ${eid_ipv4_num} | ${eid_ipv6_num}
+| | ${set_eid} = | Generate Lisp Local Eid Data
+| | ... | ${eid_ipv4_num} | ${eid_ipv6_num}
+| | Set Test Variable | ${set_eid}
+
+| Lisp eid address is set
+| | [Documentation] | Set the lisp eid address on the VPP node.
+| | ...
+| | ... | *Arguments:*
+| | ... | - ${dut_node} - DUT node. Type: dictionary
+| | ...
+| | ... | *Return:*
+| | ... | - No value returned
+| | ...
+| | ... | _NOTE:_ This KW requires following test case variables:
+| | ... | - ${set_eid} - Generated eid data which will be set to VPP.
+| | ...
+| | ... | *Example:*
+| | ... | \| When Lisp eid address is set \| ${nodes['DUT1']} \|
+| | ...
+| | [Arguments] | ${dut_node}
+| | Vpp Set Lisp Eid Table | ${dut_node} | ${set_eid}
+
+| Lisp eid address is set correct to eid table
+| | [Documentation] | Test if the locator_set is set correct on the VPP node.
+| | ...
+| | ... | *Arguments:*
+| | ... | - ${dut_node} - DUT node. Type: dictionary
+| | ...
+| | ... | *Return:*
+| | ... | - No value returned
+| | ...
+| | ... | _NOTE:_ This KW requires following test case variables:
+| | ... | - ${set_eid} - Generated eid data which will be set to the VPP node.
+| | ...
+| | ... | *Example:*
+| | ... | \| Then Lisp eid address is set correct to eid table \
+| | ... | \| ${nodes['DUT1']} \|
+| | ...
+| | [Arguments] | ${dut_node}
+| | ${show_eid}= | Vpp Show Lisp Local Eid Table | ${dut_node}
+| | Lisp Should Be Equal | ${set_eid} | ${show_eid}
+
+| Delete all lisp eid address from VPP
+| | [Documentation] | Delete all lisp eid address from the VPP node.
+| | ...
+| | ... | *Arguments:*
+| | ... | - ${dut_node} - DUT node. Type: dictionary
+| | ...
+| | ... | *Return:*
+| | ... | - No value returned
+| | ...
+| | ... | _NOTE:_ This KW requires following test case variables:
+| | ... | - ${set_eid} - Generated eid data which was set to the VPP node.
+| | ...
+| | ... | *Example:*
+| | ... | \| When Delete all lisp eid address from VPP \
+| | ... | \| ${nodes['DUT1']} \|
+| | ...
+| | [Arguments] | ${dut_node}
+| | Vpp Unset Lisp Eid Table | ${dut_node} | ${set_eid}
+
+| Lisp eid table should be empty
+| | [Documentation] | Test if the eid table is empty.
+| | ...
+| | ... | *Arguments:*
+| | ... | - ${dut_node} - DUT node. Type: dictionary
+| | ...
+| | ... | *Return:*
+| | ... | - No value returned
+| | ...
+| | ... | *Example:*
+| | ... | \| Then Lisp eid table should be empty \| ${nodes['DUT1']} \|
+| | ...
+| | [Arguments] | ${dut_node}
+| | ${show_eid}= | Vpp Show Lisp Local Eid Table | ${dut_node}
+| | Lisp Is Empty | ${show_eid}
+
+| Lisp map resolver address is prepared
+| | [Documentation] | Generate map resolver address for testing
+| | ... | lisp map resolver API.
+| | ...
+| | ... | *Arguments:*
+| | ... | - ${dut_node} - DUT node. Type: dictionary
+| | ... | - ${map_resolver_ipv4_num} - Number of generate ipv4 address.
+| | ... | Type: int
+| | ... | - ${map_resolver_ipv6_num} - Number of generate ipv6 address.
+| | ... | Type: int
+| | ...
+| | ... | *Return:*
+| | ... | - No value returned
+| | ...
+| | ... | _NOTE:_ This KW sets following test case variables:
+| | ... | - ${set_map_resolver} - Generate map resolver data.
+| | ...
+| | ... | *Example:*
+| | ... | \| Given Lisp map resolver address is prepared \
+| | ... | \| ${nodes['DUT1']} \| ${map_resolver_ipv4_num} \
+| | ... | \| ${map_resolver_ipv6_num} \|
+| | ...
+| | [Arguments] | ${dut_node} | ${map_resolver_ipv4_num} | ${map_resolver_ipv6_num}
+| | ${set_map_resolver} = | Generate Lisp Map Resolver Data
+| | ... | ${map_resolver_ipv4_num} | ${map_resolver_ipv6_num}
+| | Set Test Variable | ${set_map_resolver}
+
+| Lisp map resolver address is set
+| | [Documentation] | Set the lisp map resolver address in the VPP node.
+| | ...
+| | ... | *Arguments:*
+| | ... | - ${dut_node} - DUT node. Type: dictionary
+| | ...
+| | ... | *Return:*
+| | ... | - No value returned
+| | ...
+| | ... | _NOTE:_ This KW requires following test case variables:
+| | ... | - ${set_map_resolver} - Map resolver data which will be set
+| | ... | to the VPP node.
+| | ...
+| | ... | *Example:*
+| | ... | \| When Lisp map resolver address is set \| ${nodes['DUT1']} \|
+| | ...
+| | [Arguments] | ${dut_node}
+| | Vpp Set Lisp Map Resolver | ${dut_node} | ${set_map_resolver}
+
+| Lisp map resolver address is set correct
+| | [Documentation] | Test if the map resolver address is set correct
+| | ... | on the VPP node.
+| | ...
+| | ... | *Arguments:*
+| | ... | - ${dut_node} - DUT node. Type: dictionary
+| | ...
+| | ... | *Return:*
+| | ... | - No value returned
+| | ...
+| | ... | _NOTE:_ This KW requires following test case variables:
+| | ... | - ${set_map_resolver} - Map resolver data which was set
+| | ... | to the VPP node.
+| | ...
+| | ... | *Example:*
+| | ... | \| Then Lisp map resolver address is set correct \
+| | ... | \| ${nodes['DUT1']} \|
+| | ...
+| | [Arguments] | ${dut_node}
+| | ${show_map_resolver}= | Vpp Show Lisp Map Resolver | ${dut_node}
+| | Lisp Should Be Equal | ${set_map_resolver} | ${show_map_resolver}
+
+| Delete all lisp map resolver address from VPP
+| | [Documentation] | Delete all lisp map resolver address on the VPP node.
+| | ...
+| | ... | *Arguments:*
+| | ... | - ${dut_node} - DUT node. Type: dictionary
+| | ...
+| | ... | *Return:*
+| | ... | - No value returned
+| | ...
+| | ... | _NOTE:_ This KW requires following test case variables:
+| | ... | - ${set_map_resolver} - Map resolver data which was set
+| | ... | to the VPP node.
+| | ...
+| | ... | *Example:*
+| | ... | \| When Delete all lisp map resolver address from VPP \
+| | ... | \| ${nodes['DUT1']} \|
+| | ...
+| | [Arguments] | ${dut_node}
+| | Vpp Unset Lisp Map Resolver | ${dut_node} | ${set_map_resolver}
+
+| Lip map resolver address should be empty
+| | [Documentation] | Test if the map resolver are empty.
+| | ...
+| | ... | *Arguments:*
+| | ... | - ${dut_node} - DUT node. Type: dictionary
+| | ...
+| | ... | *Return:*
+| | ... | - No value returned
+| | ...
+| | ... | *Example:*
+| | ... | \| Then Lip map resolver address should be empty \
+| | ... | \| ${nodes['DUT1']} \|
+| | ...
+| | [Arguments] | ${dut_node}
+| | ${show_map_resolver}= | Vpp Show Lisp Map Resolver | ${dut_node}
+| | Lisp Is Empty | ${show_map_resolver}