diff options
author | Antoine Pitrou <solipsis@pitrou.net> | 2014-10-17 22:35:44 (GMT) |
---|---|---|
committer | Antoine Pitrou <solipsis@pitrou.net> | 2014-10-17 22:35:44 (GMT) |
commit | bc92bbd4d22e82e9458a3300c50b89e80b2c2d60 (patch) | |
tree | 54b073cdefd6e484fca89d31e8bd5ca57557f85a /Lib | |
parent | 4dc7278546992f1d985dd296fc0c0d884b57f0a5 (diff) | |
parent | d6967320256a65b847cfc64173d12bf818171db5 (diff) | |
download | cpython-bc92bbd4d22e82e9458a3300c50b89e80b2c2d60.zip cpython-bc92bbd4d22e82e9458a3300c50b89e80b2c2d60.tar.gz cpython-bc92bbd4d22e82e9458a3300c50b89e80b2c2d60.tar.bz2 |
Issue #22653: Fix an assertion failure in debug mode when doing a reentrant dict insertion in debug mode.
Diffstat (limited to 'Lib')
-rw-r--r-- | Lib/test/test_dict.py | 29 |
1 files changed, 29 insertions, 0 deletions
diff --git a/Lib/test/test_dict.py b/Lib/test/test_dict.py index a388959..98d8a3b 100644 --- a/Lib/test/test_dict.py +++ b/Lib/test/test_dict.py @@ -906,6 +906,35 @@ class DictTest(unittest.TestCase): f.a = 'a' self.assertEqual(f.__dict__, {1:1, 'a':'a'}) + def check_reentrant_insertion(self, mutate): + # This object will trigger mutation of the dict when replaced + # by another value. Note this relies on refcounting: the test + # won't achieve its purpose on fully-GCed Python implementations. + class Mutating: + def __del__(self): + mutate(d) + + d = {k: Mutating() for k in 'abcdefghijklmnopqr'} + for k in list(d): + d[k] = k + + def test_reentrant_insertion(self): + # Reentrant insertion shouldn't crash (see issue #22653) + def mutate(d): + d['b'] = 5 + self.check_reentrant_insertion(mutate) + + def mutate(d): + d.update(self.__dict__) + d.clear() + self.check_reentrant_insertion(mutate) + + def mutate(d): + while d: + d.popitem() + self.check_reentrant_insertion(mutate) + + from test import mapping_tests class GeneralMappingTests(mapping_tests.BasicTestMappingProtocol): |