From 7a1ce77ca43602c8a2915fd4753d30b14b904db4 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Piotr=20Wo=CC=81jcik?= <3044353+pwojcikdev@users.noreply.github.com> Date: Sat, 20 Apr 2024 19:26:59 +0200 Subject: [PATCH] Fix `socket.max_connections` --- nano/core_test/socket.cpp | 26 +++++++++++++++++++------- 1 file changed, 19 insertions(+), 7 deletions(-) diff --git a/nano/core_test/socket.cpp b/nano/core_test/socket.cpp index ee59b6dc9b..5a7a627735 100644 --- a/nano/core_test/socket.cpp +++ b/nano/core_test/socket.cpp @@ -33,10 +33,12 @@ TEST (socket, max_connections) // successful incoming connections are stored in server_sockets to keep them alive (server side) std::vector> server_sockets; + std::mutex server_sockets_mutex; // start a server socket that allows max 2 live connections nano::transport::tcp_listener listener{ server_port, *node, 2 }; - listener.connection_accepted.add ([&server_sockets] (auto const & socket, auto const & server) { + listener.connection_accepted.add ([&] (auto const & socket, auto const & server) { + std::lock_guard guard{ server_sockets_mutex }; server_sockets.push_back (socket); }); nano::test::start_stop_guard stop_guard{ listener }; @@ -69,14 +71,22 @@ TEST (socket, max_connections) return node->stats.count (nano::stat::type::tcp_listener, nano::stat::detail::accept_success, nano::stat::dir::in); }; + auto server_sockets_size = [&] () { + std::lock_guard guard{ server_sockets_mutex }; + return server_sockets.size (); + }; + ASSERT_TIMELY_EQ (10s, get_tcp_accept_successes (), 2); ASSERT_ALWAYS_EQ (1s, get_tcp_accept_successes (), 2); ASSERT_TIMELY_EQ (5s, connection_attempts, 3); - ASSERT_TIMELY_EQ (5s, server_sockets.size (), 2); + ASSERT_TIMELY_EQ (5s, server_sockets_size (), 2); // create space for one socket and fill the connections table again - server_sockets[0].reset (); + { + std::lock_guard guard{ server_sockets_mutex }; + server_sockets[0].reset (); + } auto client4 = std::make_shared (*node); client4->async_connect (dst_endpoint, connect_handler); @@ -91,9 +101,11 @@ TEST (socket, max_connections) // close all existing sockets and fill the connections table again // start counting form 1 because 0 is the already closed socket - - server_sockets[1].reset (); - server_sockets[2].reset (); + { + std::lock_guard guard{ server_sockets_mutex }; + server_sockets[1].reset (); + server_sockets[2].reset (); + } auto client6 = std::make_shared (*node); client6->async_connect (dst_endpoint, connect_handler); @@ -107,7 +119,7 @@ TEST (socket, max_connections) ASSERT_TIMELY_EQ (5s, get_tcp_accept_successes (), 5); ASSERT_ALWAYS_EQ (1s, get_tcp_accept_successes (), 5); ASSERT_TIMELY_EQ (5s, connection_attempts, 8); // connections initiated by the client - ASSERT_TIMELY_EQ (5s, server_sockets.size (), 5); // connections accepted by the server + ASSERT_TIMELY_EQ (5s, server_sockets_size (), 5); // connections accepted by the server } TEST (socket, max_connections_per_ip)