summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorNick Mathewson <nickm@torproject.org>2008-12-11 06:18:01 +0000
committerNick Mathewson <nickm@torproject.org>2008-12-11 06:18:01 +0000
commit595e77c8d7b189ee29a058136691e53dc946c4ef (patch)
tree4a010e94a61b4877ec574e68c7ddf481f8fe6fe5
parent6ffb4d4ab6cd62b047ecc2f4a3118f6f1d098a20 (diff)
downloadtor-595e77c8d7b189ee29a058136691e53dc946c4ef.tar.gz
tor-595e77c8d7b189ee29a058136691e53dc946c4ef.zip
Fix memory leaks in test_v3_networkstatus.
svn:r17579
-rw-r--r--src/or/test.c75
1 files changed, 48 insertions, 27 deletions
diff --git a/src/or/test.c b/src/or/test.c
index e5446d0872..cb9117ba22 100644
--- a/src/or/test.c
+++ b/src/or/test.c
@@ -3062,19 +3062,25 @@ generate_ri_from_rs(const vote_routerstatus_t *vrs)
static void
test_v3_networkstatus(void)
{
- authority_cert_t *cert1, *cert2, *cert3;
- crypto_pk_env_t *sign_skey_1, *sign_skey_2, *sign_skey_3;
+ authority_cert_t *cert1=NULL, *cert2=NULL, *cert3=NULL;
+ crypto_pk_env_t *sign_skey_1=NULL, *sign_skey_2=NULL, *sign_skey_3=NULL;
crypto_pk_env_t *sign_skey_leg1;
const char *msg=NULL;
time_t now = time(NULL);
networkstatus_voter_info_t *voter;
- networkstatus_t *vote, *v1, *v2, *v3, *con;
+ networkstatus_t *vote=NULL, *v1=NULL, *v2=NULL, *v3=NULL, *con=NULL;
vote_routerstatus_t *vrs;
routerstatus_t *rs;
- char *v1_text, *v2_text, *v3_text, *consensus_text, *cp;
+ char *v1_text=NULL, *v2_text=NULL, *v3_text=NULL, *consensus_text=NULL, *cp;
smartlist_t *votes = smartlist_create();
+ /* For generating the two other consensuses. */
+ char *detached_text1=NULL, *detached_text2=NULL;
+ char *consensus_text2=NULL, *consensus_text3=NULL;
+ networkstatus_t *con2=NULL, *con3=NULL;
+ ns_detached_signatures_t *dsig1=NULL, *dsig2=NULL;
+
/* Parse certificates and keys. */
cert1 = authority_cert_parse_from_string(AUTHORITY_CERT_1, NULL);
test_assert(cert1);
@@ -3426,9 +3432,8 @@ test_v3_networkstatus(void)
test_assert(!voter->bad_signature);
{
- char *consensus_text2, *consensus_text3;
+ /*XXXX these fields can be leaked. */
networkstatus_t *con2, *con3;
- char *detached_text1, *detached_text2;
ns_detached_signatures_t *dsig1, *dsig2;
const char *msg=NULL;
/* Compute the other two signed consensuses. */
@@ -3504,34 +3509,50 @@ test_v3_networkstatus(void)
smartlist_get(con->voters, 3),
cert1));
- networkstatus_vote_free(con2);
- networkstatus_vote_free(con3);
- tor_free(consensus_text2);
- tor_free(consensus_text3);
- tor_free(detached_text1);
- tor_free(detached_text2);
- ns_detached_signatures_free(dsig1);
- ns_detached_signatures_free(dsig2);
}
+ done:
smartlist_free(votes);
tor_free(v1_text);
tor_free(v2_text);
tor_free(v3_text);
tor_free(consensus_text);
- networkstatus_vote_free(vote);
- networkstatus_vote_free(v1);
- networkstatus_vote_free(v2);
- networkstatus_vote_free(v3);
- networkstatus_vote_free(con);
- crypto_free_pk_env(sign_skey_1);
- crypto_free_pk_env(sign_skey_2);
- crypto_free_pk_env(sign_skey_3);
- authority_cert_free(cert1);
- authority_cert_free(cert2);
- authority_cert_free(cert3);
- done:
- ;
+
+ if (vote)
+ networkstatus_vote_free(vote);
+ if (v1)
+ networkstatus_vote_free(v1);
+ if (v2)
+ networkstatus_vote_free(v2);
+ if (v3)
+ networkstatus_vote_free(v3);
+ if (con)
+ networkstatus_vote_free(con);
+ if (sign_skey_1)
+ crypto_free_pk_env(sign_skey_1);
+ if (sign_skey_2)
+ crypto_free_pk_env(sign_skey_2);
+ if (sign_skey_3)
+ crypto_free_pk_env(sign_skey_3);
+ if (cert1)
+ authority_cert_free(cert1);
+ if (cert2)
+ authority_cert_free(cert2);
+ if (cert3)
+ authority_cert_free(cert3);
+
+ tor_free(consensus_text2);
+ tor_free(consensus_text3);
+ tor_free(detached_text1);
+ tor_free(detached_text2);
+ if (con2)
+ networkstatus_vote_free(con2);
+ if (con3)
+ networkstatus_vote_free(con3);
+ if (dsig1)
+ ns_detached_signatures_free(dsig1);
+ if (dsig2)
+ ns_detached_signatures_free(dsig2);
}
static void