commit 860cd87212d6caca7f23423940ed1807cf3f0f84 Author: Damian Johnson atagar@torproject.org Date: Sun Jun 10 13:58:23 2012 -0700
Integ test with bridge extra-info content
Adding a bridge extra-info descriptor from metrics. I'm currently being a bit lazy and only parsing some of the mapping fields. The rest should be covered by unit tests, so I'll only add the rest if this ends up bitting us. --- stem/descriptor/extrainfo_descriptor.py | 2 +- .../descriptor/data/extrainfo_bridge_descriptor | 22 ++++++ test/integ/descriptor/data/extrainfo_descriptor | 13 --- .../descriptor/data/extrainfo_relay_descriptor | 13 +++ test/integ/descriptor/extrainfo_descriptor.py | 78 +++++++++++++++++++- 5 files changed, 112 insertions(+), 16 deletions(-)
diff --git a/stem/descriptor/extrainfo_descriptor.py b/stem/descriptor/extrainfo_descriptor.py index 0515099..257b747 100644 --- a/stem/descriptor/extrainfo_descriptor.py +++ b/stem/descriptor/extrainfo_descriptor.py @@ -727,7 +727,7 @@ class BridgeExtraInfoDescriptor(ExtraInfoDescriptor): "router-signature", )
- filter(lambda e: not e in excluded_fields, REQUIRED_FIELDS) + return filter(lambda e: not e in excluded_fields, REQUIRED_FIELDS)
def _last_keyword(self): return None diff --git a/test/integ/descriptor/data/extrainfo_bridge_descriptor b/test/integ/descriptor/data/extrainfo_bridge_descriptor new file mode 100644 index 0000000..e78c354 --- /dev/null +++ b/test/integ/descriptor/data/extrainfo_bridge_descriptor @@ -0,0 +1,22 @@ +@type bridge-extra-info 1.0 +extra-info ec2bridgereaac65a3 1EC248422B57D9C0BD751892FE787585407479A4 +published 2012-06-08 02:21:27 +write-history 2012-06-08 02:10:38 (900 s) 343040,991232,5649408,49548288,24411136,486400,465920,975872,930816,758784,5650432,1844224,4387840,7417856,789504,623616,7376896,3940352,10039296,6054912,2051072,462848,4260864,5298176,500736,717824,714752,1370112,760832,576512,1521664,3986432,724992,615424,7079936,20995072,17465344,2592768,1014784,3082240,11468800,2770944,5660672,7646208,3385344,5404672,1158144,7741440,3275776,5239808,5291008,2197504,6070272,4919296,1180672,2245632,2362368,1641472,6153216,4660224,9184256,1488896,9736192,768000,65536,176128,2268160,3023872,704512,905216,866304,2375680,3688448,5181440,5433344,5259264,8285184,9391104,7015424,7180288,3436544,3713024,4473856,10705920,10529792,3154944,1815552,3443712,4566016,2668544,2688000,2391040,3181568,2749440,3214336,8974336 +read-history 2012-06-08 02:10:38 (900 s) 337920,437248,3995648,48726016,24125440,479232,477184,1010688,988160,772096,6388736,776192,3093504,7187456,787456,657408,7360512,3588096,9319424,5211136,2034688,474112,4222976,5154816,490496,1878016,610304,757760,667648,593920,1484800,3638272,1307648,672768,6614016,19262464,14863360,2612224,525312,1494016,11119616,3160064,1986560,5619712,3290112,5457920,1145856,7060480,3262464,5570560,5933056,2245632,4548608,3614720,829440,1765376,2379776,2531328,4306944,4244480,9225216,1054720,9806848,880640,66560,192512,2135040,3038208,830464,804864,941056,2386944,3660800,4835328,6406144,5152768,8714240,9145344,6902784,6781952,3648512,3876864,5474304,9958400,10851328,3322880,2239488,4790272,4343808,2404352,2615296,1551360,3295232,2869248,2924544,4941824 +dirreq-write-history 2012-06-08 02:10:38 (900 s) 5120,664576,2419712,578560,3072,5120,5120,3072,11264,5120,54272,1130496,1381376,202752,47104,0,6144,1064960,716800,835584,2048,0,3072,128000,4096,1024,222208,604160,129024,7168,118784,353280,0,0,761856,2236416,2574336,3072,526336,2037760,214016,726016,3592192,2205696,134144,1024,86016,656384,8192,9216,402432,14336,1617920,1436672,445440,481280,7168,1024,1959936,442368,14336,544768,4096,1024,0,4096,1052672,78848,0,223232,51200,5120,5120,1191936,1024,579584,2048,231424,68608,1305600,38912,4096,8192,1433600,5120,4096,330752,574464,382976,225280,940032,1185792,6144,1024,374784,4173824 +dirreq-read-history 2012-06-08 02:10:38 (900 s) 0,71680,99328,25600,0,0,0,0,0,0,3072,45056,74752,13312,2048,0,0,69632,18432,39936,0,0,0,8192,0,0,16384,25600,9216,0,7168,8192,0,0,96256,92160,138240,0,18432,128000,0,81920,149504,113664,8192,0,11264,46080,2048,0,25600,0,75776,77824,0,6144,19456,0,58368,14336,0,21504,0,0,0,0,25600,6144,0,0,5120,4096,0,54272,0,23552,0,0,4096,64512,2048,0,0,34816,0,0,6144,8192,10240,0,31744,48128,0,0,10240,236544 +geoip-db-digest A27BE984989AB31C50D0861C7106B17A7EEC3756 +dirreq-stats-end 2012-06-07 06:33:46 (86400 s) +dirreq-v3-ips +dirreq-v2-ips +dirreq-v3-reqs +dirreq-v2-reqs +dirreq-v3-resp ok=72,not-enough-sigs=0,unavailable=0,not-found=0,not-modified=0,busy=0 +dirreq-v2-resp ok=0,unavailable=0,not-found=0,not-modified=0,busy=0 +dirreq-v3-direct-dl complete=0,timeout=0,running=0 +dirreq-v2-direct-dl complete=0,timeout=0,running=0 +dirreq-v3-tunneled-dl complete=68,timeout=4,running=0,min=2626,d1=7795,d2=14369,q1=18695,d3=29117,d4=52562,md=70626,d6=102271,d7=164175,q3=181522,d8=271682,d9=563791,max=32136142 +dirreq-v2-tunneled-dl complete=0,timeout=0,running=0 +bridge-stats-end 2012-06-07 06:33:53 (86400 s) +bridge-ips cn=16,ir=16,sy=16,us=16,??=8,bn=8,br=8,by=8,cu=8,dk=8,dz=8,es=8,lb=8,ph=8,sd=8,tw=8 +router-digest 00A2AECCEAD3FEE033CFE29893387143146728EC diff --git a/test/integ/descriptor/data/extrainfo_descriptor b/test/integ/descriptor/data/extrainfo_descriptor deleted file mode 100644 index ecaabe0..0000000 --- a/test/integ/descriptor/data/extrainfo_descriptor +++ /dev/null @@ -1,13 +0,0 @@ -@type extra-info 1.0 -extra-info NINJA B2289C3EAB83ECD6EB916A2F481A02E6B76A0A48 -published 2012-05-05 17:03:50 -write-history 2012-05-05 17:02:45 (900 s) 1082368,19456,50176,272384,485376,1850368,1132544,1790976,2459648,4091904,6310912,13701120,3209216,3871744,7873536,5440512,7287808,10561536,9979904,11247616,11982848,7590912,10611712,20728832,38534144,6839296,3173376,16678912 -read-history 2012-05-05 17:02:45 (900 s) 3309568,9216,41984,27648,123904,2004992,364544,576512,1607680,3808256,4672512,12783616,2938880,2562048,7348224,3574784,6488064,10954752,9359360,4438016,6286336,6438912,4502528,10720256,38165504,1524736,2336768,8186880 -dirreq-write-history 2012-05-05 17:02:45 (900 s) 0,0,0,227328,349184,382976,738304,1171456,850944,657408,1675264,987136,702464,1335296,587776,1941504,893952,533504,695296,6828032,6326272,1287168,6310912,10085376,1048576,5372928,894976,8610816 -dirreq-read-history 2012-05-05 17:02:45 (900 s) 0,0,0,0,33792,27648,48128,46080,60416,51200,63488,64512,45056,27648,37888,48128,57344,34816,46080,50176,37888,51200,25600,33792,39936,32768,28672,30720 -router-signature ------BEGIN SIGNATURE----- -K5FSywk7qvw/boA4DQcqkls6Ize5vcBYfhQ8JnOeRQC9+uDxbnpm3qaYN9jZ8myj -k0d2aofcVbHr4fPQOSST0LXDrhFl5Fqo5um296zpJGvRUeO6S44U/EfJAGShtqWw -7LZqklu+gVvhMKREpchVqlAwXkWR44VENm24Hs+mT3M= ------END SIGNATURE----- diff --git a/test/integ/descriptor/data/extrainfo_relay_descriptor b/test/integ/descriptor/data/extrainfo_relay_descriptor new file mode 100644 index 0000000..ecaabe0 --- /dev/null +++ b/test/integ/descriptor/data/extrainfo_relay_descriptor @@ -0,0 +1,13 @@ +@type extra-info 1.0 +extra-info NINJA B2289C3EAB83ECD6EB916A2F481A02E6B76A0A48 +published 2012-05-05 17:03:50 +write-history 2012-05-05 17:02:45 (900 s) 1082368,19456,50176,272384,485376,1850368,1132544,1790976,2459648,4091904,6310912,13701120,3209216,3871744,7873536,5440512,7287808,10561536,9979904,11247616,11982848,7590912,10611712,20728832,38534144,6839296,3173376,16678912 +read-history 2012-05-05 17:02:45 (900 s) 3309568,9216,41984,27648,123904,2004992,364544,576512,1607680,3808256,4672512,12783616,2938880,2562048,7348224,3574784,6488064,10954752,9359360,4438016,6286336,6438912,4502528,10720256,38165504,1524736,2336768,8186880 +dirreq-write-history 2012-05-05 17:02:45 (900 s) 0,0,0,227328,349184,382976,738304,1171456,850944,657408,1675264,987136,702464,1335296,587776,1941504,893952,533504,695296,6828032,6326272,1287168,6310912,10085376,1048576,5372928,894976,8610816 +dirreq-read-history 2012-05-05 17:02:45 (900 s) 0,0,0,0,33792,27648,48128,46080,60416,51200,63488,64512,45056,27648,37888,48128,57344,34816,46080,50176,37888,51200,25600,33792,39936,32768,28672,30720 +router-signature +-----BEGIN SIGNATURE----- +K5FSywk7qvw/boA4DQcqkls6Ize5vcBYfhQ8JnOeRQC9+uDxbnpm3qaYN9jZ8myj +k0d2aofcVbHr4fPQOSST0LXDrhFl5Fqo5um296zpJGvRUeO6S44U/EfJAGShtqWw +7LZqklu+gVvhMKREpchVqlAwXkWR44VENm24Hs+mT3M= +-----END SIGNATURE----- diff --git a/test/integ/descriptor/extrainfo_descriptor.py b/test/integ/descriptor/extrainfo_descriptor.py index 2739985..68b857b 100644 --- a/test/integ/descriptor/extrainfo_descriptor.py +++ b/test/integ/descriptor/extrainfo_descriptor.py @@ -9,14 +9,15 @@ import unittest import stem.descriptor.extrainfo_descriptor import test.runner import test.integ.descriptor +from stem.descriptor.extrainfo_descriptor import DirResponses
class TestExtraInfoDescriptor(unittest.TestCase): - def test_metrics_descriptor(self): + def test_metrics_relay_descriptor(self): """ Parses and checks our results against an extrainfo descriptor from metrics. """
- descriptor_path = test.integ.descriptor.get_resource("extrainfo_descriptor") + descriptor_path = test.integ.descriptor.get_resource("extrainfo_relay_descriptor")
descriptor_file = open(descriptor_path) descriptor_file.readline() # strip header @@ -60,6 +61,79 @@ k0d2aofcVbHr4fPQOSST0LXDrhFl5Fqo5um296zpJGvRUeO6S44U/EfJAGShtqWw dir_write_values_start = [0, 0, 0, 227328, 349184, 382976, 738304] self.assertEquals(dir_write_values_start, desc.dir_write_history_values[:7])
+ def test_metrics_bridge_descriptor(self): + """ + Parses and checks our results against an extrainfo bridge descriptor from + metrics. + """ + + descriptor_path = test.integ.descriptor.get_resource("extrainfo_bridge_descriptor") + + descriptor_file = open(descriptor_path) + descriptor_file.readline() # strip header + descriptor_contents = descriptor_file.read() + descriptor_file.close() + + expected_dir_v2_responses = { + DirResponses.OK: 0, + DirResponses.UNAVAILABLE: 0, + DirResponses.NOT_FOUND: 0, + DirResponses.NOT_MODIFIED: 0, + DirResponses.BUSY: 0, + } + + expected_dir_v3_responses = { + DirResponses.OK: 72, + DirResponses.NOT_ENOUGH_SIGS: 0, + DirResponses.UNAVAILABLE: 0, + DirResponses.NOT_FOUND: 0, + DirResponses.NOT_MODIFIED: 0, + DirResponses.BUSY: 0, + } + + expected_signature = """-----BEGIN SIGNATURE----- +K5FSywk7qvw/boA4DQcqkls6Ize5vcBYfhQ8JnOeRQC9+uDxbnpm3qaYN9jZ8myj +k0d2aofcVbHr4fPQOSST0LXDrhFl5Fqo5um296zpJGvRUeO6S44U/EfJAGShtqWw +7LZqklu+gVvhMKREpchVqlAwXkWR44VENm24Hs+mT3M= +-----END SIGNATURE-----""" + + desc = stem.descriptor.extrainfo_descriptor.BridgeExtraInfoDescriptor(descriptor_contents) + self.assertEquals("ec2bridgereaac65a3", desc.nickname) + self.assertEquals("1EC248422B57D9C0BD751892FE787585407479A4", desc.fingerprint) + self.assertEquals(datetime.datetime(2012, 6, 8, 2, 21, 27), desc.published) + self.assertEquals(datetime.datetime(2012, 6, 8, 2, 10, 38), desc.read_history_end) + self.assertEquals(900, desc.read_history_interval) + self.assertEquals(datetime.datetime(2012, 6, 8, 2, 10, 38), desc.write_history_end) + self.assertEquals(900, desc.write_history_interval) + self.assertEquals(datetime.datetime(2012, 6, 8, 2, 10, 38), desc.dir_read_history_end) + self.assertEquals(900, desc.dir_read_history_interval) + self.assertEquals(datetime.datetime(2012, 6, 8, 2, 10, 38), desc.dir_write_history_end) + self.assertEquals(900, desc.dir_write_history_interval) + + # TODO: uncomment when we handle router-digest entries + #self.assertEquals([], desc.get_unrecognized_lines()) + + read_values_start = [337920, 437248, 3995648, 48726016] + self.assertEquals(read_values_start, desc.read_history_values[:4]) + + write_values_start = [343040, 991232, 5649408, 49548288] + self.assertEquals(write_values_start, desc.write_history_values[:4]) + + dir_read_values_start = [0, 71680, 99328, 25600] + self.assertEquals(dir_read_values_start, desc.dir_read_history_values[:4]) + + dir_write_values_start = [5120, 664576, 2419712, 578560] + self.assertEquals(dir_write_values_start, desc.dir_write_history_values[:4]) + + self.assertEquals({}, desc.dir_v2_requests) + self.assertEquals({}, desc.dir_v3_requests) + + self.assertEquals(expected_dir_v2_responses, desc.dir_v2_responses) + self.assertEquals(expected_dir_v3_responses, desc.dir_v3_responses) + + self.assertEquals({}, desc.dir_v2_responses_unknown) + self.assertEquals({}, desc.dir_v2_responses_unknown) + def test_cached_descriptor(self): """ Parses the cached descriptor file in our data directory, checking that it