diff options
author | R. David Murray <rdmurray@bitdance.com> | 2010-02-11 03:06:51 (GMT) |
---|---|---|
committer | R. David Murray <rdmurray@bitdance.com> | 2010-02-11 03:06:51 (GMT) |
commit | 733ecdcc2f88a4231853c364aacb702b7a6949f9 (patch) | |
tree | 8e77de4b09605ee7aab038f1a4a08b4315c6fb90 /Lib | |
parent | 709b4c35cc6e6f5db58d9e440b5ca732b7fdb6a2 (diff) | |
download | cpython-733ecdcc2f88a4231853c364aacb702b7a6949f9.zip cpython-733ecdcc2f88a4231853c364aacb702b7a6949f9.tar.gz cpython-733ecdcc2f88a4231853c364aacb702b7a6949f9.tar.bz2 |
Merged revisions 78145 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/branches/py3k
................
r78145 | r.david.murray | 2010-02-10 21:42:19 -0500 (Wed, 10 Feb 2010) | 18 lines
Merged revisions 78141-78142 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/trunk
........
r78141 | r.david.murray | 2010-02-10 20:38:42 -0500 (Wed, 10 Feb 2010) | 6 lines
Issue 5754: tweak shelve doc wording to make it clearer that even when
writeback=True values are written to the backing store when assigned to
the shelf. Add test to confirm that this happens. Doc patch and added
test by Robert Lehmann. I also fixed the cross references to the sync
and close methods.
........
r78142 | r.david.murray | 2010-02-10 20:56:42 -0500 (Wed, 10 Feb 2010) | 3 lines
Improve issue 7835 fix per MAL to handle the case that the
module dictionary has also been cleared.
........
................
Diffstat (limited to 'Lib')
-rw-r--r-- | Lib/shelve.py | 9 | ||||
-rw-r--r-- | Lib/test/test_shelve.py | 13 |
2 files changed, 18 insertions, 4 deletions
diff --git a/Lib/shelve.py b/Lib/shelve.py index 8271dfe..52e471a 100644 --- a/Lib/shelve.py +++ b/Lib/shelve.py @@ -136,11 +136,12 @@ class Shelf(collections.MutableMapping): self.dict.close() except AttributeError: pass - # _ClosedDict can be None when close is called from __del__ during shutdown - if _ClosedDict is None: - self.dict = None - else: + # Catch errors that may happen when close is called from __del__ + # because CPython is in interpreter shutdown. + try: self.dict = _ClosedDict() + except (NameError, TypeError): + self.dict = None def __del__(self): if not hasattr(self, 'writeback'): diff --git a/Lib/test/test_shelve.py b/Lib/test/test_shelve.py index 9699043..066208a 100644 --- a/Lib/test/test_shelve.py +++ b/Lib/test/test_shelve.py @@ -122,6 +122,19 @@ class TestCase(unittest.TestCase): self.assertEqual(len(d1), 1) self.assertEqual(len(d2), 1) + def test_writeback_also_writes_immediately(self): + # Issue 5754 + d = {} + key = 'key' + encodedkey = key.encode('utf-8') + s = shelve.Shelf(d, writeback=True) + s[key] = [1] + p1 = d[encodedkey] # Will give a KeyError if backing store not updated + s['key'].append(2) + s.close() + p2 = d[encodedkey] + self.assertNotEqual(p1, p2) # Write creates new object in store + from test import mapping_tests |