summaryrefslogtreecommitdiff
path: root/Lib/test/test_ordered_dict.py
diff options
context:
space:
mode:
authorSerhiy Storchaka <storchaka@gmail.com>2016-01-19 14:48:42 +0200
committerSerhiy Storchaka <storchaka@gmail.com>2016-01-19 14:48:42 +0200
commit4918b47c64cd69b3fecc1a7d9adcca82f6ec711c (patch)
tree7dd19bdc5818839e279289d23c75ab8c7cf19797 /Lib/test/test_ordered_dict.py
parent31a858cbf1eca34f04dd425fa7f8d6f031e5de66 (diff)
parentd205d0145c8f5a37d0a46261eb0193e27b5b0ad8 (diff)
downloadcpython-git-4918b47c64cd69b3fecc1a7d9adcca82f6ec711c.tar.gz
Issue #25935: Garbage collector now breaks reference loops with OrderedDict.
Diffstat (limited to 'Lib/test/test_ordered_dict.py')
-rw-r--r--Lib/test/test_ordered_dict.py13
1 files changed, 13 insertions, 0 deletions
diff --git a/Lib/test/test_ordered_dict.py b/Lib/test/test_ordered_dict.py
index 9f9922cb71..633e90919b 100644
--- a/Lib/test/test_ordered_dict.py
+++ b/Lib/test/test_ordered_dict.py
@@ -1,10 +1,12 @@
import contextlib
import copy
+import gc
import pickle
from random import randrange, shuffle
import struct
import sys
import unittest
+import weakref
from collections.abc import MutableMapping
from test import mapping_tests, support
@@ -593,6 +595,17 @@ class OrderedDictTests:
dict.update(od, [('spam', 1)])
self.assertNotIn('NULL', repr(od))
+ def test_reference_loop(self):
+ # Issue 25935
+ OrderedDict = self.OrderedDict
+ class A:
+ od = OrderedDict()
+ A.od[A] = None
+ r = weakref.ref(A)
+ del A
+ gc.collect()
+ self.assertIsNone(r())
+
class PurePythonOrderedDictTests(OrderedDictTests, unittest.TestCase):