diff options
author | Charles-François Natali <cf.natali@gmail.com> | 2014-10-13 18:19:26 (GMT) |
---|---|---|
committer | Charles-François Natali <cf.natali@gmail.com> | 2014-10-13 18:19:26 (GMT) |
commit | 0f4f048fa5ff06438a4624bc1dc02aa458a79748 (patch) | |
tree | 26aa0625a57f2e7d49c3c93a9a7c30d3b9d4f631 /Lib | |
parent | efc7258377e79cff0ea41f97fa999873325e2fb5 (diff) | |
download | cpython-0f4f048fa5ff06438a4624bc1dc02aa458a79748.zip cpython-0f4f048fa5ff06438a4624bc1dc02aa458a79748.tar.gz cpython-0f4f048fa5ff06438a4624bc1dc02aa458a79748.tar.bz2 |
Issue #22435: Fix a file descriptor leak when SocketServer bind fails.
Diffstat (limited to 'Lib')
-rw-r--r-- | Lib/socketserver.py | 8 | ||||
-rw-r--r-- | Lib/test/test_socketserver.py | 10 |
2 files changed, 16 insertions, 2 deletions
diff --git a/Lib/socketserver.py b/Lib/socketserver.py index 2f395fa..7339911 100644 --- a/Lib/socketserver.py +++ b/Lib/socketserver.py @@ -426,8 +426,12 @@ class TCPServer(BaseServer): self.socket = socket.socket(self.address_family, self.socket_type) if bind_and_activate: - self.server_bind() - self.server_activate() + try: + self.server_bind() + self.server_activate() + except: + self.server_close() + raise def server_bind(self): """Called by constructor to bind the socket. diff --git a/Lib/test/test_socketserver.py b/Lib/test/test_socketserver.py index 0617b30..0276f99 100644 --- a/Lib/test/test_socketserver.py +++ b/Lib/test/test_socketserver.py @@ -302,6 +302,16 @@ class SocketServerTest(unittest.TestCase): t.join() s.server_close() + def test_tcpserver_bind_leak(self): + # Issue #22435: the server socket wouldn't be closed if bind()/listen() + # failed. + # Create many servers for which bind() will fail, to see if this result + # in FD exhaustion. + for i in range(1024): + with self.assertRaises(OverflowError): + socketserver.TCPServer((HOST, -1), + socketserver.StreamRequestHandler) + def test_main(): if imp.lock_held(): |