[Author Prev][Author Next][Thread Prev][Thread Next][Author Index][Thread Index]
[tor-commits] [stem/master] Tidying up event testing boilerplate
commit fb0aec5d95e9d2e6d64b7ab7c51018f3581565c5
Author: Damian Johnson <atagar@xxxxxxxxxxxxxx>
Date: Mon Dec 3 23:20:24 2012 -0800
Tidying up event testing boilerplate
Most event unit tests initially check two things...
* That the event class matches an expected value.
* That the string content for the event matches what we were constructed with.
Blending these two checks with the function that provides us with events.
---
test/unit/response/events.py | 302 +++++++++++++++++-------------------------
1 files changed, 119 insertions(+), 183 deletions(-)
diff --git a/test/unit/response/events.py b/test/unit/response/events.py
index 58aebb4..6fbd907 100644
--- a/test/unit/response/events.py
+++ b/test/unit/response/events.py
@@ -199,11 +199,6 @@ $B4BE08B22D4D2923EDC3970FD1B93D0448C6D8FF~Unnamed"
ADDRMAP = '650 ADDRMAP www.atagar.com 75.119.206.243 "2012-11-19 00:50:13" \
EXPIRES="2012-11-19 08:50:13"'
-def _get_event(content):
- controller_event = mocking.get_message(content)
- stem.response.convert("EVENT", controller_event, arrived_at = 25)
- return controller_event
-
class TestEvents(unittest.TestCase):
def test_example(self):
"""
@@ -219,7 +214,7 @@ class TestEvents(unittest.TestCase):
def event_sender():
for i in xrange(3):
- print_bw(_get_event("650 BW 15 25"))
+ print_bw(self._get_event("650 BW 15 25"))
time.sleep(0.05)
controller = mocking.get_object(Controller, {
@@ -236,29 +231,24 @@ class TestEvents(unittest.TestCase):
events_thread.join()
def test_log_events(self):
- event = _get_event("650 DEBUG connection_edge_process_relay_cell(): Got an extended cell! Yay.")
+ event = self._get_event("650 DEBUG connection_edge_process_relay_cell(): Got an extended cell! Yay.", stem.response.events.LogEvent)
- self.assertTrue(isinstance(event, stem.response.events.LogEvent))
self.assertEqual("DEBUG", event.runlevel)
self.assertEqual("connection_edge_process_relay_cell(): Got an extended cell! Yay.", event.message)
- event = _get_event("650 INFO circuit_finish_handshake(): Finished building circuit hop:")
+ event = self._get_event("650 INFO circuit_finish_handshake(): Finished building circuit hop:", stem.response.events.LogEvent)
- self.assertTrue(isinstance(event, stem.response.events.LogEvent))
self.assertEqual("INFO", event.runlevel)
self.assertEqual("circuit_finish_handshake(): Finished building circuit hop:", event.message)
- event = _get_event("650+WARN\na multi-line\nwarning message\n.\n650 OK\n")
+ event = self._get_event("650+WARN\na multi-line\nwarning message\n.\n650 OK\n", stem.response.events.LogEvent, False)
- self.assertTrue(isinstance(event, stem.response.events.LogEvent))
self.assertEqual("WARN", event.runlevel)
self.assertEqual("a multi-line\nwarning message", event.message)
def test_addrmap_event(self):
- event = _get_event(ADDRMAP)
+ event = self._get_event(ADDRMAP, stem.response.events.AddrMapEvent)
- self.assertTrue(isinstance(event, stem.response.events.AddrMapEvent))
- self.assertEqual(ADDRMAP.lstrip("650 "), str(event))
self.assertEqual("www.atagar.com", event.hostname)
self.assertEqual("75.119.206.243", event.destination)
self.assertEqual(datetime.datetime(2012, 11, 19, 0, 50, 13), event.expiry)
@@ -266,20 +256,16 @@ class TestEvents(unittest.TestCase):
self.assertEqual(datetime.datetime(2012, 11, 19, 8, 50, 13), event.utc_expiry)
def test_authdir_newdesc_event(self):
- # TODO: We aren't actually parsing the event yet. Until then we can only
- # check that we properly get a AuthDirNewDescEvent for it.
+ # TODO: awaiting test data - https://trac.torproject.org/7534
- event = _get_event("650+AUTHDIR_NEWDESCS\nAction\nMessage\nDescriptor\n.\n650 OK\n")
+ event = self._get_event("650+AUTHDIR_NEWDESCS\nAction\nMessage\nDescriptor\n.\n650 OK\n", stem.response.events.AuthDirNewDescEvent, False)
- self.assertTrue(isinstance(event, stem.response.events.AuthDirNewDescEvent))
self.assertEqual([], event.positional_args)
self.assertEqual({}, event.keyword_args)
def test_build_timeout_set_event(self):
- event = _get_event(BUILD_TIMEOUT_EVENT)
+ event = self._get_event(BUILD_TIMEOUT_EVENT, stem.response.events.BuildTimeoutSetEvent)
- self.assertTrue(isinstance(event, stem.response.events.BuildTimeoutSetEvent))
- self.assertEqual(BUILD_TIMEOUT_EVENT.lstrip("650 "), str(event))
self.assertEqual(TimeoutSetType.COMPUTED, event.set_type)
self.assertEqual(124, event.total_times)
self.assertEqual(9019, event.timeout)
@@ -291,13 +277,11 @@ class TestEvents(unittest.TestCase):
self.assertEqual(0.072581, event.close_rate)
def test_bw_event(self):
- event = _get_event("650 BW 15 25")
-
- self.assertTrue(isinstance(event, stem.response.events.BandwidthEvent))
+ event = self._get_event("650 BW 15 25", stem.response.events.BandwidthEvent)
self.assertEqual(15, event.read)
self.assertEqual(25, event.written)
- event = _get_event("650 BW 0 0")
+ event = self._get_event("650 BW 0 0")
self.assertEqual(0, event.read)
self.assertEqual(0, event.written)
@@ -306,21 +290,19 @@ class TestEvents(unittest.TestCase):
# since tor doesn't actually do it yet (and likely never will), but might
# as well sanity test that it'll be ok.
- event = _get_event("650 BW 10 20 OR=5 EXIT=500")
+ event = self._get_event("650 BW 10 20 OR=5 EXIT=500")
self.assertEqual(10, event.read)
self.assertEqual(20, event.written)
self.assertEqual({'OR': '5', 'EXIT': '500'}, event.keyword_args)
- self.assertRaises(ProtocolError, _get_event, "650 BW 15")
- self.assertRaises(ProtocolError, _get_event, "650 BW -15 25")
- self.assertRaises(ProtocolError, _get_event, "650 BW 15 -25")
- self.assertRaises(ProtocolError, _get_event, "650 BW x 25")
+ self.assertRaises(ProtocolError, self._get_event, "650 BW 15")
+ self.assertRaises(ProtocolError, self._get_event, "650 BW -15 25")
+ self.assertRaises(ProtocolError, self._get_event, "650 BW 15 -25")
+ self.assertRaises(ProtocolError, self._get_event, "650 BW x 25")
def test_circ_event(self):
- event = _get_event(CIRC_LAUNCHED)
+ event = self._get_event(CIRC_LAUNCHED, stem.response.events.CircuitEvent)
- self.assertTrue(isinstance(event, stem.response.events.CircuitEvent))
- self.assertEqual(CIRC_LAUNCHED.lstrip("650 "), str(event))
self.assertEqual("7", event.id)
self.assertEqual(CircStatus.LAUNCHED, event.status)
self.assertEqual((), event.path)
@@ -332,10 +314,8 @@ class TestEvents(unittest.TestCase):
self.assertEqual(None, event.reason)
self.assertEqual(None, event.remote_reason)
- event = _get_event(CIRC_EXTENDED)
+ event = self._get_event(CIRC_EXTENDED, stem.response.events.CircuitEvent)
- self.assertTrue(isinstance(event, stem.response.events.CircuitEvent))
- self.assertEqual(CIRC_EXTENDED.lstrip("650 "), str(event))
self.assertEqual("7", event.id)
self.assertEqual(CircStatus.EXTENDED, event.status)
self.assertEqual((("999A226EBED397F331B612FE1E4CFAE5C1F201BA", "piyaz"),), event.path)
@@ -347,10 +327,8 @@ class TestEvents(unittest.TestCase):
self.assertEqual(None, event.reason)
self.assertEqual(None, event.remote_reason)
- event = _get_event(CIRC_FAILED)
+ event = self._get_event(CIRC_FAILED, stem.response.events.CircuitEvent)
- self.assertTrue(isinstance(event, stem.response.events.CircuitEvent))
- self.assertEqual(CIRC_FAILED.lstrip("650 "), str(event))
self.assertEqual("5", event.id)
self.assertEqual(CircStatus.FAILED, event.status)
self.assertEqual((("E57A476CD4DFBD99B4EE52A100A58610AD6E80B9", "ergebnisoffen"),), event.path)
@@ -362,10 +340,8 @@ class TestEvents(unittest.TestCase):
self.assertEqual(CircClosureReason.DESTROYED, event.reason)
self.assertEqual(CircClosureReason.OR_CONN_CLOSED, event.remote_reason)
- event = _get_event(CIRC_LAUNCHED_OLD)
+ event = self._get_event(CIRC_LAUNCHED_OLD, stem.response.events.CircuitEvent)
- self.assertTrue(isinstance(event, stem.response.events.CircuitEvent))
- self.assertEqual(CIRC_LAUNCHED_OLD.lstrip("650 "), str(event))
self.assertEqual("4", event.id)
self.assertEqual(CircStatus.LAUNCHED, event.status)
self.assertEqual((), event.path)
@@ -377,10 +353,8 @@ class TestEvents(unittest.TestCase):
self.assertEqual(None, event.reason)
self.assertEqual(None, event.remote_reason)
- event = _get_event(CIRC_EXTENDED_OLD)
+ event = self._get_event(CIRC_EXTENDED_OLD, stem.response.events.CircuitEvent)
- self.assertTrue(isinstance(event, stem.response.events.CircuitEvent))
- self.assertEqual(CIRC_EXTENDED_OLD.lstrip("650 "), str(event))
self.assertEqual("1", event.id)
self.assertEqual(CircStatus.EXTENDED, event.status)
self.assertEqual((("E57A476CD4DFBD99B4EE52A100A58610AD6E80B9", None), (None,"hamburgerphone")), event.path)
@@ -392,10 +366,8 @@ class TestEvents(unittest.TestCase):
self.assertEqual(None, event.reason)
self.assertEqual(None, event.remote_reason)
- event = _get_event(CIRC_BUILT_OLD)
+ event = self._get_event(CIRC_BUILT_OLD, stem.response.events.CircuitEvent)
- self.assertTrue(isinstance(event, stem.response.events.CircuitEvent))
- self.assertEqual(CIRC_BUILT_OLD.lstrip("650 "), str(event))
self.assertEqual("1", event.id)
self.assertEqual(CircStatus.BUILT, event.status)
self.assertEqual((("E57A476CD4DFBD99B4EE52A100A58610AD6E80B9", None), (None,"hamburgerphone"), (None, "PrivacyRepublic14")), event.path)
@@ -408,19 +380,14 @@ class TestEvents(unittest.TestCase):
self.assertEqual(None, event.remote_reason)
def test_clients_seen_event(self):
- event = _get_event(CLIENTS_SEEN_EVENT)
-
- self.assertTrue(isinstance(event, stem.response.events.ClientsSeenEvent))
- self.assertEqual(CLIENTS_SEEN_EVENT.lstrip("650 "), str(event))
+ event = self._get_event(CLIENTS_SEEN_EVENT, stem.response.events.ClientsSeenEvent)
self.assertEqual(datetime.datetime(2008, 12, 25, 23, 50, 43), event.start_time)
self.assertEqual({'us': 16, 'de': 8, 'uk': 8}, event.locales)
self.assertEqual({'v4': 16, 'v6': 40}, event.ip_versions)
def test_circ_minor_event(self):
- event = _get_event(CIRC_MINOR_EVENT)
+ event = self._get_event(CIRC_MINOR_EVENT, stem.response.events.CircMinorEvent)
- self.assertTrue(isinstance(event, stem.response.events.CircMinorEvent))
- self.assertEqual(CIRC_MINOR_EVENT.lstrip("650 "), str(event))
self.assertEqual("7", event.id)
self.assertEqual(CircEvent.PURPOSE_CHANGED, event.event)
self.assertEqual((("67B2BDA4264D8A189D9270E28B1D30A262838243", "europa1"),), event.path)
@@ -433,79 +400,59 @@ class TestEvents(unittest.TestCase):
self.assertEqual(None, event.old_hs_state)
def test_conf_changed(self):
- event = _get_event(CONF_CHANGED_EVENT)
-
expected_config = {
'ExitNodes': 'caerSidi',
'MaxCircuitDirtiness': '20',
'ExitPolicy': None,
}
- self.assertTrue(isinstance(event, stem.response.events.ConfChangedEvent))
+ event = self._get_event(CONF_CHANGED_EVENT, stem.response.events.ConfChangedEvent, False)
self.assertEqual(expected_config, event.config)
def test_descchanged_event(self):
- # all we can check for is that the event is properly parsed as a
- # DescChangedEvent instance
-
- event = _get_event("650 DESCCHANGED")
-
- self.assertTrue(isinstance(event, stem.response.events.DescChangedEvent))
- self.assertEqual("DESCCHANGED", str(event))
- self.assertEqual([], event.positional_args)
- self.assertEqual({}, event.keyword_args)
+ self._get_event("650 DESCCHANGED", stem.response.events.DescChangedEvent)
def test_guard_event(self):
- event = _get_event(GUARD_NEW)
-
- self.assertTrue(isinstance(event, stem.response.events.GuardEvent))
- self.assertEqual(GUARD_NEW.lstrip("650 "), str(event))
+ event = self._get_event(GUARD_NEW, stem.response.events.GuardEvent)
self.assertEqual(GuardType.ENTRY, event.guard_type)
self.assertEqual("$36B5DBA788246E8369DBAF58577C6BC044A9A374", event.name)
self.assertEqual(GuardStatus.NEW, event.status)
- event = _get_event(GUARD_GOOD)
+ event = self._get_event(GUARD_GOOD, stem.response.events.GuardEvent)
self.assertEqual(GuardType.ENTRY, event.guard_type)
self.assertEqual("$5D0034A368E0ABAF663D21847E1C9B6CFA09752A", event.name)
self.assertEqual(GuardStatus.GOOD, event.status)
- event = _get_event(GUARD_BAD)
+ event = self._get_event(GUARD_BAD, stem.response.events.GuardEvent)
self.assertEqual(GuardType.ENTRY, event.guard_type)
self.assertEqual("$5D0034A368E0ABAF663D21847E1C9B6CFA09752A", event.name)
self.assertEqual(GuardStatus.BAD, event.status)
def test_newdesc_event(self):
- event = _get_event(NEWDESC_SINGLE)
- expected_relays = (("B3FA3110CC6F42443F039220C134CBD2FC4F0493", "Sakura"),)
+ event = self._get_event(NEWDESC_SINGLE, stem.response.events.NewDescEvent)
- self.assertTrue(isinstance(event, stem.response.events.NewDescEvent))
- self.assertEqual(NEWDESC_SINGLE.lstrip("650 "), str(event))
+ expected_relays = (("B3FA3110CC6F42443F039220C134CBD2FC4F0493", "Sakura"),)
self.assertEqual(expected_relays, event.relays)
- event = _get_event(NEWDESC_MULTIPLE)
expected_relays = (("BE938957B2CA5F804B3AFC2C1EE6673170CDBBF8", "Moonshine"),
("B4BE08B22D4D2923EDC3970FD1B93D0448C6D8FF", "Unnamed"))
- self.assertTrue(isinstance(event, stem.response.events.NewDescEvent))
- self.assertEqual(NEWDESC_MULTIPLE.lstrip("650 "), str(event))
+ event = self._get_event(NEWDESC_MULTIPLE, stem.response.events.NewDescEvent)
self.assertEqual(expected_relays, event.relays)
def test_new_consensus_event(self):
- expected_desc = []
-
- expected_desc.append(mocking.get_router_status_entry_v3({
- "r": "Beaver /96bKo4soysolMgKn5Hex2nyFSY pAJH9dSBp/CG6sPhhVY/5bLaVPM 2012-12-02 22:02:45 77.223.43.54 9001 0",
- "s": "Fast Named Running Stable Valid",
- }))
-
- expected_desc.append(mocking.get_router_status_entry_v3({
- "r": "Unnamed /+fJRWjmIGNAL2C5rRZHq3R91tA 7AnpZjfdBpYzXnMNm+w1bTsFF6Y 2012-12-02 17:51:10 91.121.184.87 9001 0",
- "s": "Fast Guard Running Stable Valid",
- }))
-
- event = _get_event(NEWCONSENSUS_EVENT)
-
- self.assertTrue(isinstance(event, stem.response.events.NewConsensusEvent))
+ expected_desc = [
+ mocking.get_router_status_entry_v3({
+ "r": "Beaver /96bKo4soysolMgKn5Hex2nyFSY pAJH9dSBp/CG6sPhhVY/5bLaVPM 2012-12-02 22:02:45 77.223.43.54 9001 0",
+ "s": "Fast Named Running Stable Valid",
+ }),
+ mocking.get_router_status_entry_v3({
+ "r": "Unnamed /+fJRWjmIGNAL2C5rRZHq3R91tA 7AnpZjfdBpYzXnMNm+w1bTsFF6Y 2012-12-02 17:51:10 91.121.184.87 9001 0",
+ "s": "Fast Guard Running Stable Valid",
+ }),
+ ]
+
+ event = self._get_event(NEWCONSENSUS_EVENT, stem.response.events.NewConsensusEvent, False)
self.assertEqual(expected_desc, event.desc)
def test_ns_event(self):
@@ -514,16 +461,12 @@ class TestEvents(unittest.TestCase):
"s": "Fast HSDir Named Stable V2Dir Valid",
})
- event = _get_event(NS_EVENT)
-
- self.assertTrue(isinstance(event, stem.response.events.NetworkStatusEvent))
+ event = self._get_event(NS_EVENT, stem.response.events.NetworkStatusEvent, False)
self.assertEqual([expected_desc], event.desc)
def test_orconn_event(self):
- event = _get_event(ORCONN_CONNECTED)
+ event = self._get_event(ORCONN_CONNECTED, stem.response.events.ORConnEvent)
- self.assertTrue(isinstance(event, stem.response.events.ORConnEvent))
- self.assertEqual(ORCONN_CONNECTED.lstrip("650 "), str(event))
self.assertEqual("$7ED90E2833EE38A75795BA9237B0A4560E51E1A0=GreenDragon", event.endpoint)
self.assertEqual("7ED90E2833EE38A75795BA9237B0A4560E51E1A0", event.endpoint_fingerprint)
self.assertEqual("GreenDragon", event.endpoint_nickname)
@@ -533,10 +476,8 @@ class TestEvents(unittest.TestCase):
self.assertEqual(None, event.reason)
self.assertEqual(None, event.circ_count)
- event = _get_event(ORCONN_CLOSED)
+ event = self._get_event(ORCONN_CLOSED, stem.response.events.ORConnEvent)
- self.assertTrue(isinstance(event, stem.response.events.ORConnEvent))
- self.assertEqual(ORCONN_CLOSED.lstrip("650 "), str(event))
self.assertEqual("$A1130635A0CDA6F60C276FBF6994EFBD4ECADAB1~tama", event.endpoint)
self.assertEqual("A1130635A0CDA6F60C276FBF6994EFBD4ECADAB1", event.endpoint_fingerprint)
self.assertEqual("tama", event.endpoint_nickname)
@@ -547,40 +488,32 @@ class TestEvents(unittest.TestCase):
self.assertEqual(None, event.circ_count)
def test_signal_event(self):
- event = _get_event("650 SIGNAL DEBUG")
- self.assertTrue(isinstance(event, stem.response.events.SignalEvent))
- self.assertEqual("SIGNAL DEBUG", str(event))
+ event = self._get_event("650 SIGNAL DEBUG", stem.response.events.SignalEvent)
self.assertEqual(Signal.DEBUG, event.signal)
- event = _get_event("650 SIGNAL DUMP")
+ event = self._get_event("650 SIGNAL DUMP", stem.response.events.SignalEvent)
self.assertEqual(Signal.DUMP, event.signal)
def test_status_event_consensus_arrived(self):
- event = _get_event(STATUS_CLIENT_CONSENSUS_ARRIVED)
-
- self.assertTrue(isinstance(event, stem.response.events.StatusEvent))
- self.assertEqual(STATUS_CLIENT_CONSENSUS_ARRIVED.lstrip("650 "), str(event))
+ event = self._get_event(STATUS_CLIENT_CONSENSUS_ARRIVED, stem.response.events.StatusEvent)
self.assertEqual(StatusType.CLIENT, event.status_type)
self.assertEqual(Runlevel.NOTICE, event.runlevel)
self.assertEqual("CONSENSUS_ARRIVED", event.action)
def test_status_event_enough_dir_info(self):
- event = _get_event(STATUS_CLIENT_ENOUGH_DIR_INFO)
-
+ event = self._get_event(STATUS_CLIENT_ENOUGH_DIR_INFO, stem.response.events.StatusEvent)
self.assertEqual(StatusType.CLIENT, event.status_type)
self.assertEqual(Runlevel.NOTICE, event.runlevel)
self.assertEqual("ENOUGH_DIR_INFO", event.action)
def test_status_event_circuit_established(self):
- event = _get_event(STATUS_CLIENT_CIRC_ESTABLISHED)
-
+ event = self._get_event(STATUS_CLIENT_CIRC_ESTABLISHED, stem.response.events.StatusEvent)
self.assertEqual(StatusType.CLIENT, event.status_type)
self.assertEqual(Runlevel.NOTICE, event.runlevel)
self.assertEqual("CIRCUIT_ESTABLISHED", event.action)
def test_status_event_bootstrap_descriptors(self):
- event = _get_event(STATUS_CLIENT_BOOTSTRAP_DESCRIPTORS)
-
+ event = self._get_event(STATUS_CLIENT_BOOTSTRAP_DESCRIPTORS, stem.response.events.StatusEvent)
self.assertEqual(StatusType.CLIENT, event.status_type)
self.assertEqual(Runlevel.NOTICE, event.runlevel)
self.assertEqual("BOOTSTRAP", event.action)
@@ -594,8 +527,7 @@ class TestEvents(unittest.TestCase):
self.assertEqual(expected_attr, event.keyword_args)
def test_status_event_bootstrap_stuck(self):
- event = _get_event(STATUS_CLIENT_BOOTSTRAP_STUCK)
-
+ event = self._get_event(STATUS_CLIENT_BOOTSTRAP_STUCK, stem.response.events.StatusEvent)
self.assertEqual(StatusType.CLIENT, event.status_type)
self.assertEqual(Runlevel.WARN, event.runlevel)
self.assertEqual("BOOTSTRAP", event.action)
@@ -613,8 +545,7 @@ class TestEvents(unittest.TestCase):
self.assertEqual(expected_attr, event.keyword_args)
def test_status_event_bootstrap_connecting(self):
- event = _get_event(STATUS_CLIENT_BOOTSTRAP_CONNECTING)
-
+ event = self._get_event(STATUS_CLIENT_BOOTSTRAP_CONNECTING, stem.response.events.StatusEvent)
self.assertEqual(StatusType.CLIENT, event.status_type)
self.assertEqual(Runlevel.NOTICE, event.runlevel)
self.assertEqual("BOOTSTRAP", event.action)
@@ -628,8 +559,7 @@ class TestEvents(unittest.TestCase):
self.assertEqual(expected_attr, event.keyword_args)
def test_status_event_bootstrap_first_handshake(self):
- event = _get_event(STATUS_CLIENT_BOOTSTRAP_FIRST_HANDSHAKE)
-
+ event = self._get_event(STATUS_CLIENT_BOOTSTRAP_FIRST_HANDSHAKE, stem.response.events.StatusEvent)
self.assertEqual(StatusType.CLIENT, event.status_type)
self.assertEqual(Runlevel.NOTICE, event.runlevel)
self.assertEqual("BOOTSTRAP", event.action)
@@ -643,8 +573,7 @@ class TestEvents(unittest.TestCase):
self.assertEqual(expected_attr, event.keyword_args)
def test_status_event_bootstrap_established(self):
- event = _get_event(STATUS_CLIENT_BOOTSTRAP_ESTABLISHED)
-
+ event = self._get_event(STATUS_CLIENT_BOOTSTRAP_ESTABLISHED, stem.response.events.StatusEvent)
self.assertEqual(StatusType.CLIENT, event.status_type)
self.assertEqual(Runlevel.NOTICE, event.runlevel)
self.assertEqual("BOOTSTRAP", event.action)
@@ -658,8 +587,7 @@ class TestEvents(unittest.TestCase):
self.assertEqual(expected_attr, event.keyword_args)
def test_status_event_bootstrap_done(self):
- event = _get_event(STATUS_CLIENT_BOOTSTRAP_DONE)
-
+ event = self._get_event(STATUS_CLIENT_BOOTSTRAP_DONE, stem.response.events.StatusEvent)
self.assertEqual(StatusType.CLIENT, event.status_type)
self.assertEqual(Runlevel.NOTICE, event.runlevel)
self.assertEqual("BOOTSTRAP", event.action)
@@ -673,8 +601,7 @@ class TestEvents(unittest.TestCase):
self.assertEqual(expected_attr, event.keyword_args)
def test_status_event_bootstrap_check_reachability(self):
- event = _get_event(STATUS_SERVER_CHECK_REACHABILITY)
-
+ event = self._get_event(STATUS_SERVER_CHECK_REACHABILITY, stem.response.events.StatusEvent)
self.assertEqual(StatusType.SERVER, event.status_type)
self.assertEqual(Runlevel.NOTICE, event.runlevel)
self.assertEqual("CHECKING_REACHABILITY", event.action)
@@ -686,8 +613,7 @@ class TestEvents(unittest.TestCase):
self.assertEqual(expected_attr, event.keyword_args)
def test_status_event_dns_timeout(self):
- event = _get_event(STATUS_SERVER_DNS_TIMEOUT)
-
+ event = self._get_event(STATUS_SERVER_DNS_TIMEOUT, stem.response.events.StatusEvent)
self.assertEqual(StatusType.SERVER, event.status_type)
self.assertEqual(Runlevel.NOTICE, event.runlevel)
self.assertEqual("NAMESERVER_STATUS", event.action)
@@ -701,15 +627,13 @@ class TestEvents(unittest.TestCase):
self.assertEqual(expected_attr, event.keyword_args)
def test_status_event_dns_down(self):
- event = _get_event(STATUS_SERVER_DNS_DOWN)
-
+ event = self._get_event(STATUS_SERVER_DNS_DOWN, stem.response.events.StatusEvent)
self.assertEqual(StatusType.SERVER, event.status_type)
self.assertEqual(Runlevel.WARN, event.runlevel)
self.assertEqual("NAMESERVER_ALL_DOWN", event.action)
def test_status_event_dns_up(self):
- event = _get_event(STATUS_SERVER_DNS_UP)
-
+ event = self._get_event(STATUS_SERVER_DNS_UP, stem.response.events.StatusEvent)
self.assertEqual(StatusType.SERVER, event.status_type)
self.assertEqual(Runlevel.NOTICE, event.runlevel)
self.assertEqual("NAMESERVER_STATUS", event.action)
@@ -721,11 +645,9 @@ class TestEvents(unittest.TestCase):
self.assertEqual(expected_attr, event.keyword_args)
- def test_stream_event(self):
- event = _get_event(STREAM_NEW)
+ def test_stream_event_new(self):
+ event = self._get_event(STREAM_NEW, stem.response.events.StreamEvent)
- self.assertTrue(isinstance(event, stem.response.events.StreamEvent))
- self.assertEqual(STREAM_NEW.lstrip("650 "), str(event))
self.assertEqual("18", event.id)
self.assertEqual(StreamStatus.NEW, event.status)
self.assertEqual(None, event.circ_id)
@@ -739,11 +661,10 @@ class TestEvents(unittest.TestCase):
self.assertEqual("127.0.0.1", event.source_address)
self.assertEqual(47849, event.source_port)
self.assertEqual(StreamPurpose.USER, event.purpose)
+
+ def test_stream_event_sent_connect(self):
+ event = self._get_event(STREAM_SENTCONNECT, stem.response.events.StreamEvent)
- event = _get_event(STREAM_SENTCONNECT)
-
- self.assertTrue(isinstance(event, stem.response.events.StreamEvent))
- self.assertEqual(STREAM_SENTCONNECT.lstrip("650 "), str(event))
self.assertEqual("18", event.id)
self.assertEqual(StreamStatus.SENTCONNECT, event.status)
self.assertEqual("26", event.circ_id)
@@ -757,11 +678,10 @@ class TestEvents(unittest.TestCase):
self.assertEqual(None, event.source_address)
self.assertEqual(None, event.source_port)
self.assertEqual(None, event.purpose)
+
+ def test_stream_event_remap(self):
+ event = self._get_event(STREAM_REMAP, stem.response.events.StreamEvent)
- event = _get_event(STREAM_REMAP)
-
- self.assertTrue(isinstance(event, stem.response.events.StreamEvent))
- self.assertEqual(STREAM_REMAP.lstrip("650 "), str(event))
self.assertEqual("18", event.id)
self.assertEqual(StreamStatus.REMAP, event.status)
self.assertEqual("26", event.circ_id)
@@ -775,11 +695,10 @@ class TestEvents(unittest.TestCase):
self.assertEqual(None, event.source_address)
self.assertEqual(None, event.source_port)
self.assertEqual(None, event.purpose)
+
+ def test_stream_event_succeeded(self):
+ event = self._get_event(STREAM_SUCCEEDED, stem.response.events.StreamEvent)
- event = _get_event(STREAM_SUCCEEDED)
-
- self.assertTrue(isinstance(event, stem.response.events.StreamEvent))
- self.assertEqual(STREAM_SUCCEEDED.lstrip("650 "), str(event))
self.assertEqual("18", event.id)
self.assertEqual(StreamStatus.SUCCEEDED, event.status)
self.assertEqual("26", event.circ_id)
@@ -793,11 +712,10 @@ class TestEvents(unittest.TestCase):
self.assertEqual(None, event.source_address)
self.assertEqual(None, event.source_port)
self.assertEqual(None, event.purpose)
+
+ def test_stream_event_closed_reset(self):
+ event = self._get_event(STREAM_CLOSED_RESET, stem.response.events.StreamEvent)
- event = _get_event(STREAM_CLOSED_RESET)
-
- self.assertTrue(isinstance(event, stem.response.events.StreamEvent))
- self.assertEqual(STREAM_CLOSED_RESET.lstrip("650 "), str(event))
self.assertEqual("21", event.id)
self.assertEqual(StreamStatus.CLOSED, event.status)
self.assertEqual("26", event.circ_id)
@@ -811,11 +729,10 @@ class TestEvents(unittest.TestCase):
self.assertEqual(None, event.source_address)
self.assertEqual(None, event.source_port)
self.assertEqual(None, event.purpose)
+
+ def test_stream_event_closed_done(self):
+ event = self._get_event(STREAM_CLOSED_DONE, stem.response.events.StreamEvent)
- event = _get_event(STREAM_CLOSED_DONE)
-
- self.assertTrue(isinstance(event, stem.response.events.StreamEvent))
- self.assertEqual(STREAM_CLOSED_DONE.lstrip("650 "), str(event))
self.assertEqual("25", event.id)
self.assertEqual(StreamStatus.CLOSED, event.status)
self.assertEqual("26", event.circ_id)
@@ -829,11 +746,10 @@ class TestEvents(unittest.TestCase):
self.assertEqual(None, event.source_address)
self.assertEqual(None, event.source_port)
self.assertEqual(None, event.purpose)
+
+ def test_stream_event_dir_fetch(self):
+ event = self._get_event(STREAM_DIR_FETCH, stem.response.events.StreamEvent)
- event = _get_event(STREAM_DIR_FETCH)
-
- self.assertTrue(isinstance(event, stem.response.events.StreamEvent))
- self.assertEqual(STREAM_DIR_FETCH.lstrip("650 "), str(event))
self.assertEqual("14", event.id)
self.assertEqual(StreamStatus.NEW, event.status)
self.assertEqual(None, event.circ_id)
@@ -847,11 +763,10 @@ class TestEvents(unittest.TestCase):
self.assertEqual("(Tor_internal)", event.source_address)
self.assertEqual(0, event.source_port)
self.assertEqual(StreamPurpose.DIR_FETCH, event.purpose)
+
+ def test_stream_event_dns_request(self):
+ event = self._get_event(STREAM_DNS_REQUEST, stem.response.events.StreamEvent)
- event = _get_event(STREAM_DNS_REQUEST)
-
- self.assertTrue(isinstance(event, stem.response.events.StreamEvent))
- self.assertEqual(STREAM_DNS_REQUEST.lstrip("650 "), str(event))
self.assertEqual("1113", event.id)
self.assertEqual(StreamStatus.NEW, event.status)
self.assertEqual(None, event.circ_id)
@@ -867,26 +782,24 @@ class TestEvents(unittest.TestCase):
self.assertEqual(StreamPurpose.DNS_REQUEST, event.purpose)
def test_stream_bw_event(self):
- event = _get_event("650 STREAM_BW 2 15 25")
-
- self.assertTrue(isinstance(event, stem.response.events.StreamBwEvent))
+ event = self._get_event("650 STREAM_BW 2 15 25", stem.response.events.StreamBwEvent)
self.assertEqual("2", event.id)
self.assertEqual(15, event.written)
self.assertEqual(25, event.read)
- event = _get_event("650 STREAM_BW Stream02 0 0")
+ event = self._get_event("650 STREAM_BW Stream02 0 0")
self.assertEqual("Stream02", event.id)
self.assertEqual(0, event.written)
self.assertEqual(0, event.read)
- self.assertRaises(ProtocolError, _get_event, "650 STREAM_BW")
- self.assertRaises(ProtocolError, _get_event, "650 STREAM_BW 2")
- self.assertRaises(ProtocolError, _get_event, "650 STREAM_BW 2 15")
- self.assertRaises(ProtocolError, _get_event, "650 STREAM_BW - 15 25")
- self.assertRaises(ProtocolError, _get_event, "650 STREAM_BW 12345678901234567 15 25")
- self.assertRaises(ProtocolError, _get_event, "650 STREAM_BW 2 -15 25")
- self.assertRaises(ProtocolError, _get_event, "650 STREAM_BW 2 15 -25")
- self.assertRaises(ProtocolError, _get_event, "650 STREAM_BW 2 x 25")
+ self.assertRaises(ProtocolError, self._get_event, "650 STREAM_BW")
+ self.assertRaises(ProtocolError, self._get_event, "650 STREAM_BW 2")
+ self.assertRaises(ProtocolError, self._get_event, "650 STREAM_BW 2 15")
+ self.assertRaises(ProtocolError, self._get_event, "650 STREAM_BW - 15 25")
+ self.assertRaises(ProtocolError, self._get_event, "650 STREAM_BW 12345678901234567 15 25")
+ self.assertRaises(ProtocolError, self._get_event, "650 STREAM_BW 2 -15 25")
+ self.assertRaises(ProtocolError, self._get_event, "650 STREAM_BW 2 15 -25")
+ self.assertRaises(ProtocolError, self._get_event, "650 STREAM_BW 2 x 25")
def test_unrecognized_enum_logging(self):
"""
@@ -900,17 +813,40 @@ class TestEvents(unittest.TestCase):
# Try parsing a valid event. We shouldn't log anything.
- _get_event(STATUS_CLIENT_CONSENSUS_ARRIVED)
+ self._get_event(STATUS_CLIENT_CONSENSUS_ARRIVED)
self.assertTrue(logging_buffer.is_empty())
self.assertEqual([], list(logging_buffer))
# Parse an invalid runlevel.
- _get_event(STATUS_CLIENT_CONSENSUS_ARRIVED.replace("NOTICE", "OMEGA_CRITICAL!!!"))
+ self._get_event(STATUS_CLIENT_CONSENSUS_ARRIVED.replace("NOTICE", "OMEGA_CRITICAL!!!"))
logged_events = list(logging_buffer)
self.assertEqual(1, len(logged_events))
self.assertTrue("STATUS_CLIENT event had an unrecognized runlevel" in logged_events[0])
stem_logger.removeHandler(logging_buffer)
+
+ def _get_event(self, content, assert_class = None, assert_content = True):
+ """
+ Provides an :class:`~stem.response.events.Event` subclass for the given
+ content.
+
+ :param str content: content to create an event from
+ :param class assert_class: assert that the response is an instance of this class
+ :param bool assert_content: check the event's string content if **True**
+
+ :raises: :class:`stem.ProtocolError` if a problem arises in parsing the event
+ """
+
+ controller_event = mocking.get_message(content)
+ stem.response.convert("EVENT", controller_event, arrived_at = 25)
+
+ if assert_class:
+ self.assertTrue(isinstance(controller_event, assert_class))
+
+ if assert_content:
+ self.assertEqual(content.lstrip("650 "), str(controller_event))
+
+ return controller_event
_______________________________________________
tor-commits mailing list
tor-commits@xxxxxxxxxxxxxxxxxxxx
https://lists.torproject.org/cgi-bin/mailman/listinfo/tor-commits