applies the better dbm and shelve related unittests. bug 1007 from larryhastings
This commit is contained in:
parent
41cfce9c2b
commit
178fefb9b5
@ -11,7 +11,33 @@ from test import test_support
|
|||||||
|
|
||||||
_fname = test_support.TESTFN
|
_fname = test_support.TESTFN
|
||||||
|
|
||||||
def _delete_files():
|
_all_modules = []
|
||||||
|
|
||||||
|
for _name in anydbm._names:
|
||||||
|
try:
|
||||||
|
_module = __import__(_name)
|
||||||
|
except ImportError:
|
||||||
|
continue
|
||||||
|
_all_modules.append(_module)
|
||||||
|
|
||||||
|
|
||||||
|
#
|
||||||
|
# Iterates over every database module supported by anydbm
|
||||||
|
# currently available, setting anydbm to use each in turn,
|
||||||
|
# and yielding that module
|
||||||
|
#
|
||||||
|
def dbm_iterator():
|
||||||
|
old_default = anydbm._defaultmod
|
||||||
|
for module in _all_modules:
|
||||||
|
anydbm._defaultmod = module
|
||||||
|
yield module
|
||||||
|
anydbm._defaultmod = old_default
|
||||||
|
|
||||||
|
#
|
||||||
|
# Clean up all scratch databases we might have created
|
||||||
|
# during testing
|
||||||
|
#
|
||||||
|
def delete_files():
|
||||||
# we don't know the precise name the underlying database uses
|
# we don't know the precise name the underlying database uses
|
||||||
# so we use glob to locate all names
|
# so we use glob to locate all names
|
||||||
for f in glob.glob(_fname + "*"):
|
for f in glob.glob(_fname + "*"):
|
||||||
@ -60,6 +86,14 @@ class AnyDBMTestCase(unittest.TestCase):
|
|||||||
keys = self.keys_helper(f)
|
keys = self.keys_helper(f)
|
||||||
f.close()
|
f.close()
|
||||||
|
|
||||||
|
def test_anydbm_access(self):
|
||||||
|
self.init_db()
|
||||||
|
f = anydbm.open(_fname, 'r')
|
||||||
|
key = "a".encode("ascii")
|
||||||
|
assert(key in f)
|
||||||
|
assert(f[key] == b"Python:")
|
||||||
|
f.close()
|
||||||
|
|
||||||
def read_helper(self, f):
|
def read_helper(self, f):
|
||||||
keys = self.keys_helper(f)
|
keys = self.keys_helper(f)
|
||||||
for key in self._dict:
|
for key in self._dict:
|
||||||
@ -78,16 +112,18 @@ class AnyDBMTestCase(unittest.TestCase):
|
|||||||
return keys
|
return keys
|
||||||
|
|
||||||
def tearDown(self):
|
def tearDown(self):
|
||||||
_delete_files()
|
delete_files()
|
||||||
|
|
||||||
def setUp(self):
|
def setUp(self):
|
||||||
_delete_files()
|
delete_files()
|
||||||
|
|
||||||
|
|
||||||
def test_main():
|
def test_main():
|
||||||
try:
|
try:
|
||||||
test_support.run_unittest(AnyDBMTestCase)
|
for module in dbm_iterator():
|
||||||
|
test_support.run_unittest(AnyDBMTestCase)
|
||||||
finally:
|
finally:
|
||||||
_delete_files()
|
delete_files()
|
||||||
|
|
||||||
if __name__ == "__main__":
|
if __name__ == "__main__":
|
||||||
test_main()
|
test_main()
|
||||||
|
@ -89,6 +89,12 @@ class DumbDBMTestCase(unittest.TestCase):
|
|||||||
keys = self.keys_helper(f)
|
keys = self.keys_helper(f)
|
||||||
f.close()
|
f.close()
|
||||||
|
|
||||||
|
def test_write_contains(self):
|
||||||
|
f = dumbdbm.open(_fname)
|
||||||
|
f[b'1'] = b'hello'
|
||||||
|
assert b'1' in f
|
||||||
|
f.close()
|
||||||
|
|
||||||
def test_write_write_read(self):
|
def test_write_write_read(self):
|
||||||
# test for bug #482460
|
# test for bug #482460
|
||||||
f = dumbdbm.open(_fname)
|
f = dumbdbm.open(_fname)
|
||||||
|
@ -3,6 +3,7 @@ import shelve
|
|||||||
import glob
|
import glob
|
||||||
from test import test_support
|
from test import test_support
|
||||||
from UserDict import DictMixin
|
from UserDict import DictMixin
|
||||||
|
from test.test_anydbm import dbm_iterator
|
||||||
|
|
||||||
def L1(s):
|
def L1(s):
|
||||||
return s.decode("latin-1")
|
return s.decode("latin-1")
|
||||||
@ -148,15 +149,16 @@ class TestProto2MemShelve(TestShelveBase):
|
|||||||
_in_mem = True
|
_in_mem = True
|
||||||
|
|
||||||
def test_main():
|
def test_main():
|
||||||
test_support.run_unittest(
|
for module in dbm_iterator():
|
||||||
TestAsciiFileShelve,
|
test_support.run_unittest(
|
||||||
TestBinaryFileShelve,
|
TestAsciiFileShelve,
|
||||||
TestProto2FileShelve,
|
TestBinaryFileShelve,
|
||||||
TestAsciiMemShelve,
|
TestProto2FileShelve,
|
||||||
TestBinaryMemShelve,
|
TestAsciiMemShelve,
|
||||||
TestProto2MemShelve,
|
TestBinaryMemShelve,
|
||||||
TestCase
|
TestProto2MemShelve,
|
||||||
)
|
TestCase
|
||||||
|
)
|
||||||
|
|
||||||
if __name__ == "__main__":
|
if __name__ == "__main__":
|
||||||
test_main()
|
test_main()
|
||||||
|
@ -10,57 +10,49 @@ import whichdb
|
|||||||
import anydbm
|
import anydbm
|
||||||
import tempfile
|
import tempfile
|
||||||
import glob
|
import glob
|
||||||
|
from test.test_anydbm import delete_files, dbm_iterator
|
||||||
|
|
||||||
_fname = test.test_support.TESTFN
|
_fname = test.test_support.TESTFN
|
||||||
|
|
||||||
def _delete_files():
|
|
||||||
# we don't know the precise name the underlying database uses
|
|
||||||
# so we use glob to locate all names
|
|
||||||
for f in glob.glob(_fname + "*"):
|
|
||||||
try:
|
|
||||||
os.unlink(f)
|
|
||||||
except OSError:
|
|
||||||
pass
|
|
||||||
|
|
||||||
class WhichDBTestCase(unittest.TestCase):
|
class WhichDBTestCase(unittest.TestCase):
|
||||||
# Actual test methods are added to namespace
|
# Actual test methods are added to namespace
|
||||||
# after class definition.
|
# after class definition.
|
||||||
def __init__(self, *args):
|
def __init__(self, *args):
|
||||||
unittest.TestCase.__init__(self, *args)
|
unittest.TestCase.__init__(self, *args)
|
||||||
|
|
||||||
|
def test_whichdb(self):
|
||||||
|
for module in dbm_iterator():
|
||||||
|
# Check whether whichdb correctly guesses module name
|
||||||
|
# for databases opened with "module" module.
|
||||||
|
# Try with empty files first
|
||||||
|
name = module.__name__
|
||||||
|
if name == 'dumbdbm':
|
||||||
|
continue # whichdb can't support dumbdbm
|
||||||
|
f = module.open(_fname, 'c')
|
||||||
|
f.close()
|
||||||
|
self.assertEqual(name, whichdb.whichdb(_fname))
|
||||||
|
# Now add a key
|
||||||
|
f = module.open(_fname, 'w')
|
||||||
|
f[b"1"] = b"1"
|
||||||
|
# and test that we can find it
|
||||||
|
assert b"1" in f
|
||||||
|
# and read it
|
||||||
|
assert f[b"1"] == b"1"
|
||||||
|
f.close()
|
||||||
|
self.assertEqual(name, whichdb.whichdb(_fname))
|
||||||
|
|
||||||
def tearDown(self):
|
def tearDown(self):
|
||||||
_delete_files()
|
delete_files()
|
||||||
|
|
||||||
def setUp(self):
|
def setUp(self):
|
||||||
_delete_files()
|
delete_files()
|
||||||
|
|
||||||
for name in anydbm._names:
|
|
||||||
# we define a new test method for each
|
|
||||||
# candidate database module.
|
|
||||||
try:
|
|
||||||
mod = __import__(name)
|
|
||||||
except ImportError:
|
|
||||||
continue
|
|
||||||
|
|
||||||
def test_whichdb_name(self, name=name, mod=mod):
|
|
||||||
# Check whether whichdb correctly guesses module name
|
|
||||||
# for databases opened with module mod.
|
|
||||||
# Try with empty files first
|
|
||||||
f = mod.open(_fname, 'c')
|
|
||||||
f.close()
|
|
||||||
self.assertEqual(name, whichdb.whichdb(_fname))
|
|
||||||
# Now add a key
|
|
||||||
f = mod.open(_fname, 'w')
|
|
||||||
f[b"1"] = b"1"
|
|
||||||
f.close()
|
|
||||||
self.assertEqual(name, whichdb.whichdb(_fname))
|
|
||||||
setattr(WhichDBTestCase,"test_whichdb_%s" % name, test_whichdb_name)
|
|
||||||
|
|
||||||
def test_main():
|
def test_main():
|
||||||
try:
|
try:
|
||||||
test.test_support.run_unittest(WhichDBTestCase)
|
test.test_support.run_unittest(WhichDBTestCase)
|
||||||
finally:
|
finally:
|
||||||
_delete_files()
|
delete_files()
|
||||||
|
|
||||||
if __name__ == "__main__":
|
if __name__ == "__main__":
|
||||||
test_main()
|
test_main()
|
||||||
|
Loading…
x
Reference in New Issue
Block a user