[tor-commits] [chutney/master] TorNet: Print incremental bootstrap progress
teor at torproject.org
teor at torproject.org
Fri Mar 13 01:11:26 UTC 2020
commit f366fe1361e353e329a037ed6ba7d2e4b291ae19
Author: teor <teor at torproject.org>
Date: Wed Feb 19 15:53:07 2020 +1000
TorNet: Print incremental bootstrap progress
wait_for_bootstrap now prints bootstrap progress every 20 seconds.
Part of 33232.
---
lib/chutney/TorNet.py | 27 ++++++++++++++++++++++-----
1 file changed, 22 insertions(+), 5 deletions(-)
diff --git a/lib/chutney/TorNet.py b/lib/chutney/TorNet.py
index 3fa94ac..fb6486e 100644
--- a/lib/chutney/TorNet.py
+++ b/lib/chutney/TorNet.py
@@ -1448,18 +1448,29 @@ class Network(object):
print("Sending SIGHUP to nodes")
return all([n.getController().hup() for n in self._nodes])
- def print_bootstrap_status(self, controllers, most_recent_status):
- print("Bootstrap failed. Node status:")
+ def print_bootstrap_status(self, controllers, most_recent_status,
+ elapsed=None,
+ msg="Bootstrap in progress"):
+ header = "Node status:"
+ elapsed_msg = ""
+ if elapsed:
+ elapsed_msg = " for {} seconds".format(int(elapsed))
+ if msg:
+ header = "{}{}. {}".format(msg, elapsed_msg, header)
+ print(header)
for c, status in zip(controllers,most_recent_status):
c.check(listRunning=False, listNonRunning=True)
print("{}: {}".format(c.getNick(), status))
+ print()
CHECK_NETWORK_STATUS_DELAY = 0.5
+ PRINT_NETWORK_STATUS_DELAY = 20.0
def wait_for_bootstrap(self):
- print("Waiting for nodes to bootstrap...")
+ print("Waiting for nodes to bootstrap...\n")
start = time.time()
limit = start + getenv_int("CHUTNEY_START_TIME", 60)
+ next_print_status = start + Network.PRINT_NETWORK_STATUS_DELAY
controllers = [n.getController() for n in self._nodes]
most_recent_status = [ None ] * len(controllers)
while True:
@@ -1472,16 +1483,22 @@ class Network(object):
all_bootstrapped = False
now = time.time()
+ elapsed = now - start
if all_bootstrapped:
- elapsed = now - start
print("Everything bootstrapped after {} sec"
.format(int(elapsed)))
return True
if now >= limit:
break
+ if now >= next_print_status:
+ self.print_bootstrap_status(controllers, most_recent_status,
+ elapsed=elapsed)
+ next_print_status = now + Network.PRINT_NETWORK_STATUS_DELAY
time.sleep(Network.CHECK_NETWORK_STATUS_DELAY)
- self.print_bootstrap_status(controllers, most_recent_status)
+ self.print_bootstrap_status(controllers, most_recent_status,
+ elapsed=elapsed,
+ msg="Bootstrap failed")
return False
def stop(self):
More information about the tor-commits
mailing list