[tor-commits] [stem/master] Added test for list circuits example script

atagar at torproject.org atagar at torproject.org
Sun Dec 21 23:15:52 UTC 2014


commit f28142dce4ee8f1035e0df5ec009725c641a8545
Author: Sambuddha Basu <sambuddhabasu1 at gmail.com>
Date:   Sun Dec 14 15:33:13 2014 +0400

    Added test for list circuits example script
    
    Made better use of functions
---
 test/settings.cfg              |    1 +
 test/unit/tutorial_examples.py |  111 ++++++++++++++++++++++++++++++++++++++++
 2 files changed, 112 insertions(+)

diff --git a/test/settings.cfg b/test/settings.cfg
index 6ce27b8..96fa40d 100644
--- a/test/settings.cfg
+++ b/test/settings.cfg
@@ -172,6 +172,7 @@ test.unit_tests
 |test.unit.exit_policy.policy.TestExitPolicy
 |test.unit.version.TestVersion
 |test.unit.tutorial.TestTutorial
+|test.unit.tutorial_examples.TestTutorialExamples
 |test.unit.response.control_message.TestControlMessage
 |test.unit.response.control_line.TestControlLine
 |test.unit.response.events.TestEvents
diff --git a/test/unit/tutorial_examples.py b/test/unit/tutorial_examples.py
new file mode 100644
index 0000000..59be150
--- /dev/null
+++ b/test/unit/tutorial_examples.py
@@ -0,0 +1,111 @@
+"""
+Tests for the examples given in stem's tutorial.
+"""
+
+import StringIO
+import unittest
+
+import stem.response
+
+from stem.control import Controller
+from test import mocking
+from test.mocking import get_router_status_entry_v3
+from test.mocking import ROUTER_STATUS_ENTRY_V3_HEADER
+
+try:
+  # added in python 3.3
+  from unittest.mock import patch
+except ImportError:
+  from mock import patch
+
+CIRC_CONTENT = '650 CIRC %d %s \
+%s \
+PURPOSE=%s'
+
+PATH_CONTENT = '$%s=%s,$%s=%s,$%s=%s'
+
+LIST_CIRCUITS_OUTPUT = """\
+
+Circuit 4 (GENERAL)
+ |- B1FA7D51B8B6F0CB585D944F450E7C06EDE7E44C (ByTORAndTheSnowDog, 173.209.180.61)
+ |- 0DD9935C5E939CFA1E07B8DDA6D91C1A2A9D9338 (afo02, 87.238.194.176)
+ +- DB3B1CFBD3E4D97B84B548ADD5B9A31451EEC4CC (edwardsnowden3, 109.163.234.10)
+
+Circuit 6 (GENERAL)
+ |- B1FA7D51B8B6F0CB585D944F450E7C06EDE7E44C (ByTORAndTheSnowDog, 173.209.180.61)
+ |- EC01CB4766BADC1611678555CE793F2A7EB2D723 (sprockets, 46.165.197.96)
+ +- 9EA317EECA56BDF30CAEB208A253FB456EDAB1A0 (bolobolo1, 96.47.226.20)
+
+Circuit 10 (GENERAL)
+ |- B1FA7D51B8B6F0CB585D944F450E7C06EDE7E44C (ByTORAndTheSnowDog, 173.209.180.61)
+ |- 00C2C2A16AEDB51D5E5FB7D6168FC66B343D822F (ph3x, 86.59.119.83)
+ +- 65242C91BFF30F165DA4D132C81A9EBA94B71D62 (torexit16, 176.67.169.171)
+"""
+
+
+def _get_event(id, status, hop1, hop2, hop3, purpose):
+  path = PATH_CONTENT % (hop1[0], hop1[1], hop2[0], hop2[1], hop3[0], hop3[1])
+  content = CIRC_CONTENT % (id, status, path, purpose)
+  controller_event = mocking.get_message(content)
+  stem.response.convert('EVENT', controller_event)
+  return controller_event
+
+
+def _get_router_status(address):
+  r_line = ROUTER_STATUS_ENTRY_V3_HEADER[0][1].replace('71.35.150.29', address)
+  content = get_router_status_entry_v3({'r': r_line})
+  return content
+
+
+class TestTutorialExamples(unittest.TestCase):
+  @patch('sys.stdout', new_callable = StringIO.StringIO)
+  @patch('stem.control.Controller.from_port', spec = Controller)
+  def test_list_circuits(self, from_port_mock, stdout_mock):
+    def tutorial_example():
+      from stem import CircStatus
+      from stem.control import Controller
+
+      with Controller.from_port(port = 9051) as controller:
+        controller.authenticate()
+
+        for circ in sorted(controller.get_circuits()):
+          if circ.status != CircStatus.BUILT:
+            continue
+
+          print
+          print "Circuit %s (%s)" % (circ.id, circ.purpose)
+
+          for i, entry in enumerate(circ.path):
+            div = '+' if (i == len(circ.path) - 1) else '|'
+            fingerprint, nickname = entry
+
+            desc = controller.get_network_status(fingerprint, None)
+            address = desc.address if desc else 'unknown'
+
+            print " %s- %s (%s, %s)" % (div, fingerprint, nickname, address)
+
+    path_1 = ('B1FA7D51B8B6F0CB585D944F450E7C06EDE7E44C', 'ByTORAndTheSnowDog')
+    path_2 = ('0DD9935C5E939CFA1E07B8DDA6D91C1A2A9D9338', 'afo02')
+    path_3 = ('DB3B1CFBD3E4D97B84B548ADD5B9A31451EEC4CC', 'edwardsnowden3')
+    path_4 = ('EC01CB4766BADC1611678555CE793F2A7EB2D723', 'sprockets')
+    path_5 = ('9EA317EECA56BDF30CAEB208A253FB456EDAB1A0', 'bolobolo1')
+    path_6 = ('00C2C2A16AEDB51D5E5FB7D6168FC66B343D822F', 'ph3x')
+    path_7 = ('65242C91BFF30F165DA4D132C81A9EBA94B71D62', 'torexit16')
+
+    circuit_4 = _get_event(4, 'BUILT', path_1, path_2, path_3, 'GENERAL')
+    circuit_6 = _get_event(6, 'BUILT', path_1, path_4, path_5, 'GENERAL')
+    circuit_10 = _get_event(10, 'BUILT', path_1, path_6, path_7, 'GENERAL')
+
+    controller = from_port_mock().__enter__()
+    controller.get_circuits.return_value = [circuit_4, circuit_6, circuit_10]
+    controller.get_network_status.side_effect = lambda fingerprint, *args: {
+      path_1[0]: _get_router_status("173.209.180.61"),
+      path_2[0]: _get_router_status("87.238.194.176"),
+      path_3[0]: _get_router_status("109.163.234.10"),
+      path_4[0]: _get_router_status("46.165.197.96"),
+      path_5[0]: _get_router_status("96.47.226.20"),
+      path_6[0]: _get_router_status("86.59.119.83"),
+      path_7[0]: _get_router_status("176.67.169.171")
+    }[fingerprint]
+    tutorial_example()
+    self.assertEqual(LIST_CIRCUITS_OUTPUT, stdout_mock.getvalue())





More information about the tor-commits mailing list