[tor-commits] [arm/master] Test Daemon's general functionality

atagar at torproject.org atagar at torproject.org
Mon Jan 6 01:54:14 UTC 2014


commit 2269d007c5ba9ba1207a49d1440e33284e57581d
Author: Damian Johnson <atagar at torproject.org>
Date:   Sun Jan 5 15:09:27 2014 -0800

    Test Daemon's general functionality
    
    Check that the Daemon's pause method and that it executes the given task at a
    set rate.
---
 arm/util/tracker.py         |   12 ++++++++++--
 test/util/tracker/daemon.py |   33 +++++++++++++++++++++++++++++++--
 2 files changed, 41 insertions(+), 4 deletions(-)

diff --git a/arm/util/tracker.py b/arm/util/tracker.py
index 8febb12..1a716d3 100644
--- a/arm/util/tracker.py
+++ b/arm/util/tracker.py
@@ -218,7 +218,7 @@ class Daemon(threading.Thread):
       time_since_last_ran = time.time() - self._last_ran
 
       if self._is_paused or time_since_last_ran < self._rate:
-        sleep_duration = max(0.2, self._rate - time_since_last_ran)
+        sleep_duration = max(0.02, self._rate - time_since_last_ran)
 
         with self._pause_condition:
           if not self._halt:
@@ -248,7 +248,7 @@ class Daemon(threading.Thread):
     :returns: **bool** indicating if our run was successful or not
     """
 
-    pass
+    return True
 
   def run_counter(self):
     """
@@ -306,6 +306,14 @@ class Daemon(threading.Thread):
         self._process_pid = tor_pid
         self._process_name = tor_cmd if tor_cmd else 'tor'
 
+  def __enter__(self):
+    self.start()
+    return self
+
+  def __exit__(self, exit_type, value, traceback):
+    self.stop()
+    self.join()
+
 
 class ConnectionTracker(Daemon):
   """
diff --git a/test/util/tracker/daemon.py b/test/util/tracker/daemon.py
index 9bde71f..9d409e2 100644
--- a/test/util/tracker/daemon.py
+++ b/test/util/tracker/daemon.py
@@ -1,8 +1,9 @@
+import time
 import unittest
 
 from arm.util.tracker import Daemon
 
-from mock import patch
+from mock import Mock, patch
 
 
 class TestDaemon(unittest.TestCase):
@@ -17,7 +18,7 @@ class TestDaemon(unittest.TestCase):
 
     daemon = Daemon(0.05)
 
-    self.assertEqual(0.05, daemon._rate)
+    self.assertEqual(0.05, daemon.get_rate())
     self.assertEqual(12345, daemon._process_pid)
     self.assertEqual('local_tor', daemon._process_name)
 
@@ -45,3 +46,31 @@ class TestDaemon(unittest.TestCase):
     daemon = Daemon(0.05)
     self.assertEqual(None, daemon._process_pid)
     self.assertEqual('tor', daemon._process_name)
+    self.assertEqual(0, system_mock.call_count)
+
+  @patch('arm.util.tracker.tor_controller', Mock(return_value = Mock()))
+  @patch('arm.util.tracker.system', Mock(return_value = Mock()))
+  def test_daemon_calls_task(self):
+    # Check that our Daemon calls the task method at the given rate.
+
+    with Daemon(0.01) as daemon:
+      time.sleep(0.05)
+      self.assertTrue(2 < daemon.run_counter())
+
+  @patch('arm.util.tracker.tor_controller', Mock(return_value = Mock()))
+  @patch('arm.util.tracker.system', Mock(return_value = Mock()))
+  def test_pausing_daemon(self):
+    # Check that we can pause and unpause daemon.
+
+    with Daemon(0.01) as daemon:
+      time.sleep(0.05)
+      self.assertTrue(2 < daemon.run_counter())
+
+      daemon.set_paused(True)
+      daemon._run_counter = 0
+      time.sleep(0.05)
+      self.assertEqual(0, daemon.run_counter())
+
+      daemon.set_paused(False)
+      time.sleep(0.05)
+      self.assertTrue(2 < daemon.run_counter())





More information about the tor-commits mailing list