summaryrefslogtreecommitdiffstats
path: root/Lib
diff options
context:
space:
mode:
authorR. David Murray <rdmurray@bitdance.com>2009-05-23 00:48:58 (GMT)
committerR. David Murray <rdmurray@bitdance.com>2009-05-23 00:48:58 (GMT)
commitad3058e0b8ef8a2f753195e9611b47c01c4f3b0d (patch)
treee2f96416103f5ed6d52ef017a402a08c3ba3fbe6 /Lib
parenteae1b28fb128056144d05892eb2e9f10b4a34cfb (diff)
downloadcpython-ad3058e0b8ef8a2f753195e9611b47c01c4f3b0d.zip
cpython-ad3058e0b8ef8a2f753195e9611b47c01c4f3b0d.tar.gz
cpython-ad3058e0b8ef8a2f753195e9611b47c01c4f3b0d.tar.bz2
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-xLib/smtplib.py7
-rw-r--r--Lib/test/test_smtpnet.py26
2 files changed, 30 insertions, 3 deletions
diff --git a/Lib/smtplib.py b/Lib/smtplib.py
index 69d7f71..9300474 100755
--- a/Lib/smtplib.py
+++ b/Lib/smtplib.py
@@ -754,9 +754,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()