[tor-commits] [stem/master] Defaulting to consensus-method 1
atagar at torproject.org
atagar at torproject.org
Sat Oct 13 18:35:45 UTC 2012
commit 7218845d7bfce16b9ae4a0812cc74cd54b07f7c2
Author: Damian Johnson <atagar at torproject.org>
Date: Sun Sep 9 16:02:58 2012 -0700
Defaulting to consensus-method 1
As per the spec clarification in commit b829224, when the consensus-method or
consensus-methods fields are missing we should default to method 1 (since in
practice that's the only time the field doesn't appear).
---
stem/descriptor/networkstatus.py | 11 ++++++++++-
test/unit/descriptor/networkstatus/document.py | 14 +++++++++++++-
2 files changed, 23 insertions(+), 2 deletions(-)
diff --git a/stem/descriptor/networkstatus.py b/stem/descriptor/networkstatus.py
index beafe89..1efcf58 100644
--- a/stem/descriptor/networkstatus.py
+++ b/stem/descriptor/networkstatus.py
@@ -305,22 +305,31 @@ class NetworkStatusDocument(stem.descriptor.Descriptor):
raise ValueError("Expected a version 3 network status documents, got version '%s' instead" % self.version)
elif keyword == 'vote-status':
# "vote-status" type
+ #
+ # The consensus-method and consensus-methods fields are optional since
+ # they weren't included in version 1. Setting a default now that we
+ # know if we're a vote or not.
if value == 'consensus':
self.is_consensus, self.is_vote = True, False
+ self.consensus_method = 1
elif value == 'vote':
self.is_consensus, self.is_vote = False, True
+ self.consensus_methods = [1]
elif validate:
raise ValueError("A network status document's vote-status line can only be 'consensus' or 'vote', got '%s' instead" % value)
elif keyword == 'consensus-methods':
# "consensus-methods" IntegerList
+ consensus_methods = []
for entry in value.split(" "):
if entry.isdigit():
- self.consensus_methods.append(int(entry))
+ consensus_methods.append(int(entry))
elif validate:
raise ValueError("A network status document's consensus-methods must be a list of integer values, but was '%s'" % value)
+ self.consensus_methods = consensus_methods
+
if validate and not (1 in self.consensus_methods):
raise ValueError("Network status votes must include consensus-method version 1")
elif keyword == 'consensus-method':
diff --git a/test/unit/descriptor/networkstatus/document.py b/test/unit/descriptor/networkstatus/document.py
index 5e3ec4b..2deeb35 100644
--- a/test/unit/descriptor/networkstatus/document.py
+++ b/test/unit/descriptor/networkstatus/document.py
@@ -267,6 +267,12 @@ class TestNetworkStatusDocument(unittest.TestCase):
document = NetworkStatusDocument(content, False)
self.assertEquals(expected_consensus_methods, document.consensus_methods)
+
+ # check that we default to including consensus-method 1
+ content = get_network_status_document({"vote-status": "vote"}, ("consensus-methods",))
+ document = NetworkStatusDocument(content)
+ self.assertEquals([1], document.consensus_methods)
+ self.assertEquals(None, document.consensus_method)
def test_invalid_consensus_method(self):
"""
@@ -286,7 +292,13 @@ class TestNetworkStatusDocument(unittest.TestCase):
self.assertRaises(ValueError, NetworkStatusDocument, content)
document = NetworkStatusDocument(content, False)
- self.assertEquals(None, document.consensus_method)
+ self.assertEquals(1, document.consensus_method)
+
+ # check that we default to being consensus-method 1
+ content = get_network_status_document(exclude = ("consensus-method",))
+ document = NetworkStatusDocument(content)
+ self.assertEquals(1, document.consensus_method)
+ self.assertEquals([], document.consensus_methods)
def test_invalid_time_fields(self):
"""
More information about the tor-commits
mailing list