diff options
author | Artem Glazychev <artem.glazychev@xored.com> | 2021-05-28 19:09:14 +0700 |
---|---|---|
committer | Damjan Marion <dmarion@me.com> | 2021-10-08 11:38:56 +0000 |
commit | ea96292985760b7fc3af54669e3eab35e7561a10 (patch) | |
tree | 05a0317fb9cb7460f86056e16d256e448147eeaa /test/vpp_vxlan_gpe_tunnel.py | |
parent | 3f59c639609be9768f592111e5f8a8a2c23db3ac (diff) |
vxlan-gpe: add udp-port configuration support
similar behavior as here: 839dcc0fb7313638d9b8f52a9db81350dddfe461
Type: improvement
Signed-off-by: Artem Glazychev <artem.glazychev@xored.com>
Change-Id: I1b0a8f8f3dab48839e27df7065cf5f786cf0b5e9
Diffstat (limited to 'test/vpp_vxlan_gpe_tunnel.py')
-rw-r--r-- | test/vpp_vxlan_gpe_tunnel.py | 83 |
1 files changed, 83 insertions, 0 deletions
diff --git a/test/vpp_vxlan_gpe_tunnel.py b/test/vpp_vxlan_gpe_tunnel.py new file mode 100644 index 00000000000..cff5e456aee --- /dev/null +++ b/test/vpp_vxlan_gpe_tunnel.py @@ -0,0 +1,83 @@ +from vpp_interface import VppInterface +from vpp_papi import VppEnum + + +INDEX_INVALID = 0xffffffff +DEFAULT_PORT = 4790 +UNDEFINED_PORT = 0 + + +def find_vxlan_gpe_tunnel(test, src, dst, s_port, d_port, vni): + ts = test.vapi.vxlan_gpe_tunnel_v2_dump(INDEX_INVALID) + + src_port = DEFAULT_PORT + if s_port != UNDEFINED_PORT: + src_port = s_port + + dst_port = DEFAULT_PORT + if d_port != UNDEFINED_PORT: + dst_port = d_port + + for t in ts: + if src == str(t.local) and \ + dst == str(t.remote) and \ + src_port == t.local_port and \ + dst_port == t.remote_port and \ + t.vni == vni: + return t.sw_if_index + return INDEX_INVALID + + +class VppVxlanGpeTunnel(VppInterface): + """ + VPP VXLAN GPE interface + """ + + def __init__(self, test, src_addr, dst_addr, vni, + src_port=UNDEFINED_PORT, dst_port=UNDEFINED_PORT, + mcast_sw_if_index=INDEX_INVALID, + encap_vrf_id=None, + decap_vrf_id=None, protocol=3): + """ Create VXLAN GPE Tunnel interface """ + super(VppVxlanGpeTunnel, self).__init__(test) + self.src = src_addr + self.dst = dst_addr + self.vni = vni + self.src_port = src_port + self.dst_port = dst_port + self.mcast_sw_if_index = mcast_sw_if_index + self.encap_vrf_id = encap_vrf_id + self.decap_vrf_id = decap_vrf_id + self.protocol = 3 + + def add_vpp_config(self): + reply = self.test.vapi.vxlan_gpe_add_del_tunnel_v2( + is_add=1, local=self.src, remote=self.dst, vni=self.vni, + local_port=self.src_port, remote_port=self.dst_port, + mcast_sw_if_index=self.mcast_sw_if_index, + encap_vrf_id=self.encap_vrf_id, + decap_vrf_id=self.decap_vrf_id, + protocol=self.protocol) + self.set_sw_if_index(reply.sw_if_index) + self._test.registry.register(self, self._test.logger) + + def remove_vpp_config(self): + self.test.vapi.vxlan_gpe_add_del_tunnel_v2( + is_add=0, local=self.src, remote=self.dst, vni=self.vni, + local_port=self.src_port, remote_port=self.dst_port, + mcast_sw_if_index=self.mcast_sw_if_index, + encap_vrf_id=self.encap_vrf_id, + decap_vrf_id=self.decap_vrf_id, + protocol=self.protocol) + + def query_vpp_config(self): + return (INDEX_INVALID != find_vxlan_gpe_tunnel(self._test, + self.src, + self.dst, + self.src_port, + self.dst_port, + self.vni)) + + def object_id(self): + return "vxlan-%d-%d-%s-%s" % (self.sw_if_index, self.vni, + self.src, self.dst) |