diff options
author | Andrew Svetlov <andrew.svetlov@gmail.com> | 2012-10-06 10:52:19 (GMT) |
---|---|---|
committer | Andrew Svetlov <andrew.svetlov@gmail.com> | 2012-10-06 10:52:19 (GMT) |
commit | ef08fb1f040cb51e752c6b1322008714262fbf3e (patch) | |
tree | a4617bbf91a1a2ca34304e63824838de777fca2e /Lib | |
parent | dc22587df2a577cdcdd21f3aec629e22b07f4263 (diff) | |
download | cpython-ef08fb1f040cb51e752c6b1322008714262fbf3e.zip cpython-ef08fb1f040cb51e752c6b1322008714262fbf3e.tar.gz cpython-ef08fb1f040cb51e752c6b1322008714262fbf3e.tar.bz2 |
Issue #13896: Make shelf instances work with 'with' as context managers.
Original patch by Filip GruszczyĆski.
Diffstat (limited to 'Lib')
-rw-r--r-- | Lib/shelve.py | 7 | ||||
-rw-r--r-- | Lib/test/test_shelve.py | 13 |
2 files changed, 20 insertions, 0 deletions
diff --git a/Lib/shelve.py b/Lib/shelve.py index cc1815e..cfb6863 100644 --- a/Lib/shelve.py +++ b/Lib/shelve.py @@ -131,6 +131,12 @@ class Shelf(collections.MutableMapping): except KeyError: pass + def __enter__(self): + return self + + def __exit__(self, type, value, traceback): + self.close() + def close(self): self.sync() try: @@ -147,6 +153,7 @@ class Shelf(collections.MutableMapping): def __del__(self): if not hasattr(self, 'writeback'): # __init__ didn't succeed, so don't bother closing + # see http://bugs.python.org/issue1339007 for details return self.close() diff --git a/Lib/test/test_shelve.py b/Lib/test/test_shelve.py index 13c1265..bd51d86 100644 --- a/Lib/test/test_shelve.py +++ b/Lib/test/test_shelve.py @@ -148,6 +148,19 @@ class TestCase(unittest.TestCase): p2 = d[encodedkey] self.assertNotEqual(p1, p2) # Write creates new object in store + def test_with(self): + d1 = {} + with shelve.Shelf(d1, protocol=2, writeback=False) as s: + s['key1'] = [1,2,3,4] + self.assertEqual(s['key1'], [1,2,3,4]) + self.assertEqual(len(s), 1) + self.assertRaises(ValueError, len, s) + try: + s['key1'] + except ValueError: + pass + else: + self.fail('Closed shelf should not find a key') from test import mapping_tests |