diff options
| author | Serhiy Storchaka <storchaka@gmail.com> | 2016-01-19 14:48:42 +0200 |
|---|---|---|
| committer | Serhiy Storchaka <storchaka@gmail.com> | 2016-01-19 14:48:42 +0200 |
| commit | 4918b47c64cd69b3fecc1a7d9adcca82f6ec711c (patch) | |
| tree | 7dd19bdc5818839e279289d23c75ab8c7cf19797 /Lib/test | |
| parent | 31a858cbf1eca34f04dd425fa7f8d6f031e5de66 (diff) | |
| parent | d205d0145c8f5a37d0a46261eb0193e27b5b0ad8 (diff) | |
| download | cpython-git-4918b47c64cd69b3fecc1a7d9adcca82f6ec711c.tar.gz | |
Issue #25935: Garbage collector now breaks reference loops with OrderedDict.
Diffstat (limited to 'Lib/test')
| -rw-r--r-- | Lib/test/test_ordered_dict.py | 13 |
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): |
