X-Git-Url: https://gerrit.fd.io/r/gitweb?a=blobdiff_plain;f=test%2Fvpp_mpls_tunnel_interface.py;h=6c8941a3f19d9cc166a44f1b5211c7e2afb5f685;hb=d9b0c6fbf7aa5bd9af84264105b39c82028a4a29;hp=a2ab1bf27cb819c6803adde19de11134c8f68764;hpb=f5fa5ae2b021f946fbb8ec56e692459cd34bc7fb;p=vpp.git diff --git a/test/vpp_mpls_tunnel_interface.py b/test/vpp_mpls_tunnel_interface.py index a2ab1bf27cb..6c8941a3f19 100644 --- a/test/vpp_mpls_tunnel_interface.py +++ b/test/vpp_mpls_tunnel_interface.py @@ -1,4 +1,3 @@ - from vpp_interface import VppInterface @@ -8,61 +7,40 @@ class VppMPLSTunnelInterface(VppInterface): """ def __init__(self, test, paths, is_multicast=0, is_l2=0): - """ Create MPLS Tunnel interface """ + """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 + self.encoded_paths = [] for path in self.t_paths: - lstack = path.encode_labels() + self.encoded_paths.append(path.encode()) - 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.tunnel_index = reply.tunnel_index - self.set_sw_if_index(sw_if_index) + def add_vpp_config(self): + reply = self.test.vapi.mpls_tunnel_add_del( + 0xFFFFFFFF, + self.encoded_paths, + is_multicast=self.is_multicast, + l2_only=self.is_l2, + ) + self.set_sw_if_index(reply.sw_if_index) + self.tunnel_index = reply.tunnel_index self._test.registry.register(self, self._test.logger) def remove_vpp_config(self): - for path in self.t_paths: - lstack = path.encode_labels() - - 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=lstack, - next_hop_n_out_labels=len(lstack), - is_add=0) + reply = self.test.vapi.mpls_tunnel_add_del( + self.sw_if_index, self.encoded_paths, is_add=0 + ) def query_vpp_config(self): dump = self._test.vapi.mpls_tunnel_dump() for t in dump: - if self.sw_if_index == t.mt_sw_if_index and \ - self.tunnel_index == t.mt_tunnel_index: + if ( + self.sw_if_index == t.mt_tunnel.mt_sw_if_index + and self.tunnel_index == t.mt_tunnel.mt_tunnel_index + ): return True return False - def __str__(self): - return self.object_id() - def object_id(self): - return ("mpls-tunnel%d-%d" % (self.tunnel_index, - self.sw_if_index)) + return "mpls-tunnel%d-%d" % (self.tunnel_index, self.sw_if_index)