[tor-commits] [tor/release-0.3.5] test_rebind: wait for tor to timeout, even if it is logging a lot
nickm at torproject.org
nickm at torproject.org
Wed Dec 19 20:36:15 UTC 2018
commit 315c21d2e200fc45e4886fb7ab32e01a3a8354e9
Author: Nick Mathewson <nickm at torproject.org>
Date: Mon Dec 17 09:53:17 2018 -0500
test_rebind: wait for tor to timeout, even if it is logging a lot
Fixes bug 28883; bugfix on 0.3.5.4-alpha.
---
changes/ticket28883 | 4 ++++
src/test/test_rebind.py | 6 ++----
2 files changed, 6 insertions(+), 4 deletions(-)
diff --git a/changes/ticket28883 b/changes/ticket28883
new file mode 100644
index 000000000..1d8b6cb41
--- /dev/null
+++ b/changes/ticket28883
@@ -0,0 +1,4 @@
+ o Minor bugfixes (testing):
+ - Make sure that test_rebind.py actually obeys its timeout, even
+ when it receives a large number of log messages. Fixes bug 28883;
+ bugfix on 0.3.5.4-alpha.
diff --git a/src/test/test_rebind.py b/src/test/test_rebind.py
index 2215b4225..92a346775 100644
--- a/src/test/test_rebind.py
+++ b/src/test/test_rebind.py
@@ -11,7 +11,6 @@ import time
LOG_TIMEOUT = 60.0
LOG_WAIT = 0.1
-LOG_CHECK_LIMIT = LOG_TIMEOUT / LOG_WAIT
def fail(msg):
logging.error('FAIL')
@@ -25,8 +24,8 @@ def try_connecting_to_socksport():
socks_socket.close()
def wait_for_log(s):
- log_checked = 0
- while log_checked < LOG_CHECK_LIMIT:
+ cutoff = time.time() + LOG_TIMEOUT
+ while time.time() < cutoff:
l = tor_process.stdout.readline()
l = l.decode('utf8')
if s in l:
@@ -37,7 +36,6 @@ def wait_for_log(s):
# avoid busy-waiting
if len(s) == 0:
time.sleep(LOG_WAIT)
- log_checked += 1
fail('Could not find "{}" in logs after {} seconds'.format(s, LOG_TIMEOUT))
def pick_random_port():
More information about the tor-commits
mailing list