summaryrefslogtreecommitdiffstats
path: root/Lib
diff options
context:
space:
mode:
authorR. David Murray <rdmurray@bitdance.com>2010-02-11 03:06:51 (GMT)
committerR. David Murray <rdmurray@bitdance.com>2010-02-11 03:06:51 (GMT)
commit733ecdcc2f88a4231853c364aacb702b7a6949f9 (patch)
tree8e77de4b09605ee7aab038f1a4a08b4315c6fb90 /Lib
parent709b4c35cc6e6f5db58d9e440b5ca732b7fdb6a2 (diff)
downloadcpython-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.py9
-rw-r--r--Lib/test/test_shelve.py13
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