[tor-commits] [stem/master] Improving error output for test_skip_nondescriptor_contents
atagar at torproject.org
atagar at torproject.org
Sat Feb 2 18:20:49 UTC 2013
commit 9d53a2854178d12222480958795876e45ec0f1d6
Author: Damian Johnson <atagar at torproject.org>
Date: Tue Jan 29 08:54:03 2013 -0800
Improving error output for test_skip_nondescriptor_contents
The descriptor reader's test_skip_nondescriptor_contents integ test is
especially tickle since it can fail whenever there's new non-descriptor content
in the test/integ/descriptor/data directory.
Improving its error output to say what it expected and got rather than simply
saying that the counts mismatch.
---
test/integ/descriptor/reader.py | 17 ++++++++++++-----
1 files changed, 12 insertions(+), 5 deletions(-)
diff --git a/test/integ/descriptor/reader.py b/test/integ/descriptor/reader.py
index 960eaeb..97ea27c 100644
--- a/test/integ/descriptor/reader.py
+++ b/test/integ/descriptor/reader.py
@@ -363,16 +363,23 @@ class TestDescriptorReader(unittest.TestCase):
reader = stem.descriptor.reader.DescriptorReader(DESCRIPTOR_TEST_DATA)
reader.register_skip_listener(skip_listener.listener)
+ expected_skip_files = ("riddle", "tiny.png", "vote", "new_metrics_type")
+
with reader:
list(reader) # iterates over all of the descriptors
- self.assertEqual(4, len(skip_listener.results))
+ # strip anything with a .swp suffix (vim tmp files)
- for skip_path, skip_exception in skip_listener.results:
- if skip_path.endswith(".swp"):
- continue # skip vim temp files
+ skip_listener.results = [(path, exc) for (path, exc) in skip_listener.results if not path.endswith(".swp")]
+
+ if len(skip_listener.results) != len(expected_skip_files):
+ expected_label = ",\n ".join(expected_skip_files)
+ results_label = ",\n ".join(["%s (%s)" % (path, exc) for (path, exc) in skip_listener.results])
- if not os.path.basename(skip_path) in ("riddle", "tiny.png", "vote", "new_metrics_type"):
+ self.fail("Skipped files that we should have been able to parse.\n\nExpected:\n %s\n\nResult:\n %s" % (expected_label, results_label))
+
+ for skip_path, skip_exception in skip_listener.results:
+ if not os.path.basename(skip_path) in expected_skip_files:
self.fail("Unexpected non-descriptor content: %s" % skip_path)
self.assertTrue(isinstance(skip_exception, stem.descriptor.reader.UnrecognizedType))
More information about the tor-commits
mailing list