aboutsummaryrefslogtreecommitdiffstats
path: root/resources/libraries
diff options
context:
space:
mode:
Diffstat (limited to 'resources/libraries')
-rw-r--r--resources/libraries/python/LispSetup.py103
-rw-r--r--resources/libraries/robot/lisp/lisp_api.robot (renamed from resources/libraries/robot/lisp.robot)9
-rw-r--r--resources/libraries/robot/lisp/lisp_static_mapping.robot88
3 files changed, 194 insertions, 6 deletions
diff --git a/resources/libraries/python/LispSetup.py b/resources/libraries/python/LispSetup.py
index e0c86aae51..88fcfacda6 100644
--- a/resources/libraries/python/LispSetup.py
+++ b/resources/libraries/python/LispSetup.py
@@ -17,6 +17,94 @@ from resources.libraries.python.topology import NodeType
from resources.libraries.python.VatExecutor import VatExecutor
+class Lisp(object):
+ """Class for lisp API."""
+
+ def __init__(self):
+ pass
+
+ @staticmethod
+ def vpp_lisp_enable_disable(node, state):
+ """Enable/Disable lisp in the VPP node in topology.
+
+ :param node: Node of the test topology.
+ :param state: State of the lisp, enable or disable.
+ :type node: dict
+ :type state: str
+ """
+
+ VatExecutor.cmd_from_template(node,
+ 'lisp/lisp.vat',
+ state=state)
+
+
+class LispRemoteMapping(object):
+ """Class for lisp remote mapping API."""
+
+ def __init__(self):
+ pass
+
+ @staticmethod
+ def vpp_add_lisp_remote_mapping(node, vni, deid, deid_prefix, seid,
+ seid_prefix, rloc):
+ """Add lisp remote mapping on the VPP node in topology.
+
+ :param node: VPP node.
+ :param vni: Vni.
+ :param deid: Destination eid address.
+ :param deid_predix: Destination eid address prefix_len.
+ :param seid: Source eid address.
+ :param seid_prefix: Source eid address prefix_len.
+ :param rloc: Receiver locator.
+ :type node: dict
+ :type vni: int
+ :type deid: str
+ :type deid_prefix: int
+ :type seid: str
+ :type seid_prefix: int
+ :type rloc: str
+ """
+
+ VatExecutor.cmd_from_template(node,
+ 'lisp/add_lisp_remote_mapping.vat',
+ vni=vni,
+ deid=deid,
+ deid_prefix=deid_prefix,
+ seid=seid,
+ seid_prefix=seid_prefix,
+ rloc=rloc)
+
+ @staticmethod
+ def vpp_del_lisp_remote_mapping(node, vni, deid, deid_prefix, seid,
+ seid_prefix, rloc):
+ """Delete lisp remote mapping on the VPP node in topology.
+
+ :param node: VPP node.
+ :param vni: Vni.
+ :param deid: Destination eid address.
+ :param deid_predix: Destination eid address prefix_len.
+ :param seid: Source eid address.
+ :param seid_prefix: Source eid address prefix_len.
+ :param rloc: Receiver locator.
+ :type node: dict
+ :type vni: int
+ :type deid: str
+ :type deid_prefix: int
+ :type seid: str
+ :type seid_prefix: int
+ :type rloc: str
+ """
+
+ VatExecutor.cmd_from_template(node,
+ 'lisp/del_lisp_remote_mapping.vat',
+ vni=vni,
+ deid=deid,
+ deid_predix=deid_prefix,
+ seid=seid,
+ seid_prefix=seid_prefix,
+ rloc=rloc)
+
+
class LispGpeIface(object):
"""Class for Lisp gpe interface API."""
@@ -28,7 +116,7 @@ class LispGpeIface(object):
"""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
+ :param state: State of the gpe iface, up or down.
:type node: dict
:type state: str
"""
@@ -406,3 +494,16 @@ class LispSetup(object):
lgi = LispGpeIface()
lgi.vpp_lisp_gpe_iface(node, state)
+
+ @staticmethod
+ def vpp_lisp_state(node, state):
+ """Enable/Disable lisp on VPP node in topology.
+
+ :param node: VPP node.
+ :param state: State of the lisp, enable or disable
+ :type node: dict
+ :type state: str
+ """
+
+ lgi = Lisp()
+ lgi.vpp_lisp_enable_disable(node, state)
diff --git a/resources/libraries/robot/lisp.robot b/resources/libraries/robot/lisp/lisp_api.robot
index a5b69fc547..43471a9d86 100644
--- a/resources/libraries/robot/lisp.robot
+++ b/resources/libraries/robot/lisp/lisp_api.robot
@@ -12,11 +12,10 @@
# 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
+| Resource | resources/libraries/robot/interfaces.robot
+| Library | resources.libraries.python.NodePath
+| Library | resources.libraries.python.LispSetup.LispSetup
+| Library | resources.libraries.python.LispUtil
*** Keywords ***
diff --git a/resources/libraries/robot/lisp/lisp_static_mapping.robot b/resources/libraries/robot/lisp/lisp_static_mapping.robot
new file mode 100644
index 0000000000..8d6bf311d0
--- /dev/null
+++ b/resources/libraries/robot/lisp/lisp_static_mapping.robot
@@ -0,0 +1,88 @@
+# 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 ***
+| Documentation | Lisp State mapping suite keywords
+| Resource | resources/libraries/robot/interfaces.robot
+| Library | resources.libraries.python.NodePath
+| Library | resources.libraries.python.LispSetup.LispLocatorSet
+| Library | resources.libraries.python.LispSetup.LispLocator
+| Library | resources.libraries.python.LispSetup.LispLocalEid
+| Library | resources.libraries.python.LispSetup.LispRemoteMapping
+| Library | resources.libraries.python.LispSetup.LispSetup
+| Library | resources.libraries.python.LispUtil
+
+*** Keywords ***
+| Set up Lisp topology
+| | [Documentation] | Set up Lisp static remote mapping topology.
+| | ...
+| | ... | *Arguments:*
+| | ... | - ${dut1_node} - DUT1 node. Type: dictionary
+| | ... | - ${dut1_int_name} - DUT1 node interface name. Type: string
+| | ... | - ${dut1_int_index} - DUT1 node interface index. Type: integer
+| | ... | - ${dut2_node} - DUT2 node. Type: dictionary
+| | ... | - ${dut2_int_name} - DUT2 node interface name. Type: string
+| | ... | - ${dut2_int_index} - DUT2 node interface index. Type: integer
+| | ... | - ${locator_set} - Locator set values. Type: dict
+| | ... | - ${dut1_eid} - Dut1 node eid address. Type: dict
+| | ... | - ${dut2_eid} - Dut2 node eid address. Type: dict
+| | ... | - ${dut1_static_mapping} - Dut1 static mapping address. Type: dict
+| | ... | - ${dut2_static_mapping} - Dut2 static mapping address. Type: dict
+| | ...
+| | ... | *Return:*
+| | ... | - No value returned
+| | ...
+| | ... | *Example:*
+| | ... | \| Set up Lisp topology \| ${dut1_node} \| ${interface_name} \
+| | ... | \| None \| ${dut2_node} \| ${interface_name} \| None \
+| | ... | \| ${locator_set} \| ${dut1_eid} \| ${dut2_eid} \
+| | ... | \| ${dut1_static_mapping} \| ${dut2_static_mapping} \|
+| | ...
+| | [Arguments] | ${dut1_node} | ${dut1_int_name} | ${dut1_int_index}
+| | ... | ${dut2_node} | ${dut2_int_name} | ${dut2_int_index}
+| | ... | ${locator_set} | ${dut1_eid} | ${dut2_eid}
+| | ... | ${dut1_static_mapping} | ${dut2_static_mapping}
+| | ${dut1_int_index}= | Run Keyword If | ${dut1_int_index} is None
+| | | ... | Get Interface Sw Index | ${dut1_node}
+| | | ... | ${dut1_int_name}
+| | | ... | ELSE | Set Variable | ${dut1_int_index}
+| | ${dut2_int_index}= | Run Keyword If | ${dut2_int_index} is None
+| | | ... | Get Interface Sw Index | ${dut2_node}
+| | | ... | ${dut2_int_name}
+| | | ... | ELSE | Set Variable | ${dut2_int_index}
+| | Vpp lisp state | ${dut1_node} | enable
+| | Vpp Add Lisp Locator Set | ${dut1_node} | ${locator_set['locator_name']}
+| | Vpp Add Lisp Locator | ${dut1_node} | ${locator_set['locator_name']}
+| | ... | ${dut1_int_index} | ${locator_set['priority']}
+| | ... | ${locator_set['weight']}
+| | Vpp Add Lisp Local Eid | ${dut1_node} | ${dut1_eid['locator_name']} | ${dut1_eid['eid']}
+| | ... | ${dut1_eid['prefix']}
+| | Vpp Add Lisp Remote Mapping | ${dut1_node} | ${dut1_static_mapping['vni']}
+| | ... | ${dut1_static_mapping['deid']}
+| | ... | ${dut1_static_mapping['prefix']}
+| | ... | ${dut1_static_mapping['seid']}
+| | ... | ${dut1_static_mapping['prefix']}
+| | ... | ${dut1_static_mapping['rloc']}
+| | Vpp Lisp State | ${dut2_node} | enable
+| | Vpp Add Lisp Locator Set | ${dut2_node} | ${locator_set['locator_name']}
+| | Vpp Add Lisp Locator | ${dut2_node} | ${locator_set['locator_name']}
+| | ... | ${dut2_int_index} | ${locator_set['priority']}
+| | ... | ${locator_set['weight']}
+| | Vpp Add Lisp Local Eid | ${dut2_node} | ${dut2_eid['locator_name']} | ${dut2_eid['eid']}
+| | ... | ${dut2_eid['prefix']}
+| | Vpp Add Lisp Remote Mapping | ${dut2_node} | ${dut2_static_mapping['vni']}
+| | ... | ${dut2_static_mapping['deid']}
+| | ... | ${dut2_static_mapping['prefix']}
+| | ... | ${dut2_static_mapping['seid']}
+| | ... | ${dut2_static_mapping['prefix']}
+| | ... | ${dut2_static_mapping['rloc']} \ No newline at end of file