]> git.ipfire.org Git - thirdparty/Python/cpython.git/commitdiff
Issue #23209, #23225: selectors.BaseSelector.close() now clears its internal
authorVictor Stinner <victor.stinner@gmail.com>
Tue, 13 Jan 2015 08:58:33 +0000 (09:58 +0100)
committerVictor Stinner <victor.stinner@gmail.com>
Tue, 13 Jan 2015 08:58:33 +0000 (09:58 +0100)
reference to the selector mapping to break a reference cycle. Initial patch
written by Martin Richard.

Lib/selectors.py
Lib/test/test_selectors.py
Misc/NEWS

index e4ad4cb18c4a593f2cee66fd36fa9c83f7de04a4..beb7ef7741142c71bfcbcd118dc2171cc4375ca8 100644 (file)
@@ -175,6 +175,8 @@ class BaseSelector(metaclass=ABCMeta):
         """
         mapping = self.get_map()
         try:
+            if mapping is None:
+                raise KeyError
             return mapping[fileobj]
         except KeyError:
             raise KeyError("{!r} is not registered".format(fileobj)) from None
@@ -256,6 +258,7 @@ class _BaseSelectorImpl(BaseSelector):
 
     def close(self):
         self._fd_to_key.clear()
+        self._map = None
 
     def get_map(self):
         return self._map
index f9aac5005e48e28d2e8dfc1907002eda4f213488..dd30d441e6e9cee0108b1a5bc8783019d4e885e3 100644 (file)
@@ -180,6 +180,7 @@ class BaseSelectorTestCase(unittest.TestCase):
         s = self.SELECTOR()
         self.addCleanup(s.close)
 
+        mapping = s.get_map()
         rd, wr = self.make_socketpair()
 
         s.register(rd, selectors.EVENT_READ)
@@ -188,6 +189,8 @@ class BaseSelectorTestCase(unittest.TestCase):
         s.close()
         self.assertRaises(KeyError, s.get_key, rd)
         self.assertRaises(KeyError, s.get_key, wr)
+        self.assertRaises(KeyError, mapping.__getitem__, rd)
+        self.assertRaises(KeyError, mapping.__getitem__, wr)
 
     def test_get_key(self):
         s = self.SELECTOR()
index 08a02f2890025e4c99ad6a29fe88f03e6e10651c..96e34e496c533a2478e56f8439c7b9a1cf300ab1 100644 (file)
--- a/Misc/NEWS
+++ b/Misc/NEWS
@@ -44,6 +44,10 @@ Core and Builtins
 Library
 -------
 
+- Issue #23209, #23225: selectors.BaseSelector.close() now clears its internal
+  reference to the selector mapping to break a reference cycle. Initial patch
+  written by Martin Richard.
+
 - Issue #21356: Make ssl.RAND_egd() optional to support LibreSSL. The
   availability of the function is checked during the compilation. Patch written
   by Bernard Spil.