aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorNick Mathewson <nickm@torproject.org>2021-01-26 16:58:27 -0500
committerNick Mathewson <nickm@torproject.org>2021-01-26 16:58:27 -0500
commit37ea6cd9eb9bc4b6c0eb4f5d9cf70b97ea43eba4 (patch)
tree32dd3e8d8b8a62e1a68683840805b1fb86d09141
parent930a17f347d834e928e6f4bd89803d676e233454 (diff)
downloadtor-37ea6cd9eb9bc4b6c0eb4f5d9cf70b97ea43eba4.tar.gz
tor-37ea6cd9eb9bc4b6c0eb4f5d9cf70b97ea43eba4.zip
Fix a subtle memory leak in test_exorport.c
This is a _subtle_ bug introduced by d1494d14, which resolved connections that was allocated in the extorport/handshake test. So how did the connection get freed? Our test was set up so that every extorport connection would get the same ext_or_id. Two connections couldn't have the same ext_or_id, and if they did, one would get freed. This meant that the _next_ connection to be constructed in the test would cause the previous connection to become closeable, even if it hadn't been closeable before. But when we applied d149d14, we stopped making it so our code enforced this uniqueness, and thereby make it so we _weren't_ freeing this connection in the tests. Closes #40260; bug not in any released version of Tor.
-rw-r--r--src/test/test_extorport.c2
1 files changed, 1 insertions, 1 deletions
diff --git a/src/test/test_extorport.c b/src/test/test_extorport.c
index fd260f06dc..89a1aa90b3 100644
--- a/src/test/test_extorport.c
+++ b/src/test/test_extorport.c
@@ -473,7 +473,7 @@ test_ext_or_handshake(void *arg)
tt_int_op(handshake_start_called,OP_EQ,1);
tt_int_op(TO_CONN(conn)->type, OP_EQ, CONN_TYPE_OR);
tt_int_op(TO_CONN(conn)->state, OP_EQ, 0);
- close_closeable_connections();
+ connection_free_(TO_CONN(conn));
conn = NULL;
/* Okay, this time let's succeed the handshake but fail the USERADDR