2009-05-23 09:30:26 +08:00
|
|
|
import unittest
|
|
|
|
from test import support
|
|
|
|
import smtplib
|
2013-12-03 03:44:17 +08:00
|
|
|
import socket
|
2011-05-19 02:02:50 +08:00
|
|
|
|
|
|
|
ssl = support.import_module("ssl")
|
2009-05-23 09:30:26 +08:00
|
|
|
|
2009-05-23 10:36:15 +08:00
|
|
|
support.requires("network")
|
2009-05-23 09:30:26 +08:00
|
|
|
|
2013-12-03 03:44:17 +08:00
|
|
|
def check_ssl_verifiy(host, port):
|
|
|
|
context = ssl.create_default_context()
|
|
|
|
with socket.create_connection((host, port)) as sock:
|
|
|
|
try:
|
|
|
|
sock = context.wrap_socket(sock, server_hostname=host)
|
|
|
|
except Exception:
|
|
|
|
return False
|
|
|
|
else:
|
|
|
|
sock.close()
|
|
|
|
return True
|
|
|
|
|
2011-05-19 00:03:09 +08:00
|
|
|
|
|
|
|
class SmtpTest(unittest.TestCase):
|
|
|
|
testServer = 'smtp.gmail.com'
|
2015-03-02 13:40:36 +08:00
|
|
|
remotePort = 587
|
2011-05-19 00:03:09 +08:00
|
|
|
|
|
|
|
def test_connect_starttls(self):
|
|
|
|
support.get_attribute(smtplib, 'SMTP_SSL')
|
2017-09-16 02:27:30 +08:00
|
|
|
context = ssl.SSLContext(ssl.PROTOCOL_TLS_CLIENT)
|
|
|
|
context.check_hostname = False
|
|
|
|
context.verify_mode = ssl.CERT_NONE
|
2011-05-19 00:03:09 +08:00
|
|
|
with support.transient_internet(self.testServer):
|
|
|
|
server = smtplib.SMTP(self.testServer, self.remotePort)
|
2011-07-31 05:46:54 +08:00
|
|
|
try:
|
2013-12-03 03:44:17 +08:00
|
|
|
server.starttls(context=context)
|
2011-07-31 05:46:54 +08:00
|
|
|
except smtplib.SMTPException as e:
|
|
|
|
if e.args[0] == 'STARTTLS extension not supported by server.':
|
|
|
|
unittest.skip(e.args[0])
|
|
|
|
else:
|
|
|
|
raise
|
2011-05-19 00:04:04 +08:00
|
|
|
server.ehlo()
|
|
|
|
server.quit()
|
2011-05-19 00:03:09 +08:00
|
|
|
|
|
|
|
|
2009-05-23 09:30:26 +08:00
|
|
|
class SmtpSSLTest(unittest.TestCase):
|
|
|
|
testServer = 'smtp.gmail.com'
|
|
|
|
remotePort = 465
|
|
|
|
|
|
|
|
def test_connect(self):
|
2009-05-23 10:36:15 +08:00
|
|
|
support.get_attribute(smtplib, 'SMTP_SSL')
|
2010-10-14 01:14:16 +08:00
|
|
|
with support.transient_internet(self.testServer):
|
|
|
|
server = smtplib.SMTP_SSL(self.testServer, self.remotePort)
|
2011-05-19 00:04:04 +08:00
|
|
|
server.ehlo()
|
|
|
|
server.quit()
|
2009-05-23 09:30:26 +08:00
|
|
|
|
2011-05-08 01:39:37 +08:00
|
|
|
def test_connect_default_port(self):
|
|
|
|
support.get_attribute(smtplib, 'SMTP_SSL')
|
|
|
|
with support.transient_internet(self.testServer):
|
|
|
|
server = smtplib.SMTP_SSL(self.testServer)
|
2011-05-19 00:04:04 +08:00
|
|
|
server.ehlo()
|
|
|
|
server.quit()
|
2011-05-08 01:39:37 +08:00
|
|
|
|
2011-05-19 00:03:09 +08:00
|
|
|
def test_connect_using_sslcontext(self):
|
2017-09-16 02:27:30 +08:00
|
|
|
context = ssl.SSLContext(ssl.PROTOCOL_TLS_CLIENT)
|
|
|
|
context.check_hostname = False
|
|
|
|
context.verify_mode = ssl.CERT_NONE
|
2013-12-03 03:44:17 +08:00
|
|
|
support.get_attribute(smtplib, 'SMTP_SSL')
|
|
|
|
with support.transient_internet(self.testServer):
|
|
|
|
server = smtplib.SMTP_SSL(self.testServer, self.remotePort, context=context)
|
|
|
|
server.ehlo()
|
|
|
|
server.quit()
|
|
|
|
|
|
|
|
def test_connect_using_sslcontext_verified(self):
|
2014-09-04 06:35:43 +08:00
|
|
|
with support.transient_internet(self.testServer):
|
|
|
|
can_verify = check_ssl_verifiy(self.testServer, self.remotePort)
|
|
|
|
if not can_verify:
|
|
|
|
self.skipTest("SSL certificate can't be verified")
|
|
|
|
|
2011-05-19 00:03:09 +08:00
|
|
|
support.get_attribute(smtplib, 'SMTP_SSL')
|
2013-12-03 03:44:17 +08:00
|
|
|
context = ssl.create_default_context()
|
2011-05-19 00:03:09 +08:00
|
|
|
with support.transient_internet(self.testServer):
|
2013-12-03 03:44:17 +08:00
|
|
|
server = smtplib.SMTP_SSL(self.testServer, self.remotePort, context=context)
|
2011-05-19 00:04:04 +08:00
|
|
|
server.ehlo()
|
|
|
|
server.quit()
|
2011-05-19 00:03:09 +08:00
|
|
|
|
|
|
|
|
2009-05-23 09:30:26 +08:00
|
|
|
if __name__ == "__main__":
|
2015-04-14 04:00:43 +08:00
|
|
|
unittest.main()
|