summaryrefslogtreecommitdiff
path: root/src/test/test_dir.c
diff options
context:
space:
mode:
authorOla Bini <ola@olabini.se>2016-01-12 12:33:05 -0500
committerOla Bini <ola@olabini.se>2016-01-12 12:33:05 -0500
commitfcd7923a966893131cf4e8f60a6ac9a0f46251b8 (patch)
tree63986403610268999ba736c5030607cd0411d118 /src/test/test_dir.c
parentee39869f67a1e9e829f7807cf8df783bbbbeccc3 (diff)
downloadtor-fcd7923a966893131cf4e8f60a6ac9a0f46251b8.tar.gz
tor-fcd7923a966893131cf4e8f60a6ac9a0f46251b8.zip
Fix remaining memory leaks
Diffstat (limited to 'src/test/test_dir.c')
-rw-r--r--src/test/test_dir.c30
1 files changed, 22 insertions, 8 deletions
diff --git a/src/test/test_dir.c b/src/test/test_dir.c
index 62aae03dba..c888e0076b 100644
--- a/src/test/test_dir.c
+++ b/src/test/test_dir.c
@@ -6,6 +6,7 @@
#include "orconfig.h"
#include <math.h>
+#define CONFIG_PRIVATE
#define DIRSERV_PRIVATE
#define DIRVOTE_PRIVATE
#define ROUTER_PRIVATE
@@ -15,6 +16,7 @@
#define RELAY_PRIVATE
#include "or.h"
+#include "confparse.h"
#include "config.h"
#include "crypto_ed25519.h"
#include "directory.h"
@@ -587,6 +589,7 @@ test_dir_extrainfo_parsing(void *arg)
#undef CHECK_FAIL
done:
+ escaped(NULL);
memarea_clear_freelist();
extrainfo_free(ei);
routerinfo_free(ri);
@@ -3527,20 +3530,31 @@ static void
test_dir_authdir_type_to_string(void *data)
{
(void)data;
+ char *res;
- tt_str_op(authdir_type_to_string(NO_DIRINFO), OP_EQ,
+ tt_str_op(res = authdir_type_to_string(NO_DIRINFO), OP_EQ,
"[Not an authority]");
- tt_str_op(authdir_type_to_string(EXTRAINFO_DIRINFO), OP_EQ,
+ tor_free(res);
+
+ tt_str_op(res = authdir_type_to_string(EXTRAINFO_DIRINFO), OP_EQ,
"[Not an authority]");
- tt_str_op(authdir_type_to_string(MICRODESC_DIRINFO), OP_EQ,
+ tor_free(res);
+
+ tt_str_op(res = authdir_type_to_string(MICRODESC_DIRINFO), OP_EQ,
"[Not an authority]");
+ tor_free(res);
+
+ tt_str_op(res = authdir_type_to_string(V3_DIRINFO), OP_EQ, "V3");
+ tor_free(res);
+
+ tt_str_op(res = authdir_type_to_string(BRIDGE_DIRINFO), OP_EQ, "Bridge");
+ tor_free(res);
- tt_str_op(authdir_type_to_string(V3_DIRINFO), OP_EQ, "V3");
- tt_str_op(authdir_type_to_string(BRIDGE_DIRINFO), OP_EQ, "Bridge");
- tt_str_op(authdir_type_to_string(
+ tt_str_op(res = authdir_type_to_string(
V3_DIRINFO | BRIDGE_DIRINFO | EXTRAINFO_DIRINFO), OP_EQ,
"V3, Bridge");
- done: ;
+ done:
+ tor_free(res);
}
static void
@@ -3644,7 +3658,7 @@ test_dir_should_use_directory_guards(void *data)
done:
NS_UNMOCK(public_server_mode);
- tor_free(options);
+ or_options_free(options);
tor_free(errmsg);
}