bpo-31026: Fix test_dbm if dbm.ndbm is build with Berkeley DB. (GH-6632)
(cherry picked from commit 70af06cdc4e8fbee0b9d7d46bdc193097d4bc71f)
Co-authored-by: Serhiy Storchaka <storchaka@gmail.com>
diff --git a/Lib/test/test_dbm.py b/Lib/test/test_dbm.py
index fb89807..78c32c4 100644
--- a/Lib/test/test_dbm.py
+++ b/Lib/test/test_dbm.py
@@ -38,8 +38,7 @@
class AnyDBMTestCase:
- _dict = {'0': b'',
- 'a': b'Python:',
+ _dict = {'a': b'Python:',
'b': b'Programming',
'c': b'the',
'd': b'way',
@@ -109,6 +108,20 @@
keys = self.keys_helper(f)
f.close()
+ def test_empty_value(self):
+ if getattr(dbm._defaultmod, 'library', None) == 'Berkeley DB':
+ self.skipTest("Berkeley DB doesn't distinguish the empty value "
+ "from the absent one")
+ f = dbm.open(_fname, 'c')
+ self.assertEqual(f.keys(), [])
+ f[b'empty'] = b''
+ self.assertEqual(f.keys(), [b'empty'])
+ self.assertIn(b'empty', f)
+ self.assertEqual(f[b'empty'], b'')
+ self.assertEqual(f.get(b'empty'), b'')
+ self.assertEqual(f.setdefault(b'empty'), b'')
+ f.close()
+
def test_anydbm_access(self):
self.init_db()
f = dbm.open(_fname, 'r')