vpp/test/vpp_mpls_tunnel_interface.py
Neale Ranns 7c922dc404 SR-MPLS: fixes and tests
- the FIB path takes a vector of type fib_mpls_label_t not u32 so the untype safe vec_add did not work
- write som eSR-MPLS tests
- allow an MPLS tunnel to resolve through a SR BSID

Change-Id: I2a18b9a9bf43584100ac269c4ebc286c9e3b3ea5
Signed-off-by: Neale Ranns <nranns@cisco.com>
2018-08-30 17:12:11 +00:00

50 lines
1.6 KiB
Python

from vpp_interface import VppInterface
class VppMPLSTunnelInterface(VppInterface):
"""
VPP MPLS Tunnel interface
"""
def __init__(self, test, paths, is_multicast=0, is_l2=0):
""" Create MPLS Tunnel interface """
super(VppMPLSTunnelInterface, self).__init__(test)
self.t_paths = paths
self.is_multicast = is_multicast
self.is_l2 = is_l2
def add_vpp_config(self):
sw_if_index = 0xffffffff
for path in self.t_paths:
lstack = path.encode_labels()
reply = self.test.vapi.mpls_tunnel_add_del(
sw_if_index,
1, # IPv4 next-hop
path.nh_addr,
path.nh_itf,
path.nh_table_id,
path.weight,
next_hop_via_label=path.nh_via_label,
next_hop_out_label_stack=lstack,
next_hop_n_out_labels=len(lstack),
is_multicast=self.is_multicast,
l2_only=self.is_l2)
sw_if_index = reply.sw_if_index
self.set_sw_if_index(sw_if_index)
def remove_vpp_config(self):
for path in self.t_paths:
self.test.vapi.mpls_tunnel_add_del(
self.sw_if_index,
1, # IPv4 next-hop
path.nh_addr,
path.nh_itf,
path.nh_table_id,
path.weight,
next_hop_via_label=path.nh_via_label,
next_hop_out_label_stack=path.nh_labels,
next_hop_n_out_labels=len(path.nh_labels),
is_add=0)