summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorCharles-François Natali <cf.natali@gmail.com>2014-10-13 17:39:34 (GMT)
committerCharles-François Natali <cf.natali@gmail.com>2014-10-13 17:39:34 (GMT)
commit977c424ef6e806d9ae8e1c385c21811f1a050ac8 (patch)
treee63ad75e0aba5f71ad582e29aeb2400c11b620a8
parentc468abafc7a8690be365d1eb192c4551b03c2856 (diff)
downloadcpython-977c424ef6e806d9ae8e1c385c21811f1a050ac8.zip
cpython-977c424ef6e806d9ae8e1c385c21811f1a050ac8.tar.gz
cpython-977c424ef6e806d9ae8e1c385c21811f1a050ac8.tar.bz2
Issue #22435: Fix a file descriptor leak when SocketServer bind fails.
-rw-r--r--Lib/SocketServer.py8
-rw-r--r--Lib/test/test_socketserver.py10
-rw-r--r--Misc/NEWS2
3 files changed, 18 insertions, 2 deletions
diff --git a/Lib/SocketServer.py b/Lib/SocketServer.py
index afb8686..23ce6fc 100644
--- a/Lib/SocketServer.py
+++ b/Lib/SocketServer.py
@@ -416,8 +416,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 83f5e3f..8707017 100644
--- a/Lib/test/test_socketserver.py
+++ b/Lib/test/test_socketserver.py
@@ -314,6 +314,16 @@ class SocketServerTest(unittest.TestCase):
for t, s in threads:
t.join()
+ 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():
diff --git a/Misc/NEWS b/Misc/NEWS
index 27a6322..62f3deb 100644
--- a/Misc/NEWS
+++ b/Misc/NEWS
@@ -19,6 +19,8 @@ Core and Builtins
Library
-------
+- Issue #22435: Fix a file descriptor leak when SocketServer bind fails.
+
- Issue #21580: Now Tkinter correctly handles binary "data" and "maskdata"
configure options of tkinter.PhotoImage.