summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorMike Perry <mikeperry-git@fscked.org>2013-01-19 21:16:24 -0800
committerMike Perry <mikeperry-git@fscked.org>2013-01-20 14:32:56 -0800
commitf858370233a7d01d89949f79f92e8b67acd69f46 (patch)
treee8a6df846a6e7a97ef6a43e25a2ebf5032309921 /src
parentfb711e6d77cc6b4d4ff2daa506960919626a3f6a (diff)
downloadtor-f858370233a7d01d89949f79f92e8b67acd69f46.tar.gz
tor-f858370233a7d01d89949f79f92e8b67acd69f46.zip
Prevent early close of path bias testing circuits.
We need to let them live long enough to perform the test.
Diffstat (limited to 'src')
-rw-r--r--src/or/circuituse.c5
-rw-r--r--src/or/rendservice.c3
2 files changed, 6 insertions, 2 deletions
diff --git a/src/or/circuituse.c b/src/or/circuituse.c
index 0b2fe9eb8d..48a774352e 100644
--- a/src/or/circuituse.c
+++ b/src/or/circuituse.c
@@ -1078,7 +1078,10 @@ circuit_expire_old_circuits_clientside(void)
"purpose %d)",
circ->n_circ_id, (long)(now.tv_sec - circ->timestamp_dirty),
circ->purpose);
- circuit_mark_for_close(circ, END_CIRC_REASON_FINISHED);
+ /* Don't do this magic for testing circuits. Their death is governed
+ * by circuit_expire_building */
+ if (circ->purpose != CIRCUIT_PURPOSE_PATH_BIAS_TESTING)
+ circuit_mark_for_close(circ, END_CIRC_REASON_FINISHED);
} else if (!circ->timestamp_dirty && circ->state == CIRCUIT_STATE_OPEN) {
if (timercmp(&circ->timestamp_began, &cutoff, <)) {
if (circ->purpose == CIRCUIT_PURPOSE_C_GENERAL ||
diff --git a/src/or/rendservice.c b/src/or/rendservice.c
index 3b2eeb4ad0..f115d8bfc8 100644
--- a/src/or/rendservice.c
+++ b/src/or/rendservice.c
@@ -3068,7 +3068,8 @@ rend_services_introduce(void)
if (intro->time_expiring + INTRO_POINT_EXPIRATION_GRACE_PERIOD > now) {
/* This intro point has completely expired. Remove it, and
* mark the circuit for close if it's still alive. */
- if (intro_circ != NULL) {
+ if (intro_circ != NULL &&
+ intro_circ->base_.purpose != CIRCUIT_PURPOSE_PATH_BIAS_TESTING) {
circuit_mark_for_close(TO_CIRCUIT(intro_circ),
END_CIRC_REASON_FINISHED);
}