diff options
| author | Antoine Pitrou <solipsis@pitrou.net> | 2010-03-22 14:49:10 +0000 | 
|---|---|---|
| committer | Antoine Pitrou <solipsis@pitrou.net> | 2010-03-22 14:49:10 +0000 | 
| commit | 5733c08f55e9bf1ff5ac79908d941581feafea57 (patch) | |
| tree | f0f7d64783ed07d6804f63cef4999b9d2d634a4e | |
| parent | 808fc0a0eea56dd4ef2fa9f9dee00ef0c20760f2 (diff) | |
| download | cpython-git-5733c08f55e9bf1ff5ac79908d941581feafea57.tar.gz | |
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.
........
| -rw-r--r-- | Lib/ssl.py | 14 | ||||
| -rw-r--r-- | Lib/test/test_ftplib.py | 7 | ||||
| -rw-r--r-- | Misc/NEWS | 2 | 
3 files changed, 12 insertions, 11 deletions
diff --git a/Lib/ssl.py b/Lib/ssl.py index b1cc149d87..e009697164 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 2ed1e5f2d7..29f7f7d84b 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'' @@ -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.  | 
