diff options
-rw-r--r-- | test/framework.py | 5 | ||||
-rw-r--r-- | test/test_wireguard.py | 87 |
2 files changed, 71 insertions, 21 deletions
diff --git a/test/framework.py b/test/framework.py index fc22ad6483c..62fa1fe9727 100644 --- a/test/framework.py +++ b/test/framework.py @@ -26,7 +26,7 @@ from struct import pack, unpack import scapy.compat from scapy.packet import Raw, Packet -from vpp_pg_interface import VppPGInterface +from vpp_pg_interface import VppPGInterface, is_ipv6_misc from vpp_sub_interface import VppSubInterface from vpp_lo_interface import VppLoInterface from vpp_bvi_interface import VppBviInterface @@ -547,6 +547,7 @@ class VppTestCase(VppAsfTestCase): trace=True, msg=None, stats_diff=None, + filter_out_fn=is_ipv6_misc, ): if stats_diff: stats_snapshot = self.snapshot_stats(stats_diff) @@ -554,7 +555,7 @@ class VppTestCase(VppAsfTestCase): if not n_rx: n_rx = 1 if isinstance(pkts, Packet) else len(pkts) self.pg_send(intf, pkts, worker=worker, trace=trace) - rx = output.get_capture(n_rx) + rx = output.get_capture(n_rx, filter_out_fn=filter_out_fn) if trace: if msg: self.logger.debug(f"send_and_expect: {msg}") diff --git a/test/test_wireguard.py b/test/test_wireguard.py index 481aa558312..e1de75b9c14 100644 --- a/test/test_wireguard.py +++ b/test/test_wireguard.py @@ -504,6 +504,10 @@ def is_handshake_init(p): return wg_p[Wireguard].message_type == 1 +def filter_out_misc_and_handshake_init(p): + return is_ipv6_misc(p) or is_handshake_init(p) + + @unittest.skipIf( "wireguard" in config.excluded_plugins, "Exclude Wireguard plugin tests" ) @@ -578,15 +582,14 @@ class TestWg(VppTestCase): ): self.pg_send(intf, pkts) - def _filter_out_fn(p): - return is_ipv6_misc(p) or is_handshake_init(p) - try: if not timeout: timeout = 1 for i in self.pg_interfaces: i.assert_nothing_captured( - timeout=timeout, remark=remark, filter_out_fn=_filter_out_fn + timeout=timeout, + remark=remark, + filter_out_fn=filter_out_misc_and_handshake_init, ) timeout = 0.1 finally: @@ -681,7 +684,12 @@ class TestWg(VppTestCase): # prepare and send a handshake initiation # expect the peer to send a handshake response init = peer_1.mk_handshake(self.pg1, is_ip6=is_ip6) - rxs = self.send_and_expect(self.pg1, [init], self.pg1) + rxs = self.send_and_expect( + self.pg1, + [init], + self.pg1, + filter_out_fn=filter_out_misc_and_handshake_init, + ) else: # wait for the peer to send a handshake initiation rxs = self.pg1.get_capture(1, timeout=2) @@ -707,7 +715,7 @@ class TestWg(VppTestCase): self.pg_send(self.pg1, [cookie]) # wait for the peer to send a handshake initiation with mac2 set - rxs = self.pg1.get_capture(1, timeout=6) + rxs = self.pg1.get_capture(1, timeout=30) # verify the initiation and its mac2 peer_1.consume_init(rxs[0], self.pg1, is_ip6=is_ip6, is_mac2=True) @@ -786,13 +794,17 @@ class TestWg(VppTestCase): # expect a cookie reply init = peer_1.mk_handshake(self.pg1, is_ip6=is_ip6) init.mac2 = b"1234567890" - rxs = self.send_and_expect(self.pg1, [init], self.pg1) + rxs = self.send_and_expect( + self.pg1, [init], self.pg1, filter_out_fn=filter_out_misc_and_handshake_init + ) peer_1.consume_cookie(rxs[0], is_ip6=is_ip6) # prepare and send a handshake initiation with correct mac2 # expect a handshake response init = peer_1.mk_handshake(self.pg1, is_ip6=is_ip6) - rxs = self.send_and_expect(self.pg1, [init], self.pg1) + rxs = self.send_and_expect( + self.pg1, [init], self.pg1, filter_out_fn=filter_out_misc_and_handshake_init + ) # verify the response peer_1.consume_response(rxs[0], is_ip6=is_ip6) @@ -858,7 +870,9 @@ class TestWg(VppTestCase): # expect a cookie reply init = peer_1.mk_handshake(self.pg1) init.mac2 = b"1234567890" - rxs = self.send_and_expect(self.pg1, [init], self.pg1) + rxs = self.send_and_expect( + self.pg1, [init], self.pg1, filter_out_fn=filter_out_misc_and_handshake_init + ) peer_1.consume_cookie(rxs[0]) # sleep till the end of being under load @@ -869,7 +883,9 @@ class TestWg(VppTestCase): # expect a handshake response init = peer_1.mk_handshake(self.pg1) init.mac2 = b"1234567890" - rxs = self.send_and_expect(self.pg1, [init], self.pg1) + rxs = self.send_and_expect( + self.pg1, [init], self.pg1, filter_out_fn=filter_out_misc_and_handshake_init + ) # verify the response peer_1.consume_response(rxs[0]) @@ -1017,7 +1033,12 @@ class TestWg(VppTestCase): # (peer_2) prepare and send a handshake initiation # expect a cookie reply init_2 = peer_2.mk_handshake(self.pg1) - rxs = self.send_and_expect(self.pg1, [init_2], self.pg1) + rxs = self.send_and_expect( + self.pg1, + [init_2], + self.pg1, + filter_out_fn=filter_out_misc_and_handshake_init, + ) peer_2.consume_cookie(rxs[0]) # (peer_1) (peer_2) prepare and send a bunch of handshake initiations with correct mac2 @@ -1118,7 +1139,12 @@ class TestWg(VppTestCase): # prepare and send a handshake initiation # expect a handshake response sent to the new endpoint init = peer_1.mk_handshake(self.pg1, is_ip6=is_ip6) - rxs = self.send_and_expect(self.pg1, [init], self.pg1) + rxs = self.send_and_expect( + self.pg1, + [init], + self.pg1, + filter_out_fn=filter_out_misc_and_handshake_init, + ) # verify the response peer_1.consume_response(rxs[0], is_ip6=is_ip6) self.assertTrue(peer_1.query_vpp_config()) @@ -1506,7 +1532,9 @@ class TestWg(VppTestCase): # send a valid handsake init for which we expect a response p = peer_1.mk_handshake(self.pg1) - rx = self.send_and_expect(self.pg1, [p], self.pg1) + rx = self.send_and_expect( + self.pg1, [p], self.pg1, filter_out_fn=filter_out_misc_and_handshake_init + ) peer_1.consume_response(rx[0]) @@ -1667,7 +1695,9 @@ class TestWg(VppTestCase): # send a valid handsake init for which we expect a response p = peer_1.mk_handshake(self.pg1, True) - rx = self.send_and_expect(self.pg1, [p], self.pg1) + rx = self.send_and_expect( + self.pg1, [p], self.pg1, filter_out_fn=filter_out_misc_and_handshake_init + ) peer_1.consume_response(rx[0], True) @@ -1808,7 +1838,9 @@ class TestWg(VppTestCase): # send a valid handsake init for which we expect a response p = peer_1.mk_handshake(self.pg1) - rx = self.send_and_expect(self.pg1, [p], self.pg1) + rx = self.send_and_expect( + self.pg1, [p], self.pg1, filter_out_fn=filter_out_misc_and_handshake_init + ) peer_1.consume_response(rx[0]) @@ -1947,7 +1979,9 @@ class TestWg(VppTestCase): # send a valid handsake init for which we expect a response p = peer_1.mk_handshake(self.pg1, True) - rx = self.send_and_expect(self.pg1, [p], self.pg1) + rx = self.send_and_expect( + self.pg1, [p], self.pg1, filter_out_fn=filter_out_misc_and_handshake_init + ) peer_1.consume_response(rx[0], True) @@ -2172,7 +2206,12 @@ class TestWg(VppTestCase): for i in range(NUM_IFS): # send a valid handsake init for which we expect a response p = peers[i].mk_handshake(self.pg1) - rx = self.send_and_expect(self.pg1, [p], self.pg1) + rx = self.send_and_expect( + self.pg1, + [p], + self.pg1, + filter_out_fn=filter_out_misc_and_handshake_init, + ) peers[i].consume_response(rx[0]) # send a data packet from the peer through the tunnel @@ -2334,7 +2373,12 @@ class TestWg(VppTestCase): for i in range(NUM_PEERS): # wg0 peers: send a valid handsake init for which we expect a response p = peers_0[i].mk_handshake(self.pg1) - rx = self.send_and_expect(self.pg1, [p], self.pg1) + rx = self.send_and_expect( + self.pg1, + [p], + self.pg1, + filter_out_fn=filter_out_misc_and_handshake_init, + ) peers_0[i].consume_response(rx[0]) # wg0 peers: send empty packet, it means successful connection (WIREGUARD_PEER_ESTABLISHED) @@ -2357,7 +2401,12 @@ class TestWg(VppTestCase): # wg1 peers: send a valid handsake init for which we expect a response p = peers_1[i].mk_handshake(self.pg2) - rx = self.send_and_expect(self.pg2, [p], self.pg2) + rx = self.send_and_expect( + self.pg2, + [p], + self.pg2, + filter_out_fn=filter_out_misc_and_handshake_init, + ) peers_1[i].consume_response(rx[0]) # wg1 peers: send empty packet, it means successful connection (WIREGUARD_PEER_ESTABLISHED) |