summaryrefslogtreecommitdiff
path: root/src/or
diff options
context:
space:
mode:
authorNick Mathewson <nickm@torproject.org>2016-12-19 12:24:30 -0500
committerNick Mathewson <nickm@torproject.org>2016-12-19 12:24:30 -0500
commitc468df3961739720337baa6cc01da23aa8520712 (patch)
treebf07b34acc2ba2add9853d06e1729d440c1310ed /src/or
parent271bfc92b8d1f91d9b9a58e85f5e0c4746944632 (diff)
downloadtor-c468df3961739720337baa6cc01da23aa8520712.tar.gz
tor-c468df3961739720337baa6cc01da23aa8520712.zip
Don't warn about absent guard state when none expected.
Self-testing circuits don't use guards, and nobody uses guards when UseEntryGuards is disabled. Fixes bug 21007; bug not in any released Tor.
Diffstat (limited to 'src/or')
-rw-r--r--src/or/circuitbuild.c4
1 files changed, 3 insertions, 1 deletions
diff --git a/src/or/circuitbuild.c b/src/or/circuitbuild.c
index a14a2b1482..55929c1666 100644
--- a/src/or/circuitbuild.c
+++ b/src/or/circuitbuild.c
@@ -971,7 +971,9 @@ circuit_send_next_onion_skin(origin_circuit_t *circ)
// The circuit is usable; we already marked the guard as okay.
r = GUARD_USABLE_NOW;
} else if (! circ->guard_state) {
- if (circuit_get_cpath_len(circ) != 1) {
+ if (circuit_get_cpath_len(circ) != 1 &&
+ circ->base_.purpose != CIRCUIT_PURPOSE_TESTING &&
+ get_options()->UseEntryGuards) {
log_warn(LD_BUG, "%d-hop circuit %p with purpose %d has no "
"guard state",
circuit_get_cpath_len(circ), circ, circ->base_.purpose);