From 839dcc0fb7313638d9b8f52a9db81350dddfe461 Mon Sep 17 00:00:00 2001 From: Artem Glazychev Date: Tue, 1 Dec 2020 02:39:21 +0700 Subject: vxlan: add udp-port configuration support Type: improvement Signed-off-by: Artem Glazychev Change-Id: Ie30d51ab4df5599b52f7335f863b930cd69dbdc1 --- test/vpp_vxlan_tunnel.py | 31 ++++++++++++++++++++++++++----- 1 file changed, 26 insertions(+), 5 deletions(-) (limited to 'test/vpp_vxlan_tunnel.py') diff --git a/test/vpp_vxlan_tunnel.py b/test/vpp_vxlan_tunnel.py index 0f6ecb771f5..dce5ab86c07 100644 --- a/test/vpp_vxlan_tunnel.py +++ b/test/vpp_vxlan_tunnel.py @@ -3,13 +3,26 @@ from vpp_papi import VppEnum INDEX_INVALID = 0xffffffff +DEFAULT_PORT = 4789 +UNDEFINED_PORT = 0 -def find_vxlan_tunnel(test, src, dst, vni): - ts = test.vapi.vxlan_tunnel_dump(INDEX_INVALID) +def find_vxlan_tunnel(test, src, dst, s_port, d_port, vni): + ts = test.vapi.vxlan_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.src_address) and \ dst == str(t.dst_address) and \ + src_port == t.src_port and \ + dst_port == t.dst_port and \ t.vni == vni: return t.sw_if_index return INDEX_INVALID @@ -20,7 +33,9 @@ class VppVxlanTunnel(VppInterface): VPP VXLAN interface """ - def __init__(self, test, src, dst, vni, mcast_itf=None, + def __init__(self, test, src, dst, vni, + src_port=UNDEFINED_PORT, dst_port=UNDEFINED_PORT, + mcast_itf=None, mcast_sw_if_index=INDEX_INVALID, decap_next_index=INDEX_INVALID, encap_vrf_id=None, instance=0xffffffff): @@ -29,6 +44,8 @@ class VppVxlanTunnel(VppInterface): self.src = src self.dst = dst self.vni = vni + self.src_port = src_port + self.dst_port = dst_port self.mcast_itf = mcast_itf self.mcast_sw_if_index = mcast_sw_if_index self.encap_vrf_id = encap_vrf_id @@ -39,8 +56,9 @@ class VppVxlanTunnel(VppInterface): self.mcast_sw_if_index = self.mcast_itf.sw_if_index def add_vpp_config(self): - reply = self.test.vapi.vxlan_add_del_tunnel( + reply = self.test.vapi.vxlan_add_del_tunnel_v2( is_add=1, src_address=self.src, dst_address=self.dst, vni=self.vni, + src_port=self.src_port, dst_port=self.dst_port, mcast_sw_if_index=self.mcast_sw_if_index, encap_vrf_id=self.encap_vrf_id, instance=self.instance, decap_next_index=self.decap_next_index) @@ -48,8 +66,9 @@ class VppVxlanTunnel(VppInterface): self._test.registry.register(self, self._test.logger) def remove_vpp_config(self): - self.test.vapi.vxlan_add_del_tunnel( + self.test.vapi.vxlan_add_del_tunnel_v2( is_add=0, src_address=self.src, dst_address=self.dst, vni=self.vni, + src_port=self.src_port, dst_port=self.dst_port, mcast_sw_if_index=self.mcast_sw_if_index, encap_vrf_id=self.encap_vrf_id, instance=self.instance, decap_next_index=self.decap_next_index) @@ -58,6 +77,8 @@ class VppVxlanTunnel(VppInterface): return (INDEX_INVALID != find_vxlan_tunnel(self._test, self.src, self.dst, + self.src_port, + self.dst_port, self.vni)) def object_id(self): -- cgit 1.2.3-korg