[tor-commits] [bridgedb/develop] Remove moved unittests from bridgedb.test.test_email_server.
isis at torproject.org
isis at torproject.org
Fri Jun 6 20:40:38 UTC 2014
commit c509a0abb5df5e355f1acc8185fe285e33763dca
Author: Isis Lovecruft <isis at torproject.org>
Date: Mon Jun 2 21:11:51 2014 +0000
Remove moved unittests from bridgedb.test.test_email_server.
---
lib/bridgedb/test/test_email_server.py | 507 +++++++++-----------------------
1 file changed, 140 insertions(+), 367 deletions(-)
diff --git a/lib/bridgedb/test/test_email_server.py b/lib/bridgedb/test/test_email_server.py
index 198cb27..f79f603 100644
--- a/lib/bridgedb/test/test_email_server.py
+++ b/lib/bridgedb/test/test_email_server.py
@@ -13,351 +13,99 @@
from __future__ import print_function
-import io
-import copy
-import os
-import shutil
import socket
+import string
import types
-from bridgedb.Dist import EmailBasedDistributor
-from bridgedb.email import server
-from bridgedb.parse.addr import BadEmail
-from bridgedb.persistent import Conf
-from bridgedb.schedule import Unscheduled
-from bridgedb.test.test_HTTPServer import DummyBridge
-from bridgedb.test.util import fileCheckDecorator
-from bridgedb.test.util import TestCaseMixin
-
from twisted.python import log
from twisted.internet import defer
from twisted.internet import reactor
+from twisted.mail.smtp import IMessage
from twisted.mail.smtp import SMTPBadRcpt
from twisted.mail.smtp import SMTPBadSender
from twisted.mail.smtp import User
from twisted.mail.smtp import Address
+from twisted.mail.smtp import rfc822
from twisted.test import proto_helpers
from twisted.trial import unittest
+from zope.interface import implementedBy
+from bridgedb.Dist import EmailBasedDistributor
+from bridgedb.Dist import TooSoonEmail
+from bridgedb.email import server
+from bridgedb.parse.addr import BadEmail
+from bridgedb.schedule import Unscheduled
+from bridgedb.test.util import fileCheckDecorator
+from bridgedb.test.util import TestCaseMixin
+from bridgedb.test.email_helpers import _createConfig
+from bridgedb.test.email_helpers import _createMailServerContext
-class CheckDKIMTests(unittest.TestCase):
- """Tests for :func:`email.server.checkDKIM`."""
+class SMTPMessageTests(unittest.TestCase):
+ """Unittests for :class:`bridgedb.email.server.SMTPMessage`."""
def setUp(self):
- """Create fake email, distributor, and associated context data."""
- self.goodMessage = io.StringIO(unicode("""\
-From: user at gmail.com
-To: bridges at localhost
-X-DKIM-Authentication-Results: pass
-Subject: testing
-
-get bridges
-"""))
- self.badMessage = io.StringIO(unicode("""\
-From: user at gmail.com
-To: bridges at localhost
-Subject: testing
-
-get bridges
-"""))
self.config = _createConfig()
- self.domainRules = self.config.EMAIL_DOMAIN_RULES
-
- def test_checkDKIM_good(self):
- message = server.smtp.rfc822.Message(self.goodMessage)
- self.assertTrue(server.checkDKIM(message,
- self.domainRules.get("gmail.com")))
-
- def test_checkDKIM_bad(self):
- message = server.smtp.rfc822.Message(self.badMessage)
- result = server.checkDKIM(message, self.domainRules.get("gmail.com"))
- self.assertIs(result, False)
-
+ self.context = _createMailServerContext(self.config)
+ self.message = server.SMTPMessage(self.context,
+ canonicalFromSMTP='localhost')
+ self.line = string.ascii_lowercase
-class CreateResponseBodyTests(unittest.TestCase):
- """Tests for :func:`bridgedb.email.server.createResponseBody`."""
-
- def _moveGPGTestKeyfile(self):
- here = os.getcwd()
- topDir = here.rstrip('_trial_temp')
- self.gpgFile = os.path.join(topDir, 'gnupghome', 'TESTING.subkeys.sec')
- self.gpgMoved = os.path.join(here, 'TESTING.subkeys.sec')
- shutil.copy(self.gpgFile, self.gpgMoved)
+ def tearDown(self):
+ """Re-enable safelogging in between test runs."""
+ server.safelog.setSafeLogging(True)
- def setUp(self):
- """Create fake email, distributor, and associated context data."""
- self._moveGPGTestKeyfile()
- self.toAddress = "user at example.com"
- self.config = _createConfig()
- self.ctx = _createMailContext(self.config)
- self.distributor = self.ctx.distributor
-
- def _getIncomingLines(self, clientAddress="user at example.com"):
- """Generate the lines of an incoming email from **clientAddress**."""
- self.toAddress = server.smtp.Address(clientAddress)
- lines = [
- "From: %s" % clientAddress,
- "To: bridges at localhost",
- "Subject: testing",
- "",
- "get bridges",
- ]
- return lines
-
- def test_createResponseBody_getKey(self):
- """A request for 'get key' should receive our GPG key."""
- lines = self._getIncomingLines()
- lines[4] = "get key"
- ret = server.createResponseBody(lines, self.ctx, self.toAddress)
- self.assertSubstring('-----BEGIN PGP PUBLIC KEY BLOCK-----', ret)
-
- def test_createResponseBody_bridges_invalid(self):
- """An invalid request for 'transport obfs3' should get help text."""
- lines = self._getIncomingLines("testing at localhost")
- lines[4] = "transport obfs3"
- ret = server.createResponseBody(lines, self.ctx, self.toAddress)
- self.assertSubstring("COMMANDs", ret)
-
- def test_createResponseBody_bridges_obfs3(self):
- """A request for 'get transport obfs3' should receive a response."""
- lines = self._getIncomingLines("testing at localhost")
- lines[4] = "get transport obfs3"
- ret = server.createResponseBody(lines, self.ctx, self.toAddress)
- self.assertSubstring("Here are your bridges", ret)
- self.assertSubstring("obfs3", ret)
-
- def test_createResponseBody_bridges_obfsobfswebz(self):
- """We should only pay attention to the *last* in a crazy request."""
- lines = self._getIncomingLines("testing at localhost")
- lines[4] = "get unblocked webz"
- lines.append("get transport obfs2")
- lines.append("get transport obfs3")
- ret = server.createResponseBody(lines, self.ctx, self.toAddress)
- self.assertSubstring("Here are your bridges", ret)
- self.assertSubstring("obfs3", ret)
-
- def test_createResponseBody_bridges_obfsobfswebzipv6(self):
- """We should *still* only pay attention to the *last* request."""
- lines = self._getIncomingLines("testing at localhost")
- lines[4] = "transport obfs3"
- lines.append("get unblocked webz")
- lines.append("get ipv6")
- lines.append("get transport obfs2")
- ret = server.createResponseBody(lines, self.ctx, self.toAddress)
- self.assertSubstring("Here are your bridges", ret)
- self.assertSubstring("obfs2", ret)
-
-
-class MailResponseTests(unittest.TestCase):
- """Tests for ``generateResponse()`` and ``MailResponse``."""
+ def test_SMTPMessage_init(self):
+ """Our ``message`` attribute should be a ``SMTPMessage`` object, and
+ ``message.responder`` should be a
+ :class:`bridgedb.email.autoresponder.SMTPAutoresponder`.
+ """
+ self.assertIsInstance(self.message, server.SMTPMessage)
+ self.assertIsInstance(self.message.responder,
+ server.autoresponder.SMTPAutoresponder)
- def setUp(self):
- 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 test_SMTPMessage_IMessage_interface(self):
+ """``SMTPMessage`` should implement ``twisted.mail.smtp.IMessage``."""
+ self.assertTrue(IMessage.implementedBy(server.SMTPMessage))
- def tearDown(self):
- server.safelog.safe_logging = True
-
- def test_MailResponse_generateResponse(self):
- response = server.generateResponse(self.fromAddr, self.clientAddr,
- self.body)
- self.assertIsInstance(response, server.MailResponse)
-
- def test_MailResponse_generateResponse_noSafelog(self):
- server.safelog.safe_logging = False
- response = server.generateResponse(self.fromAddr, self.clientAddr,
- self.body)
- self.assertIsInstance(response, server.MailResponse)
-
- def test_MailResponse_generateResponse_mailfile(self):
- response = server.generateResponse(self.fromAddr, self.clientAddr,
- self.body)
- self.assertIsInstance(response.mailfile, (io.BytesIO, io.StringIO))
-
- def test_MailResponse_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_MailResponse_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_MailResponse_close(self):
- """Calling MailResponse.close() should close the ``mailfile`` and set
- ``closed=True``.
+ def test_SMTPMessage_lineReceived_withSafelog(self):
+ """Test sending a line of text to ``SMTPMessage.lineReceived`` with
+ safelogging enabled.
"""
- response = server.MailResponse()
- self.assertEqual(response.closed, False)
- response.close()
- self.assertEqual(response.closed, True)
- self.assertRaises(ValueError, response.write, self.body)
-
- def test_MailResponse_write(self):
- """Calling MailResponse.write() should write to the mailfile."""
- response = server.MailResponse()
- response.write(self.body)
- contents = str(response.readContents()).replace('\x00', '')
- self.assertEqual(self.body.replace('\n', '\r\n') + '\r\n', contents)
-
- def test_MailResponse_writelines(self):
- """Calling MailResponse.writelines() with a list should write the
- concatenated contents of the list into the mailfile.
+ server.safelog.setSafeLogging(True)
+ self.message.lineReceived(self.line)
+ self.assertEqual(self.message.nBytes, 26)
+ self.assertTrue(self.line in self.message.lines)
+
+ def test_SMTPMessage_lineReceived_withoutSafelog(self):
+ """Test sending a line of text to ``SMTPMessage.lineReceived`` with
+ safelogging disnabled.
"""
- response = server.MailResponse()
- response.writelines(self.body.split('\n'))
- contents = str(response.readContents()).replace('\x00', '')
- self.assertEqual(self.body.replace('\n', '\r\n') + '\r\n', contents)
+ server.safelog.setSafeLogging(False)
+ for _ in range(3):
+ self.message.lineReceived(self.line)
+ self.assertEqual(self.message.nBytes, 3*26)
+ self.assertTrue(self.line in self.message.lines)
+ def test_SMTPMessage_eomReceived(self):
+ """Calling ``oemReceived`` should return a deferred."""
+ self.message.lineReceived(self.line)
+ self.assertIsInstance(self.message.eomReceived(),
+ defer.Deferred)
-class MailMessageTests(unittest.TestCase):
- """Unittests for :class:`bridgedb.email.server.MailMessage`."""
+ def test_SMTPMessage_getIncomingMessage(self):
+ """``getIncomingMessage`` should return a ``rfc822.Message``."""
+ self.message.lineReceived(self.line)
+ self.assertIsInstance(self.message.getIncomingMessage(),
+ rfc822.Message)
- def setUp(self):
- self.config = _createConfig()
- self.context = _createMailContext(self.config)
- self.message = server.MailMessage(self.context)
-
- def _getIncomingLines(self, clientAddress="user at example.com"):
- """Generate the lines of an incoming email from **clientAddress**."""
- lines = [
- "From: %s" % clientAddress,
- "To: bridges at localhost",
- "Subject: testing",
- "",
- "get bridges",
- ]
- self.message.lines = lines
-
- def test_MailMessage_getMailFrom_notbridgedb_at_yikezors_dot_net(self):
- """MailMessage.getMailFrom() for an incoming email sent to any email
- address other than the one we're listening for should return our
- configured address, not the one in the incoming email.
- """
- self._getIncomingLines()
- self.message.lines[1] = 'To: notbridgedb at yikezors.net'
- incoming = self.message.getIncomingMessage()
- recipient = str(self.message.getMailFrom(incoming))
- self.assertEqual(recipient, self.context.fromAddr)
-
- def test_MailMessage_getMailFrom_givemebridges_at_seriously(self):
- """MailMessage.getMailFrom() for an incoming email sent to any email
- address other than the one we're listening for should return our
- configured address, not the one in the incoming email.
- """
- self._getIncomingLines()
- self.message.lines[1] = 'To: givemebridges at serious.ly'
- incoming = self.message.getIncomingMessage()
- recipient = str(self.message.getMailFrom(incoming))
- self.assertEqual(recipient, self.context.fromAddr)
-
- def test_MailMessage_getMailFrom_bad_address(self):
- """MailMessage.getMailFrom() for an incoming email sent to a malformed
- email address should log an smtp.AddressError and then return our
- configured email address.
- """
- self._getIncomingLines()
- self.message.lines[1] = 'To: ><@><<<>>.foo'
- incoming = self.message.getIncomingMessage()
- recipient = str(self.message.getMailFrom(incoming))
- self.assertEqual(recipient, self.context.fromAddr)
-
- def test_MailMessage_reply_noFrom(self):
- """A received email without a "From:" or "Sender:" header shouldn't
- receive a response.
- """
- self._getIncomingLines()
- self.message.lines[0] = ""
- ret = self.message.reply()
- self.assertIsInstance(ret, defer.Deferred)
-
- def test_MailMessage_reply_badAddress(self):
- """Don't respond to RFC2822 malformed source addresses."""
- self._getIncomingLines("testing*.?\"@example.com")
- ret = self.message.reply()
- self.assertIsInstance(ret, defer.Deferred)
-
- def test_MailMessage_reply_anotherBadAddress(self):
- """Don't respond to RFC2822 malformed source addresses."""
- self._getIncomingLines("Mallory <>>@example.com")
- ret = self.message.reply()
- self.assertIsInstance(ret, defer.Deferred)
-
- def test_MailMessage_reply_invalidDomain(self):
- """Don't respond to RFC2822 malformed source addresses."""
- self._getIncomingLines("testing at exa#mple.com")
- ret = self.message.reply()
- self.assertIsInstance(ret, defer.Deferred)
-
- def test_MailMessage_reply_anotherInvalidDomain(self):
- """Don't respond to RFC2822 malformed source addresses."""
- self._getIncomingLines("testing at exam+ple.com")
- ret = self.message.reply()
- self.assertIsInstance(ret, defer.Deferred)
-
- def test_MailMessage_reply_DKIM_badDKIMheader(self):
- """An email with an 'X-DKIM-Authentication-Result:' header appended
- after the body should not receive a response.
- """
- self._getIncomingLines("testing at gmail.com")
- self.message.lines.append("X-DKIM-Authentication-Result: ")
- ret = self.message.reply()
- self.assertIsInstance(ret, defer.Deferred)
-
- def test_MailMessage_reply_goodDKIMheader(self):
- """An email with a good DKIM header should be responded to."""
- self._getIncomingLines("testing at gmail.com")
- self.message.lines.insert(3, "X-DKIM-Authentication-Result: pass")
- ret = self.message.reply()
- self.assertIsInstance(ret, defer.Deferred)
-
- def test_MailMessage_reply_transport_invalid(self):
- """An invalid request for 'transport obfs3' should get help text."""
- self.skip = True
- raise unittest.SkipTest("We need to fake the reactor for this one")
-
- self._getIncomingLines("testing at example.com")
- self.message.lines[4] = "transport obfs3"
- ret = self.message.reply()
- self.assertSubstring("COMMANDs", ret)
-
- def test_MailMessage_reply_transport_valid(self):
- """An valid request for 'get transport obfs3' should get obfs3."""
- self.skip = True
- raise unittest.SkipTest("We need to fake the reactor for this one")
-
- self._getIncomingLines("testing at example.com")
- self.message.lines[4] = "transport obfs3"
- ret = self.message.reply()
- self.assertIsInstance(ret, defer.Deferred)
- self.assertSubstring("obfs3", ret)
- return ret
-
-
-class MailDeliveryTests(unittest.TestCase):
- """Unittests for :class:`email.server.MailDelivery`."""
+
+class SMTPIncomingDeliveryTests(unittest.TestCase):
+ """Unittests for :class:`email.server.SMTPIncomingDelivery`."""
def setUp(self):
- """Set up our :class:`server.MailDelivery` instance, and reset the
+ """Set up our :class:`server.SMTPIncomingDelivery` instance, and reset the
following ``TestCase`` attributes to ``None``:
- ``helo``
- ``proto``
@@ -365,8 +113,8 @@ class MailDeliveryTests(unittest.TestCase):
- ``user``
"""
self.config = _createConfig()
- self.context = _createMailContext(self.config)
- self.delivery = server.MailDelivery()
+ self.context = _createMailServerContext(self.config)
+ self.delivery = server.SMTPIncomingDelivery()
self.helo = None
self.proto = None
@@ -417,39 +165,41 @@ class MailDeliveryTests(unittest.TestCase):
"""
self.helo = ('localhost', '127.0.0.1')
self.origin = server.smtp.Address('client at example.com')
- self.delivery.setBridgeDBContext(self.context)
+ self.delivery.setContext(self.context)
- def _setUpRCPTTO(self, username=None):
+ def _setUpRCPTTO(self, username=None, domain=None, ip=None):
"""Set up the parameters for emulating a connected client sending a
SMTP 'RCPT TO:' command to us.
The default is to emulate sending: ``RCPT TO: bridges at localhost``.
"""
name = username if username is not None else self.config.EMAIL_USERNAME
- self._createUser(name, 'localhost', '127.0.0.1')
- self.delivery.setBridgeDBContext(self.context)
-
- def test_MailDelivery_init(self):
- """After calling :meth:`server.MailDelivery.__init__`, we should have a
- :class:`server.MailDelivery` object instance.
+ host = domain if domain is not None else 'localhost'
+ addr = ip if ip is not None else '127.0.0.1'
+ self._createUser(name, host, ip)
+ self.delivery.setContext(self.context)
+
+ def test_SMTPIncomingDelivery_init(self):
+ """After calling :meth:`server.SMTPIncomingDelivery.__init__`, we should have a
+ :class:`server.SMTPIncomingDelivery` object instance.
"""
- self.assertIsInstance(self.delivery, server.MailDelivery)
+ self.assertIsInstance(self.delivery, server.SMTPIncomingDelivery)
- def test_MailDelivery_setBridgeDBContext(self):
- """Calling :meth:`server.MailDelivery.setBridgeDBContext` should set
- the :ivar:`MailDelivery.context` attribute.
+ def test_SMTPIncomingDelivery_setContext(self):
+ """Calling :meth:`server.SMTPIncomingDelivery.setContext` should set
+ the :ivar:`SMTPIncomingDelivery.context` attribute.
- The ``MailDelivery.context`` should be a :class:`server.MailContext`,
+ The ``SMTPIncomingDelivery.context`` should be a :class:`server.MailServerContext`,
and it should have relevant settings from the config file stored
within it.
"""
- self.delivery.setBridgeDBContext(self.context)
- self.assertIsInstance(self.delivery.context, server.MailContext)
+ self.delivery.setContext(self.context)
+ self.assertIsInstance(self.delivery.context, server.MailServerContext)
self.assertEqual(self.delivery.context.smtpFromAddr,
self.config.EMAIL_SMTP_FROM_ADDR)
- def test_MailDelivery_receivedHeader(self):
- """The email resulting from a MailDelivery, the latter received from
+ def test_SMTPIncomingDelivery_receivedHeader(self):
+ """The email resulting from a SMTPIncomingDelivery, the latter received from
``'client at example.com'`` should contain a header stating:
``'Received: from example.com'``.
"""
@@ -457,20 +207,20 @@ class MailDeliveryTests(unittest.TestCase):
hdr = self.delivery.receivedHeader(self.helo, self.origin, [self.user,])
self.assertSubstring("Received: from example.com", hdr)
- def test_MailDelivery_validateFrom(self):
- """A valid origin should be stored as ``MailDelivery.fromCanonical``."""
+ def test_SMTPIncomingDelivery_validateFrom(self):
+ """A valid origin should be stored as ``SMTPIncomingDelivery.fromCanonical``."""
self._setUpMAILFROM()
self.delivery.validateFrom(self.helo, self.origin)
- self.assertEqual(self.delivery.fromCanonical, 'example.com')
+ self.assertEqual(self.delivery.fromCanonicalSMTP, 'example.com')
- def test_MailDelivery_validateFrom_unsupportedDomain(self):
+ def test_SMTPIncomingDelivery_validateFrom_unsupportedDomain(self):
"""A domain not in our canon should raise a SMTPBadSender."""
self._setUpMAILFROM()
origin = server.smtp.Address('throwing.pickles at yo.mama')
self.assertRaises(SMTPBadSender,
self.delivery.validateFrom, self.helo, origin)
- def test_MailDelivery_validateFrom_origin_notAdressType(self):
+ def test_SMTPIncomingDelivery_validateFrom_origin_notAdressType(self):
"""A non ``twisted.mail.smtp.Address`` origin should raise an
AttributeError exception.
"""
@@ -478,28 +228,48 @@ class MailDeliveryTests(unittest.TestCase):
origin = 'throwing.pickles at yo.mama'
self.delivery.validateFrom(self.helo, origin)
- def test_MailDelivery_validateTo(self):
- """Should return a callable that results in a MailMessage."""
+ def test_SMTPIncomingDelivery_validateTo(self):
+ """Should return a callable that results in a SMTPMessage."""
self._setUpRCPTTO()
validated = self.delivery.validateTo(self.user)
self.assertIsInstance(validated, types.FunctionType)
- self.assertIsInstance(validated(), server.MailMessage)
+ self.assertIsInstance(validated(), server.SMTPMessage)
- def test_MailDelivery_validateTo_plusAddress(self):
- """Should return a callable that results in a MailMessage."""
+ def test_SMTPIncomingDelivery_validateTo_plusAddress(self):
+ """Should return a callable that results in a SMTPMessage."""
self._setUpRCPTTO('bridges+ar')
validated = self.delivery.validateTo(self.user)
self.assertIsInstance(validated, types.FunctionType)
- self.assertIsInstance(validated(), server.MailMessage)
+ self.assertIsInstance(validated(), server.SMTPMessage)
- def test_MailDelivery_validateTo_badUsername(self):
- """A :class:`server.MailDelivery` which sends a SMTP
+ def test_SMTPIncomingDelivery_validateTo_badUsername_plusAddress(self):
+ """'givemebridges+zh_cn at ...' should raise an SMTPBadRcpt exception."""
+ self._setUpRCPTTO('givemebridges+zh_cn')
+ self.assertRaises(SMTPBadRcpt, self.delivery.validateTo, self.user)
+
+ def test_SMTPIncomingDelivery_validateTo_badUsername(self):
+ """A :class:`server.SMTPIncomingDelivery` which sends a SMTP
``RCPT TO: yo.mama at localhost`` should raise a
``twisted.mail.smtp.SMTPBadRcpt`` exception.
"""
self._setUpRCPTTO('yo.mama')
self.assertRaises(SMTPBadRcpt, self.delivery.validateTo, self.user)
+ def test_SMTPIncomingDelivery_validateTo_notOurDomain(self):
+ """An SMTP ``RCPT TO: bridges at forealsi.es`` should raise an SMTPBadRcpt
+ exception.
+ """
+ self._setUpRCPTTO('bridges', 'forealsi.es')
+ self.assertRaises(SMTPBadRcpt, self.delivery.validateTo, self.user)
+
+ def test_SMTPIncomingDelivery_validateTo_subdomain(self):
+ """An SMTP ``RCPT TO: bridges at subdomain.localhost`` should be allowed.
+ """
+ self._setUpRCPTTO('bridges', 'subdomain.localhost')
+ validated = self.delivery.validateTo(self.user)
+ self.assertIsInstance(validated, types.FunctionType)
+ self.assertIsInstance(validated(), server.SMTPMessage)
+
class SMTPTestCaseMixin(TestCaseMixin):
"""Utility methods for use within any subclasses of
@@ -516,7 +286,7 @@ class SMTPTestCaseMixin(TestCaseMixin):
class ExampleSMTPTests(SMTPTestCaseMixin, unittest.TestCase):
def setUp(self):
- factory = twisted.mail.smtp.SMTPFactory()
+ factory = twisted.mail.smtp.SMTPIncomingServerFactory()
self.proto = self.factory.buildProtocol(('127.0.0.1', 0))
@@ -550,7 +320,7 @@ class SMTPTestCaseMixin(TestCaseMixin):
segment. Includes the SMTP DATA EOM command ('.') at the end. If no
keyword arguments are given, the defaults are fairly sane.
- Suitable for testing a :class:`bridgedb.email.server.MailFactory`.
+ Suitable for testing a :class:`bridgedb.email.server.SMTPIncomingServerFactory`.
:param str fromAddr: An email address for the 'From:' header.
:param str toAddr: An email address for the 'To:' header.
@@ -611,14 +381,17 @@ class SMTPTestCaseMixin(TestCaseMixin):
self.assertSubstring(expected, recv)
-class MailFactoryTests(SMTPTestCaseMixin, unittest.TestCase):
- """Unittests for :class:`bridgedb.email.server.MailFactory`."""
+class SMTPIncomingServerFactoryTests(SMTPTestCaseMixin, unittest.TestCase):
+ """Unittests for :class:`bridgedb.email.server.SMTPIncomingServerFactory`."""
def setUp(self):
- """Set up a localhost MailFactory handler incoming SMTP connections."""
+ """Set up a localhost SMTPIncomingServerFactory handler incoming SMTP
+ connections.
+ """
config = _createConfig()
- context = _createMailContext(config)
- factory = server.MailFactory(context)
+ context = _createMailServerContext(config)
+ factory = server.SMTPIncomingServerFactory()
+ factory.setContext(context)
factory.protocol.timeout = None # Otherwise the reactor gets dirty
self.smtpFromAddr = context.smtpFromAddr # 'bridges at localhost'
@@ -629,40 +402,40 @@ class MailFactoryTests(SMTPTestCaseMixin, unittest.TestCase):
self.transport.protocol = self.proto
self.proto.makeConnection(self.transport)
- def test_MailFactory_HELO_localhost(self):
+ def test_SMTPIncomingServerFactory_HELO_localhost(self):
"""Send 'HELO localhost' to the server's transport."""
ip = self.transport.getPeer().host
self._test(['HELO localhost'],
"Hello %s, nice to meet you" % ip)
- def test_MailFactory_MAIL_FROM_testing_at_localhost(self):
+ def test_SMTPIncomingServerFactory_MAIL_FROM_testing_at_localhost(self):
"""Send 'MAIL FROM: human at localhost'."""
self._test(['HELO localhost',
'MAIL FROM: testing at localhost'],
"250 Sender address accepted")
- def test_MailFactory_MAIL_FROM_testing_at_gethostname(self):
+ def test_SMTPIncomingServerFactory_MAIL_FROM_testing_at_gethostname(self):
"""Send 'MAIL FROM: human at hostname' for the local hostname."""
hostname = socket.gethostname() or "computer"
self._test(['HELO localhost',
'MAIL FROM: testing@%s' % hostname],
"250 Sender address accepted")
- def test_MailFactory_MAIL_FROM_testing_at_ipaddress(self):
+ def test_SMTPIncomingServerFactory_MAIL_FROM_testing_at_ipaddress(self):
"""Send 'MAIL FROM: human at ipaddr' for the loopback IP address."""
- hostname = socket.gethostbyname(socket.gethostname()) or "127.0.0.1"
+ hostname = 'localhost'
self._test(['HELO localhost',
'MAIL FROM: testing@%s' % hostname],
"250 Sender address accepted")
- def test_MailFactory_RCPT_TO_config_EMAIL_SMTP_FROM_ADDR(self):
+ def test_SMTPIncomingServerFactory_RCPT_TO_context_smtpFromAddr(self):
"""Send 'RCPT TO:' with the context.smtpFromAddr."""
self._test(['HELO localhost',
'MAIL FROM: testing at localhost',
'RCPT TO: %s' % self.smtpFromAddr],
"250 Recipient address accepted")
- def test_MailFactory_DATA_blank(self):
+ def test_SMTPIncomingServerFactory_DATA_blank(self):
"""A DATA command with nothing after it should receive::
'354 Continue'
in response.
@@ -673,7 +446,7 @@ class MailFactoryTests(SMTPTestCaseMixin, unittest.TestCase):
"DATA"],
"354 Continue")
- def test_MailFactory_DATA_get_help(self):
+ def test_SMTPIncomingServerFactory_DATA_get_help(self):
"""A DATA command with ``'get help'`` in the email body should
receive::
'250 Delivery in progress'
@@ -687,7 +460,7 @@ class MailFactoryTests(SMTPTestCaseMixin, unittest.TestCase):
"250 Delivery in progress",
noisy=True)
- def test_MailFactory_DATA_get_transport_obfs3(self):
+ def test_SMTPIncomingServerFactory_DATA_get_transport_obfs3(self):
"""A DATA command with ``'get transport obfs3'`` in the email body
should receive::
'250 Delivery in progress'
@@ -701,7 +474,7 @@ class MailFactoryTests(SMTPTestCaseMixin, unittest.TestCase):
"250 Delivery in progress",
noisy=True)
- def test_MailFactory_DATA_To_bridges_plus_zh_CN(self):
+ def test_SMTPIncomingServerFactory_DATA_To_bridges_plus_zh_CN(self):
"""Test sending to 'bridges+zh_CN' address for Chinese translations."""
# TODO: Add tests which use '+' syntax in mailTo in order to test
# email translations. Do this when some strings have been translated.
@@ -716,7 +489,7 @@ class MailFactoryTests(SMTPTestCaseMixin, unittest.TestCase):
"250 Delivery in progress",
noisy=True)
- def test_MailFactory_DATA_get_bridges_QUIT(self):
+ def test_SMTPIncomingServerFactory_DATA_get_bridges_QUIT(self):
"""Test sending 'DATA' with 'get bridges', then sending 'QUIT'."""
emailText = self._buildEmail()
self._test(['HELO localhost',
@@ -732,9 +505,9 @@ class EmailServerServiceTests(SMTPTestCaseMixin, unittest.TestCase):
"""Unittests for :func:`bridgedb.email.server.addServer`."""
def setUp(self):
- """Create a server.MailContext and EmailBasedDistributor."""
+ """Create a server.MailServerContext and EmailBasedDistributor."""
self.config = _createConfig()
- self.context = _createMailContext(self.config)
+ self.context = _createMailServerContext(self.config)
self.smtpFromAddr = self.context.smtpFromAddr # 'bridges at localhost'
self.sched = Unscheduled()
self.dist = self.context.distributor
More information about the tor-commits
mailing list