diff options
author | R. David Murray <rdmurray@bitdance.com> | 2009-05-23 01:42:42 (GMT) |
---|---|---|
committer | R. David Murray <rdmurray@bitdance.com> | 2009-05-23 01:42:42 (GMT) |
commit | eb059b8cb81ed4156f1f91cd911c7d884ad493c7 (patch) | |
tree | c98f8186c05293a97a7fb44bb74040e6e362f64a /Lib | |
parent | 4f17fe03005649d3d60ba6f863ae1aca953a53f3 (diff) | |
download | cpython-eb059b8cb81ed4156f1f91cd911c7d884ad493c7.zip cpython-eb059b8cb81ed4156f1f91cd911c7d884ad493c7.tar.gz cpython-eb059b8cb81ed4156f1f91cd911c7d884ad493c7.tar.bz2 |
Merged revisions 72835 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/trunk
........
r72835 | r.david.murray | 2009-05-22 20:48:58 -0400 (Fri, 22 May 2009) | 4 lines
Fix Issue #4066: smtplib.SMTP_SSL._get_socket now correctly returns
the socket. Patch by Farhan Ahmad, test by Marcin Bachry.
........
Diffstat (limited to 'Lib')
-rwxr-xr-x | Lib/smtplib.py | 7 | ||||
-rw-r--r-- | Lib/test/test_smtpnet.py | 26 |
2 files changed, 30 insertions, 3 deletions
diff --git a/Lib/smtplib.py b/Lib/smtplib.py index afa38bc..41a3c97 100755 --- a/Lib/smtplib.py +++ b/Lib/smtplib.py @@ -751,9 +751,10 @@ if _have_ssl: def _get_socket(self, host, port, timeout): if self.debuglevel > 0: print>>stderr, 'connect:', (host, port) - self.sock = socket.create_connection((host, port), timeout) - self.sock = ssl.wrap_socket(self.sock, self.keyfile, self.certfile) - self.file = SSLFakeFile(self.sock) + new_socket = socket.create_connection((host, port), timeout) + new_socket = ssl.wrap_socket(new_socket, self.keyfile, self.certfile) + self.file = SSLFakeFile(new_socket) + return new_socket __all__.append("SMTP_SSL") diff --git a/Lib/test/test_smtpnet.py b/Lib/test/test_smtpnet.py new file mode 100644 index 0000000..c38eeee --- /dev/null +++ b/Lib/test/test_smtpnet.py @@ -0,0 +1,26 @@ +#!/usr/bin/env python + +import unittest +from test import test_support +import smtplib + +test_support.requires( + "network", + "use of network resource is not enabled and " + "test requires Internet access for communication with smtp.gmail.com:465", + ) + +class SmtpSSLTest(unittest.TestCase): + testServer = 'smtp.gmail.com' + remotePort = 465 + + def test_connect(self): + server = smtplib.SMTP_SSL(self.testServer, self.remotePort) + server.ehlo() + server.quit() + +def test_main(): + test_support.run_unittest(SmtpSSLTest) + +if __name__ == "__main__": + test_main() |