diff options
author | Libor Peltan <libor.peltan@nic.cz> | 2024-07-09 16:44:44 +0200 |
---|---|---|
committer | Daniel Salzman <daniel.salzman@nic.cz> | 2024-07-11 18:30:29 +0200 |
commit | 3e4831f8a77957f71bf95a686fef8baf0816b92a (patch) | |
tree | 01f18a4cd65cffc9c9fa3181a31f188b19fbdb4b /tests | |
parent | Merge branch 'rrtype_wallet' into 'master' (diff) | |
download | knot-3e4831f8a77957f71bf95a686fef8baf0816b92a.tar.xz knot-3e4831f8a77957f71bf95a686fef8baf0816b92a.zip |
xdp-tcp: ignore SYN+ACK pkts in knotd (only for kxdpgun)
Diffstat (limited to 'tests')
-rw-r--r-- | tests/libknot/test_xdp_tcp.c | 17 |
1 files changed, 16 insertions, 1 deletions
diff --git a/tests/libknot/test_xdp_tcp.c b/tests/libknot/test_xdp_tcp.c index 3059ac1ea..4e02f57dc 100644 --- a/tests/libknot/test_xdp_tcp.c +++ b/tests/libknot/test_xdp_tcp.c @@ -236,6 +236,20 @@ void test_syn(void) test_conn = conn; } +void test_syn_ack_no(void) +{ + knot_xdp_msg_t msg; + knot_tcp_relay_t rl = { 0 }; + prepare_msg(&msg, KNOT_XDP_MSG_SYN | KNOT_XDP_MSG_ACK, 1, 2); + int ret = knot_tcp_recv(&rl, &msg, test_table, test_syn_table, XDP_TCP_IGNORE_NONE); + is_int(KNOT_EOK, ret, "SYN+ACK deny: relay OK"); + is_int(XDP_TCP_NOOP, rl.auto_answer, "SYN+ACK deny: no auto answer"); + is_int(XDP_TCP_NOOP, rl.answer, "SYN+ACK deny: no answer"); + is_int(0, test_table->usage, "SYN+ACK deny: no connection in normal table"); + is_int(1, test_syn_table->usage, "SYN+ACK deny: one connection in SYN table"); + knot_tcp_cleanup(test_syn_table, &rl, 1); +} + void test_establish(void) { knot_xdp_msg_t msg; @@ -260,7 +274,7 @@ void test_syn_ack(void) knot_xdp_msg_t msg; knot_tcp_relay_t rl = { 0 }; prepare_msg(&msg, KNOT_XDP_MSG_SYN | KNOT_XDP_MSG_ACK, 1000, 2000); - int ret = knot_tcp_recv(&rl, &msg, test_table, test_syn_table, XDP_TCP_IGNORE_NONE); + int ret = knot_tcp_recv(&rl, &msg, test_table, NULL, XDP_TCP_IGNORE_NONE); is_int(KNOT_EOK, ret, "SYN+ACK: relay OK"); ret = knot_tcp_send(test_sock, &rl, 1, 1); is_int(KNOT_EOK, ret, "SYN+ACK: send OK"); @@ -626,6 +640,7 @@ int main(int argc, char *argv[]) init_mock(&test_sock, mock_send); test_syn(); + test_syn_ack_no(); test_establish(); test_syn_ack(); |