tests/smtp.py
branchdevel
changeset 169 aabc04843d25
parent 164 b634a8fed51f
child 174 762981cada07
--- a/tests/smtp.py	Wed Feb 15 14:43:37 2012 +0100
+++ b/tests/smtp.py	Sat Feb 18 17:13:38 2012 +0100
@@ -5,7 +5,10 @@
 import base64
 from smtp_helper import TestSMTPServer
 
+from mock import patch, Mock
+import smtplib
 
+from iro.error import NoRoute, NoTyp, NeededOption, UnknownOption
 from iro.model.message import Mail
 from iro.offer.smtp import SMTP
 
@@ -20,15 +23,21 @@
     def tearDown(self):
         self.smtp_server.close()
 
+    def getSMTP(self, c=None):
+        ret={"send_from":"send@t.de",
+            "host":HOST,
+            "port":PORT,
+            "user":"",
+            "password":"",
+            }
+
+        if c:
+            ret.update(c)
+
+        return SMTP("test",ret.items())
+
     def testSendMail(self):
-        c=[("send_from","send@t.de"),
-            ("host",HOST),
-            ("port",PORT),
-            ("user",""),
-            ("password",""),
-            ]
-
-        p=SMTP("test",c)
+        p=self.getSMTP()
         content = "sadfadfgwertsdgsdf\n\nsdfgaerasdfsad\nadfasdf"
         status = p.send(Mail("sub", content, None), "t@t.de")
 
@@ -46,14 +55,7 @@
         self.assertEqual(base64.b64decode(msg.get_payload()),content)
 
     def testSendMailExtraFrm(self):
-        c=[("send_from","send@t.de"),
-            ("host",HOST),
-            ("port",PORT),
-            ("user",""),
-            ("password",""),
-            ]
-
-        p=SMTP("test",c)
+        p=self.getSMTP()
         content = ""
         status = p.send(Mail("sub", content, "f@t.de"), "t@t.de")
 
@@ -67,30 +69,85 @@
         self.assertEqual(msg.get_all("From"),["f@t.de"])
 
     def testSendMailException(self):
-        c=[("send_from","send@t.de"),
-            ("host",HOST),
-            ("port",PORT-1),
-            ("user",""),
-            ("password",""),
-            ]
-
-        p=SMTP("test",c)
+        p=self.getSMTP({"port":PORT-1})
         content = ""
-        status = p.send(Mail("sub", content, "f@t.de"), "t@t.de")
-        self.assertEqual(status.status, status.ERROR)
-        self.assertIsInstance(status.error,IOError)
-        self.assertEqual(status.error.errno,111)
+        self.assertRaises(IOError, p.send, Mail("sub", content, "f@t.de"), "t@t.de")
 
         self.assertEqual(len(self.smtp_server.rcvd), 0)
 
-    def testNeededOption(self):
-        pass
-    testNeededOption.todo = "test NeededOption is not implemented"
+    @patch("smtplib.SMTP_SSL")
+    def testSSLSendMail(self,mock_ssl):
+        def se(*args):
+            return smtplib.SMTP(*args)
+        mock_ssl.side_effect=se
+
+        p=self.getSMTP({"SSL":True})
+        content = "sadfadfgwertsdgsdf\n\nsdfgaerasdfsad\nadfasdf"
+        status = p.send(Mail("sub", content, None), "t@t.de")
+
+        self.assertEqual(mock_ssl.call_count,1)
+        self.assertEqual(status.status, status.GOOD)
+
+        self.assertEqual(len(self.smtp_server.rcvd), 1)
+
+    @patch("smtplib.SMTP")
+    def testTLSSendMail(self,mock_smtp):
+        mock_s = Mock()
+        mock_smtp.return_value = mock_s
+
+        p=self.getSMTP({"TLS":True})
+        content = "sadfadfgwertsdgsdf\n\nsdfgaerasdfsad\nadfasdf"
+        status = p.send(Mail("sub", content, None), "t@t.de")
+        
+        mock_s.starttls.assert_called_once_with()
+        self.assertEqual(mock_s.sendmail.call_count,1)
+        self.assertEqual([i[0] for i in mock_s.method_calls],["starttls","sendmail","quit"])
+        self.assertEqual(status.status, status.GOOD)
+
+    @patch("smtplib.SMTP")
+    def testLoginSendMail(self,mock_smtp):
+        mock_s = Mock()
+        mock_smtp.return_value = mock_s
 
-    def testUnknownOption(self):
-        pass
-    testUnknownOption.todo = "test UnknownOption is not implemented"
+        p=self.getSMTP({"user":"user","password":"pw"})
+        content = "sadfadfgwertsdgsdf\n\nsdfgaerasdfsad\nadfasdf"
+        status = p.send(Mail("sub", content, None), "t@t.de")
+        
+        mock_s.login.assert_called_once_with("user","pw")
+        self.assertEqual(mock_s.sendmail.call_count,1)
+        self.assertEqual([i[0] for i in mock_s.method_calls],["login","sendmail","quit"])
+        self.assertEqual(status.status, status.GOOD)
+
+    
+    def testNeededOption(self):
+        c={"send_from":"send@t.de",
+            "host":HOST,
+            "port":PORT,
+            "user":"u",
+            "password":"p",
+            }
+        s=SMTP("test",c.items())
+        self.assertEqual(s.send_from, "send@t.de")
+        self.assertEqual(s.host, HOST)
+        self.assertEqual(s.port, PORT)
+        self.assertEqual(s.user, "u")
+        self.assertEqual(s.password, "p")
+        self.assertEqual(s.bSSL,False)
+        self.assertEqual(s.bTLS,False)
+
+        c.update({"TLS":True, "SSL":True})
+        s=SMTP("test", c.items())
+        self.assertEqual(s.bSSL,True)
+        self.assertEqual(s.bTLS,True)
+        
+        del c["host"]
+        self.assertRaises(NeededOption,SMTP,"test",c.items())
+
+        c = {"unknown":""}
+        self.assertRaises(UnknownOption,SMTP,"test",c.items())
 
     def testSendFunc(self):
-        pass
-    testSendFunc.todo = "test getSendFunc is not implemented"
+        s = self.getSMTP()
+        self.assertEqual(s.getSendFunc("mail",None), s.send)
+        self.assertRaises(NoRoute,s.getSendFunc,"mail","foo")
+        self.assertRaises(NoTyp,s.getSendFunc,"mail2","foo")