2002-12-30 16:53:52 -04:00
|
|
|
"""TestCases for checking that it does not segfault when a DBEnv object
|
2002-11-19 13:47:07 -04:00
|
|
|
is closed before its DB objects.
|
|
|
|
"""
|
|
|
|
|
2002-12-30 16:53:52 -04:00
|
|
|
import os
|
2002-11-19 13:47:07 -04:00
|
|
|
import tempfile
|
|
|
|
import glob
|
|
|
|
import unittest
|
|
|
|
|
2003-01-28 13:20:44 -04:00
|
|
|
try:
|
2003-09-20 21:08:14 -03:00
|
|
|
# For Pythons w/distutils pybsddb
|
|
|
|
from bsddb3 import db
|
|
|
|
except ImportError:
|
2003-01-28 13:20:44 -04:00
|
|
|
# For Python 2.3
|
|
|
|
from bsddb import db
|
2002-11-19 13:47:07 -04:00
|
|
|
|
2002-12-30 16:53:52 -04:00
|
|
|
from test_all import verbose
|
|
|
|
|
|
|
|
# We're going to get warnings in this module about trying to close the db when
|
|
|
|
# its env is already closed. Let's just ignore those.
|
|
|
|
try:
|
|
|
|
import warnings
|
|
|
|
except ImportError:
|
|
|
|
pass
|
|
|
|
else:
|
|
|
|
warnings.filterwarnings('ignore',
|
|
|
|
message='DB could not be closed in',
|
|
|
|
category=RuntimeWarning)
|
2002-11-19 13:47:07 -04:00
|
|
|
|
|
|
|
|
|
|
|
#----------------------------------------------------------------------
|
|
|
|
|
|
|
|
class DBEnvClosedEarlyCrash(unittest.TestCase):
|
|
|
|
def setUp(self):
|
2007-01-05 11:51:24 -04:00
|
|
|
self.homeDir = os.path.join(tempfile.gettempdir(), 'db_home')
|
2002-11-19 13:47:07 -04:00
|
|
|
try: os.mkdir(self.homeDir)
|
|
|
|
except os.error: pass
|
|
|
|
tempfile.tempdir = self.homeDir
|
|
|
|
self.filename = os.path.split(tempfile.mktemp())[1]
|
|
|
|
tempfile.tempdir = None
|
|
|
|
|
|
|
|
def tearDown(self):
|
|
|
|
files = glob.glob(os.path.join(self.homeDir, '*'))
|
|
|
|
for file in files:
|
|
|
|
os.remove(file)
|
|
|
|
|
|
|
|
|
|
|
|
def test01_close_dbenv_before_db(self):
|
|
|
|
dbenv = db.DBEnv()
|
2002-12-30 16:53:52 -04:00
|
|
|
dbenv.open(self.homeDir,
|
|
|
|
db.DB_INIT_CDB| db.DB_CREATE |db.DB_THREAD|db.DB_INIT_MPOOL,
|
|
|
|
0666)
|
2002-11-19 13:47:07 -04:00
|
|
|
|
|
|
|
d = db.DB(dbenv)
|
|
|
|
d.open(self.filename, db.DB_BTREE, db.DB_CREATE | db.DB_THREAD, 0666)
|
|
|
|
|
|
|
|
try:
|
|
|
|
dbenv.close()
|
|
|
|
except db.DBError:
|
|
|
|
try:
|
|
|
|
d.close()
|
|
|
|
except db.DBError:
|
|
|
|
return
|
2002-12-30 16:53:52 -04:00
|
|
|
assert 0, \
|
|
|
|
"DB close did not raise an exception about its "\
|
|
|
|
"DBEnv being trashed"
|
2002-11-19 13:47:07 -04:00
|
|
|
|
2002-12-31 14:21:43 -04:00
|
|
|
# XXX This may fail when using older versions of BerkeleyDB.
|
|
|
|
# E.g. 3.2.9 never raised the exception.
|
2002-11-19 13:47:07 -04:00
|
|
|
assert 0, "dbenv did not raise an exception about its DB being open"
|
|
|
|
|
|
|
|
|
|
|
|
def test02_close_dbenv_delete_db_success(self):
|
|
|
|
dbenv = db.DBEnv()
|
2002-12-30 16:53:52 -04:00
|
|
|
dbenv.open(self.homeDir,
|
|
|
|
db.DB_INIT_CDB| db.DB_CREATE |db.DB_THREAD|db.DB_INIT_MPOOL,
|
|
|
|
0666)
|
2002-11-19 13:47:07 -04:00
|
|
|
|
|
|
|
d = db.DB(dbenv)
|
|
|
|
d.open(self.filename, db.DB_BTREE, db.DB_CREATE | db.DB_THREAD, 0666)
|
|
|
|
|
|
|
|
try:
|
|
|
|
dbenv.close()
|
|
|
|
except db.DBError:
|
|
|
|
pass # good, it should raise an exception
|
|
|
|
|
|
|
|
del d
|
|
|
|
try:
|
|
|
|
import gc
|
|
|
|
except ImportError:
|
|
|
|
gc = None
|
|
|
|
if gc:
|
|
|
|
# force d.__del__ [DB_dealloc] to be called
|
|
|
|
gc.collect()
|
|
|
|
|
|
|
|
|
|
|
|
#----------------------------------------------------------------------
|
|
|
|
|
2002-12-30 16:53:52 -04:00
|
|
|
def test_suite():
|
|
|
|
suite = unittest.TestSuite()
|
|
|
|
suite.addTest(unittest.makeSuite(DBEnvClosedEarlyCrash))
|
|
|
|
return suite
|
2002-11-19 13:47:07 -04:00
|
|
|
|
|
|
|
|
|
|
|
if __name__ == '__main__':
|
2002-12-30 16:53:52 -04:00
|
|
|
unittest.main(defaultTest='test_suite')
|