[tor-commits] [bridgedb/master] Add tests for SIGHUP and SIGUSR1 signals
isis at torproject.org
isis at torproject.org
Sat Apr 19 17:02:42 UTC 2014
commit 9c4baf91858e51dc0dabb8475c4582260201ad72
Author: Matthew Finkel <Matthew.Finkel at gmail.com>
Date: Fri Feb 7 03:15:03 2014 +0000
Add tests for SIGHUP and SIGUSR1 signals
---
lib/bridgedb/test/test_bridgedb.py | 32 +++++++++++++++++++++++++++++++-
1 file changed, 31 insertions(+), 1 deletion(-)
diff --git a/lib/bridgedb/test/test_bridgedb.py b/lib/bridgedb/test/test_bridgedb.py
index 5dc890d..1f4470b 100644
--- a/lib/bridgedb/test/test_bridgedb.py
+++ b/lib/bridgedb/test/test_bridgedb.py
@@ -89,8 +89,38 @@ class BridgeDBCliTest(unittest.TestCase):
self.doCopyFile(eindesc, eidesc, 'duplicated cached-extrainfo(.new)')
print("Running `bridgedb' to test server startups...")
- bridgedbProc = Popen([bridgedbScript, '-r', runDir])
+ # Sorry Windows users
+ devnull = open('/dev/null', 'w')
+ bridgedbProc = Popen([bridgedbScript, '-r', runDir], stdout=devnull)
time.sleep(30)
+ assignments = pjoin(runDir, 'assignments.log')
+ self.assertTrue(os.path.isfile(assignments))
+ os.unlink(assignments)
+ bridgedbProc.send_signal(signal.SIGHUP)
+ time.sleep(5)
+ try:
+ self.assertTrue(os.path.isfile(assignments))
+ except self.failureException as e:
+ bridgedbProc.send_signal(signal.SIGKILL)
+ bridgedbProcCode = bridgedbProc.wait()
+ print("`bridgedb' exited with status code %d" % int(bridgedbProcCode))
+ raise e
+ bridgedbProc.send_signal(signal.SIGUSR1)
+ time.sleep(5)
+ buckets = [['email', False], ['https', False], ['unallocated', False]]
+ for rundirfile in os.listdir(runDir):
+ for bucket in buckets:
+ if rundirfile.startswith(bucket[0]):
+ bucket[1] = True
+ break
+ for bucket in buckets:
+ try:
+ self.assertTrue(bucket[1], "%s bucket was not dumped!" % bucket[0])
+ except self.failureException as e:
+ bridgedbProc.send_signal(signal.SIGKILL)
+ bridgedbProcCode = bridgedbProc.wait()
+ print("`bridgedb' exited with status code %d" % int(bridgedbProcCode))
+ raise e
bridgedbProc.send_signal(signal.SIGINT)
bridgedbProcCode = bridgedbProc.wait()
print("`bridgedb' exited with status code %d" % int(bridgedbProcCode))
More information about the tor-commits
mailing list