[tor-commits] [stem/master] Initial approach to keep track of new Tor capabilities
atagar at torproject.org
atagar at torproject.org
Mon Mar 23 01:28:54 UTC 2015
commit c5acd3043a4a467039ff3377cf9a472b2d24addb
Author: Cristóbal <cristobal.leiva at usach.cl>
Date: Sat Mar 7 16:12:57 2015 -0300
Initial approach to keep track of new Tor capabilities
---
run_tests.py | 14 ++++++++++++++
test/integ/descriptor/server_descriptor.py | 8 +++++++-
test/util.py | 11 +++++++++++
3 files changed, 32 insertions(+), 1 deletion(-)
diff --git a/run_tests.py b/run_tests.py
index e447866..70e0648 100755
--- a/run_tests.py
+++ b/run_tests.py
@@ -287,6 +287,20 @@ def main():
println('%i TESTS WERE SKIPPED' % skipped_tests, STATUS)
println('TESTING PASSED %s\n' % runtime_label, SUCCESS)
+
+ new_capabilities = test.util.check_new_capabilities()
+
+ if new_capabilities:
+ println()
+
+ println('Your version of tor has capabilities stem presently isn\'t taking advantage of. If you\'re running the latest version of stem then please file a ticket on...\n', ERROR)
+ println('https://trac.torproject.org/projects/tor/wiki/doc/stem/bugs', ERROR)
+ println('\nNew capabilities are...\n', ERROR)
+
+ for item in new_capabilities:
+ println('%s: %s' % (new_capabilities[item], item), ERROR)
+
+ println()
sys.exit(1 if error_tracker.has_errors_occured() else 0)
diff --git a/test/integ/descriptor/server_descriptor.py b/test/integ/descriptor/server_descriptor.py
index 6d5d348..74f8afd 100644
--- a/test/integ/descriptor/server_descriptor.py
+++ b/test/integ/descriptor/server_descriptor.py
@@ -11,6 +11,8 @@ import test.runner
from test.runner import only_run_once
+import test.util
+
class TestServerDescriptor(unittest.TestCase):
@only_run_once
@@ -43,5 +45,9 @@ class TestServerDescriptor(unittest.TestCase):
# (along with new events, getinfo options, and such). For now though
# there doesn't seem to be anything in practice to trigger this so
# failing to get our attention if it does.
+
+ for line in unrecognized_lines:
+ key = line.split()[0]
+ test.util.NEW_CAPABILITIES[key] = 'Extrainfo Descriptor Entry'
- self.fail('Unrecognized descriptor content: %s' % unrecognized_lines)
+ #self.fail('Unrecognized descriptor content: %s' % unrecognized_lines)
diff --git a/test/util.py b/test/util.py
index 5614e4f..a6c6515 100644
--- a/test/util.py
+++ b/test/util.py
@@ -80,6 +80,10 @@ Target = stem.util.enum.UppercaseEnum(
STEM_BASE = os.path.sep.join(__file__.split(os.path.sep)[:-2])
+# register new capabilities found
+
+NEW_CAPABILITIES = {}
+
def get_unit_tests(module_prefix = None):
"""
@@ -263,6 +267,13 @@ def check_for_unused_tests(paths):
if unused_tests:
raise ValueError('Test modules are missing from our test/settings.cfg:\n%s' % '\n'.join(unused_tests))
+
+
+def check_new_capabilities():
+ """
+ Return list of new capabilities found during tests
+ """
+ return NEW_CAPABILITIES
def _is_test_data(path):
More information about the tor-commits
mailing list