[tor-commits] [bridgedb/master] Add email.server.generateResponse() and MailResponse unittests.

isis at torproject.org isis at torproject.org
Fri May 16 18:52:52 UTC 2014


commit 9cf6d069e7c14edfc563617e1553afc899d576da
Author: Isis Lovecruft <isis at torproject.org>
Date:   Tue May 6 12:25:38 2014 +0000

    Add email.server.generateResponse() and MailResponse unittests.
---
 lib/bridgedb/test/test_email_server.py |   60 ++++++++++++++++++++++++++------
 1 file changed, 50 insertions(+), 10 deletions(-)

diff --git a/lib/bridgedb/test/test_email_server.py b/lib/bridgedb/test/test_email_server.py
index c7fdefb..5323e38 100644
--- a/lib/bridgedb/test/test_email_server.py
+++ b/lib/bridgedb/test/test_email_server.py
@@ -208,18 +208,58 @@ class CreateResponseBodyTests(unittest.TestCase):
         self.assertSubstring("obfs2", ret)
 
 
-class EmailReplyTests(unittest.TestCase):
-    """Tests for ``EmailServer.replyToMail()``."""
+class MailResponseTests(unittest.TestCase):
+    """Tests for ``generateResponse()`` and ``MailResponse``."""
 
     def setUp(self):
-        """Create fake email, distributor, and associated context data."""
-        # TODO: Add headers if we start validating them
-        self.lines = ["From: %s@%s.com",
-                      "To: bridges at example.net",
-                      "Subject: testing",
-                      "\n",
-                      "get bridges"]
-        self.ctx = _createMailContext()
+        self.fromAddr = "bridges at torproject.org"
+        self.clientAddr = "user at example.com"
+        self.body = """\
+People think that time is strictly linear, but, in reality, it's actually just
+a ball of timey-wimey, wibbly-warbly... stuff."""
+
+    def tearDown(self):
+        server.safelog.safe_logging = True
+
+    def test_generateResponse(self):
+        response = server.generateResponse(self.fromAddr, self.clientAddr,
+                                           self.body)
+        self.assertIsInstance(response, server.MailResponse)
+
+    def test_generateResponse_noSafelog(self):
+        server.safelog.safe_logging = False
+        response = server.generateResponse(self.fromAddr, self.clientAddr,
+                                           self.body)
+        self.assertIsInstance(response, server.MailResponse)
+
+    def test_generateResponse_mailfile(self):
+        response = server.generateResponse(self.fromAddr, self.clientAddr,
+                                           self.body)
+        self.assertIsInstance(response.mailfile, (io.BytesIO, io.StringIO))
+
+    def test_generateResponse_withInReplyTo(self):
+        response = server.generateResponse(self.fromAddr, self.clientAddr,
+                                           self.body, messageID="NSA")
+        contents = str(response.readContents()).replace('\x00', '')
+        self.assertIsInstance(response.mailfile, (io.BytesIO, io.StringIO))
+        self.assertSubstring("In-Reply-To: NSA", contents)
+
+    def test_generateResponse_readContents(self):
+        response = server.generateResponse(self.fromAddr, self.clientAddr,
+                                           self.body)
+        contents = str(response.readContents()).replace('\x00', '')
+        self.assertSubstring('timey-wimey, wibbly-warbly... stuff.', contents)
+
+    def test_MailResponse_additionalHeaders(self):
+        response = server.MailResponse()
+        response.writeHeaders(self.fromAddr, self.clientAddr,
+                              subject="Re: echelon", inReplyTo="NSA",
+                              X_been_there="They were so 2004")
+        contents = str(response.readContents()).replace('\x00', '')
+        self.assertIsInstance(response.mailfile, (io.BytesIO, io.StringIO))
+        self.assertSubstring("In-Reply-To: NSA", contents)
+        self.assertSubstring("X-been-there: They were so 2004", contents)
+
 
     def test_replyToMail(self):
         self.skip = True





More information about the tor-commits mailing list