From 5733c08f55e9bf1ff5ac79908d941581feafea57 Mon Sep 17 00:00:00 2001 From: Antoine Pitrou Date: Mon, 22 Mar 2010 14:49:10 +0000 Subject: [PATCH] Merged revisions 79226,79286 via svnmerge from svn+ssh://pythondev@svn.python.org/python/trunk ........ r79226 | antoine.pitrou | 2010-03-21 20:33:38 +0100 (dim., 21 mars 2010) | 4 lines Issue #3890: Fix recv() and recv_into() on non-blocking SSL sockets. ........ r79286 | antoine.pitrou | 2010-03-22 15:41:48 +0100 (lun., 22 mars 2010) | 3 lines Fix an occasional test_ftplib failure, following r79226. ........ --- Lib/ssl.py | 14 ++++---------- Lib/test/test_ftplib.py | 7 ++++++- Misc/NEWS | 2 ++ 3 files changed, 12 insertions(+), 11 deletions(-) diff --git a/Lib/ssl.py b/Lib/ssl.py index b1cc149d87e..e0096971640 100644 --- a/Lib/ssl.py +++ b/Lib/ssl.py @@ -240,16 +240,9 @@ class SSLSocket(socket): if self._sslobj: if flags != 0: raise ValueError( - "non-zero flags not allowed in calls to recv_into() on %s" % - self.__class__) - while True: - try: - return self.read(buflen) - except SSLError as x: - if x.args[0] == SSL_ERROR_WANT_READ: - continue - else: - raise x + "non-zero flags not allowed in calls to recv() on %s" % + self.__class__) + return self.read(buflen) else: return socket.recv(self, buflen, flags) @@ -273,6 +266,7 @@ class SSLSocket(socket): continue else: raise x + return self.read(nbytes, buffer) else: return socket.recv_into(self, buffer, nbytes, flags) diff --git a/Lib/test/test_ftplib.py b/Lib/test/test_ftplib.py index 2ed1e5f2d74..29f7f7d84bc 100644 --- a/Lib/test/test_ftplib.py +++ b/Lib/test/test_ftplib.py @@ -296,7 +296,9 @@ if ssl is not None: try: return super(SSLConnection, self).send(data) except ssl.SSLError as err: - if err.args[0] in (ssl.SSL_ERROR_EOF, ssl.SSL_ERROR_ZERO_RETURN): + if err.args[0] in (ssl.SSL_ERROR_EOF, ssl.SSL_ERROR_ZERO_RETURN, + ssl.SSL_ERROR_WANT_READ, + ssl.SSL_ERROR_WANT_WRITE): return 0 raise @@ -304,6 +306,9 @@ if ssl is not None: try: return super(SSLConnection, self).recv(buffer_size) except ssl.SSLError as err: + if err.args[0] in (ssl.SSL_ERROR_WANT_READ, + ssl.SSL_ERROR_WANT_WRITE): + return '' if err.args[0] in (ssl.SSL_ERROR_EOF, ssl.SSL_ERROR_ZERO_RETURN): self.handle_close() return b'' diff --git a/Misc/NEWS b/Misc/NEWS index 8a62cbf4a29..a27dd11f92b 100644 --- a/Misc/NEWS +++ b/Misc/NEWS @@ -287,6 +287,8 @@ C-API Library ------- +- Issue #3890: Fix recv() and recv_into() on non-blocking SSL sockets. + - Issue #4282: Fix the main function of the profile module for a non-ASCII script, open the file in binary mode and not in text mode with the default (utf8) encoding.