[tor-commits] [stem/master] Integration test for reading non-descriptor files

atagar at torproject.org atagar at torproject.org
Mon Mar 26 00:10:01 UTC 2012


commit 9faad3255491642f87801926512c9cb6d334f6d8
Author: Damian Johnson <atagar at torproject.org>
Date:   Sat Mar 24 16:50:03 2012 -0700

    Integration test for reading non-descriptor files
    
    Integ test for reading non-descriptor plaintext and binary data.
---
 stem/descriptor/reader.py           |    7 ++++++-
 test/integ/descriptor/data/riddle   |   20 ++++++++++++++++++++
 test/integ/descriptor/data/tiny.png |  Bin 0 -> 188 bytes
 test/integ/descriptor/reader.py     |   18 ++++++++++++++++++
 4 files changed, 44 insertions(+), 1 deletions(-)

diff --git a/stem/descriptor/reader.py b/stem/descriptor/reader.py
index 511ba04..de39d54 100644
--- a/stem/descriptor/reader.py
+++ b/stem/descriptor/reader.py
@@ -94,7 +94,10 @@ class ParsingFailure(FileSkipped):
     self.exception = parsing_exception
 
 class UnrecognizedType(FileSkipped):
-  "File's mime type indicates that it isn't descriptor data."
+  """
+  File doesn't contain descriptor data. This could either be due to its file
+  type or because it doens't conform to a recognizable descriptor type.
+  """
   
   def __init__(self, mime_type):
     FileSkipped.__init__(self)
@@ -369,6 +372,8 @@ class DescriptorReader:
           self._enqueue_descriptor(desc)
           self._iter_notice.set()
     except TypeError, exc:
+      self._notify_skip_listeners(target, UnrecognizedType(None))
+    except ValueError, exc:
       self._notify_skip_listeners(target, ParsingFailure(exc))
     except IOError, exc:
       self._notify_skip_listeners(target, ReadFailed(exc))
diff --git a/test/integ/descriptor/data/riddle b/test/integ/descriptor/data/riddle
new file mode 100644
index 0000000..ac08f36
--- /dev/null
+++ b/test/integ/descriptor/data/riddle
@@ -0,0 +1,20 @@
+Riddle by Damian Johnson (May, 2009)
+
+Curtains raise, they take the stage,
+  mute actors that never age.
+The clouds are cotton, the floor is pine,
+  the souls bound up in fine twine.
+
+Crowds will cheer, the players dance,
+  flowing scene to scene as in a trance.
+The world is perfect, they never whine,
+  for there's not a single will, save mine.
+
+The play has ended, we take a bow,
+  but the viewers are the actors now.
+When freed from decision, of thought and blame,
+  we'll walk to another drum just the same. 
+
+answer:
+http://www.atagar.com/riddles/answer10.php
+
diff --git a/test/integ/descriptor/data/tiny.png b/test/integ/descriptor/data/tiny.png
new file mode 100644
index 0000000..e86715f
Binary files /dev/null and b/test/integ/descriptor/data/tiny.png differ
diff --git a/test/integ/descriptor/reader.py b/test/integ/descriptor/reader.py
index cdc33c2..717a55b 100644
--- a/test/integ/descriptor/reader.py
+++ b/test/integ/descriptor/reader.py
@@ -287,6 +287,24 @@ class TestDescriptorReader(unittest.TestCase):
     
     self.assertEquals(expected_results, reader.get_processed_files())
   
+  def test_skip_nondescriptor_contents(self):
+    """
+    Checks that the reader properly reports when it skips both binary and
+    plaintext non-descriptor files.
+    """
+    
+    skip_listener = SkipListener()
+    reader = stem.descriptor.reader.DescriptorReader([DESCRIPTOR_TEST_DATA])
+    reader.register_skip_listener(skip_listener.listener)
+    
+    with reader: list(reader) # iterates over all of the descriptors
+    
+    self.assertTrue(2, len(skip_listener.results))
+    
+    for skip_path, skip_exception in skip_listener.results:
+      self.assertTrue(os.path.basename(skip_path) in ("riddle", "tiny.png"))
+      self.assertTrue(isinstance(skip_exception, stem.descriptor.reader.UnrecognizedType))
+  
   def test_skip_listener_already_read(self):
     """
     Checks that calling set_processed_files() prior to reading makes us skip





More information about the tor-commits mailing list