diff options
Diffstat (limited to 'resources/libraries')
-rw-r--r-- | resources/libraries/python/LispSetup.py | 103 | ||||
-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.robot | 88 |
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 |