https://github.com/python/cpython/commit/192d17c3fd9945104bc0303cf248bb0d074d260e
commit: 192d17c3fd9945104bc0303cf248bb0d074d260e
branch: main
author: Idan Kapustian <[email protected]>
committer: vsajip <[email protected]>
date: 2024-06-16T13:15:03+01:00
summary:

gh-120485: Add an override of `allow_reuse_port` on classes subclassing 
`socketserver.TCPServer` (GH-120488)

Co-authored-by: Vinay Sajip <[email protected]>

files:
A Misc/NEWS.d/next/Core and 
Builtins/2024-06-14-07-52-00.gh-issue-120485.yy4K4b.rst
M Lib/http/server.py
M Lib/logging/config.py
M Lib/test/test_logging.py
M Lib/xmlrpc/server.py

diff --git a/Lib/http/server.py b/Lib/http/server.py
index 7d0da5052d2d4d..2d010649e56b51 100644
--- a/Lib/http/server.py
+++ b/Lib/http/server.py
@@ -129,7 +129,8 @@
 
 class HTTPServer(socketserver.TCPServer):
 
-    allow_reuse_address = 1    # Seems to make sense in testing environment
+    allow_reuse_address = True    # Seems to make sense in testing environment
+    allow_reuse_port = True
 
     def server_bind(self):
         """Override server_bind to store the server name."""
diff --git a/Lib/logging/config.py b/Lib/logging/config.py
index 9de84e527b18ac..d2f23e53f35c57 100644
--- a/Lib/logging/config.py
+++ b/Lib/logging/config.py
@@ -984,7 +984,8 @@ class ConfigSocketReceiver(ThreadingTCPServer):
         A simple TCP socket-based logging config receiver.
         """
 
-        allow_reuse_address = 1
+        allow_reuse_address = True
+        allow_reuse_port = True
 
         def __init__(self, host='localhost', port=DEFAULT_LOGGING_CONFIG_PORT,
                      handler=None, ready=None, verify=None):
diff --git a/Lib/test/test_logging.py b/Lib/test/test_logging.py
index 504862ad53395e..5192ce252a4d4c 100644
--- a/Lib/test/test_logging.py
+++ b/Lib/test/test_logging.py
@@ -1038,6 +1038,7 @@ class TestTCPServer(ControlMixin, ThreadingTCPServer):
     """
 
     allow_reuse_address = True
+    allow_reuse_port = True
 
     def __init__(self, addr, handler, poll_interval=0.5,
                  bind_and_activate=True):
diff --git a/Lib/xmlrpc/server.py b/Lib/xmlrpc/server.py
index 4dddb1d10e08bd..90a356fbb8eae4 100644
--- a/Lib/xmlrpc/server.py
+++ b/Lib/xmlrpc/server.py
@@ -578,6 +578,7 @@ class SimpleXMLRPCServer(socketserver.TCPServer,
     """
 
     allow_reuse_address = True
+    allow_reuse_port = True
 
     # Warning: this is for debugging purposes only! Never set this to True in
     # production code, as will be sending out sensitive information (exception
diff --git a/Misc/NEWS.d/next/Core and 
Builtins/2024-06-14-07-52-00.gh-issue-120485.yy4K4b.rst b/Misc/NEWS.d/next/Core 
and Builtins/2024-06-14-07-52-00.gh-issue-120485.yy4K4b.rst
new file mode 100644
index 00000000000000..f41c233908362f
--- /dev/null
+++ b/Misc/NEWS.d/next/Core and 
Builtins/2024-06-14-07-52-00.gh-issue-120485.yy4K4b.rst 
@@ -0,0 +1 @@
+Add an override of ``allow_reuse_port`` on classes subclassing 
``socketserver.TCPServer`` where ``allow_reuse_address`` is also overridden.

_______________________________________________
Python-checkins mailing list -- [email protected]
To unsubscribe send an email to [email protected]
https://mail.python.org/mailman3/lists/python-checkins.python.org/
Member address: [email protected]

Reply via email to