add test code for cursor
svn: r5958
This commit is contained in:
parent
3a54eb7edd
commit
f6ae3f18c2
163
test/GrampsDb/Cursor_Test.py
Normal file
163
test/GrampsDb/Cursor_Test.py
Normal file
@ -0,0 +1,163 @@
|
||||
import unittest
|
||||
import logging
|
||||
import os
|
||||
import tempfile
|
||||
import shutil
|
||||
import time
|
||||
import traceback
|
||||
import sys
|
||||
from bsddb import dbshelve, db
|
||||
|
||||
sys.path.append('../../src')
|
||||
|
||||
try:
|
||||
set()
|
||||
except NameError:
|
||||
from sets import Set as set
|
||||
|
||||
import const
|
||||
import RelLib
|
||||
|
||||
logger = logging.getLogger('Gramps.GrampsDbBase_Test')
|
||||
|
||||
from GrampsDbTestBase import GrampsDbBaseTest
|
||||
import GrampsDb
|
||||
|
||||
class Data(object):
|
||||
|
||||
def __init__(self,handle,surname,name):
|
||||
self.handle = handle
|
||||
self.surname = surname
|
||||
self.name = name
|
||||
|
||||
## def __repr__(self):
|
||||
## return repr((self.handle,self.surname,self.name))
|
||||
|
||||
class CursorTest(unittest.TestCase):
|
||||
"""Test the cursor handling."""
|
||||
|
||||
def setUp(self):
|
||||
self._tmpdir = tempfile.mkdtemp()
|
||||
self.full_name = os.path.join(self._tmpdir,'test.grdb')
|
||||
self.env = db.DBEnv()
|
||||
self.env.set_cachesize(0,0x2000000)
|
||||
self.env.set_lk_max_locks(25000)
|
||||
self.env.set_lk_max_objects(25000)
|
||||
self.env.set_flags(db.DB_LOG_AUTOREMOVE,1) # clean up unused logs
|
||||
# The DB_PRIVATE flag must go if we ever move to multi-user setup
|
||||
env_flags = db.DB_CREATE|db.DB_RECOVER|db.DB_PRIVATE|\
|
||||
db.DB_INIT_MPOOL|db.DB_INIT_LOCK|\
|
||||
db.DB_INIT_LOG|db.DB_INIT_TXN
|
||||
|
||||
env_name = "%s/env" % (self._tmpdir,)
|
||||
if not os.path.isdir(env_name):
|
||||
os.mkdir(env_name)
|
||||
self.env.open(env_name,env_flags)
|
||||
(self.person_map,self.surnames) = self._open_tables()
|
||||
|
||||
def _open_tables(self):
|
||||
dbmap = dbshelve.DBShelf(self.env)
|
||||
dbmap.db.set_pagesize(16384)
|
||||
dbmap.open(self.full_name, 'person', db.DB_HASH,
|
||||
db.DB_CREATE|db.DB_AUTO_COMMIT, 0666)
|
||||
person_map = dbmap
|
||||
|
||||
table_flags = db.DB_CREATE|db.DB_AUTO_COMMIT
|
||||
|
||||
surnames = db.DB(self.env)
|
||||
surnames.set_flags(db.DB_DUP|db.DB_DUPSORT)
|
||||
surnames.open(self.full_name, "surnames", db.DB_BTREE,
|
||||
flags=table_flags)
|
||||
|
||||
def find_surname(key,data):
|
||||
return data.surname
|
||||
|
||||
person_map.associate(surnames, find_surname, table_flags)
|
||||
|
||||
return (person_map,surnames)
|
||||
|
||||
def tearDown(self):
|
||||
shutil.rmtree(self._tmpdir)
|
||||
|
||||
def test_simple_insert(self):
|
||||
"""test insert and retrieve works."""
|
||||
|
||||
data = Data(str(1),'surname1','name1')
|
||||
the_txn = self.env.txn_begin()
|
||||
self.person_map.put(data.handle,data,txn=the_txn)
|
||||
the_txn.commit()
|
||||
|
||||
v = self.person_map.get(data.handle)
|
||||
|
||||
assert v.handle == data.handle
|
||||
|
||||
def test_insert_with_curor_closed(self):
|
||||
"""test_insert_with_curor_closed"""
|
||||
|
||||
cursor_txn = self.env.txn_begin()
|
||||
|
||||
cursor = self.surnames.cursor(txn=cursor_txn)
|
||||
cursor.first()
|
||||
cursor.next()
|
||||
cursor.close()
|
||||
cursor_txn.commit()
|
||||
|
||||
data = Data(str(2),'surname2','name2')
|
||||
the_txn = self.env.txn_begin()
|
||||
self.person_map.put(data.handle,data,txn=the_txn)
|
||||
the_txn.commit()
|
||||
|
||||
v = self.person_map.get(data.handle)
|
||||
|
||||
assert v.handle == data.handle
|
||||
|
||||
def test_insert_with_curor_open(self):
|
||||
"""test_insert_with_curor_open"""
|
||||
|
||||
cursor_txn = self.env.txn_begin()
|
||||
cursor = self.surnames.cursor(txn=cursor_txn)
|
||||
cursor.first()
|
||||
cursor.next()
|
||||
|
||||
data = Data(str(2),'surname2','name2')
|
||||
the_txn = self.env.txn_begin()
|
||||
self.person_map.put(data.handle,data,txn=the_txn)
|
||||
the_txn.commit()
|
||||
|
||||
cursor.close()
|
||||
cursor_txn.commit()
|
||||
|
||||
v = self.person_map.get(data.handle)
|
||||
|
||||
assert v.handle == data.handle
|
||||
|
||||
def xtest_insert_with_curor_open_and_db_open(self):
|
||||
"""test_insert_with_curor_open_and_db_open"""
|
||||
|
||||
(person2,surnames2) = self._open_tables()
|
||||
|
||||
cursor_txn = self.env.txn_begin()
|
||||
cursor = surnames2.cursor(txn=cursor_txn)
|
||||
cursor.first()
|
||||
cursor.next()
|
||||
|
||||
data = Data(str(2),'surname2','name2')
|
||||
the_txn = self.env.txn_begin()
|
||||
self.person_map.put(data.handle,data,txn=the_txn)
|
||||
the_txn.commit()
|
||||
|
||||
cursor.close()
|
||||
cursor_txn.commit()
|
||||
|
||||
v = self.person_map.get(data.handle)
|
||||
|
||||
assert v.handle == data.handle
|
||||
|
||||
|
||||
def testSuite():
|
||||
suite = unittest.makeSuite(CursorTest,'test')
|
||||
return suite
|
||||
|
||||
|
||||
if __name__ == '__main__':
|
||||
unittest.TextTestRunner().run(testSuite())
|
Loading…
Reference in New Issue
Block a user