summaryrefslogtreecommitdiffstats
path: root/Lib
diff options
context:
space:
mode:
authorCharles-François Natali <cf.natali@gmail.com>2014-10-13 18:19:26 (GMT)
committerCharles-François Natali <cf.natali@gmail.com>2014-10-13 18:19:26 (GMT)
commit0f4f048fa5ff06438a4624bc1dc02aa458a79748 (patch)
tree26aa0625a57f2e7d49c3c93a9a7c30d3b9d4f631 /Lib
parentefc7258377e79cff0ea41f97fa999873325e2fb5 (diff)
downloadcpython-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.py8
-rw-r--r--Lib/test/test_socketserver.py10
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():