Fix and move db unit tests

svn: r22767
This commit is contained in:
Nick Hall 2013-07-29 16:34:16 +00:00
parent dcd8757a77
commit 471b6beace
3 changed files with 137 additions and 144 deletions

View File

@ -18,32 +18,19 @@
# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA # Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
# #
# test/GrampsDb/Cursor_Test.py
# $Id$ # $Id$
import unittest import unittest
import logging
import os import os
import tempfile import tempfile
import shutil import shutil
import time
import traceback
import sys
from bsddb import dbshelve, db from bsddb import dbshelve, db
sys.path.append('../../gramps')
try: try:
set() set()
except NameError: except NameError:
from sets import Set as set from sets import Set as set
import gramps.gen.const
logger = logging.getLogger('Gramps.GrampsDbBase_Test')
from GrampsDbTestBase import GrampsDbBaseTest
class Data(object): class Data(object):
def __init__(self, handle,surname, name): def __init__(self, handle,surname, name):
@ -64,7 +51,21 @@ class CursorTest(unittest.TestCase):
self.env.set_cachesize(0,0x2000000) self.env.set_cachesize(0,0x2000000)
self.env.set_lk_max_locks(25000) self.env.set_lk_max_locks(25000)
self.env.set_lk_max_objects(25000) self.env.set_lk_max_objects(25000)
self.env.set_flags(db.DB_LOG_AUTOREMOVE,1) # clean up unused logs
# clean up unused logs
autoremove_flag = None
autoremove_method = None
for flag in ["DB_LOG_AUTO_REMOVE", "DB_LOG_AUTOREMOVE"]:
if hasattr(db, flag):
autoremove_flag = getattr(db, flag)
break
for method in ["log_set_config", "set_flags"]:
if hasattr(self.env, method):
autoremove_method = getattr(self.env, method)
break
if autoremove_method and autoremove_flag:
autoremove_method(autoremove_flag, 1)
# The DB_PRIVATE flag must go if we ever move to multi-user setup # 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|\ env_flags = db.DB_CREATE|db.DB_RECOVER|db.DB_PRIVATE|\
db.DB_INIT_MPOOL|db.DB_INIT_LOCK|\ db.DB_INIT_MPOOL|db.DB_INIT_LOCK|\
@ -105,12 +106,12 @@ class CursorTest(unittest.TestCase):
data = Data(str(1),'surname1','name1') data = Data(str(1),'surname1','name1')
the_txn = self.env.txn_begin() the_txn = self.env.txn_begin()
self.person_map.put(data.handle,data,txn=the_txn) self.person_map.put(data.handle, data, txn=the_txn)
the_txn.commit() the_txn.commit()
v = self.person_map.get(data.handle) v = self.person_map.get(data.handle)
assert v.handle == data.handle self.assertEqual(v.handle, data.handle)
def test_insert_with_curor_closed(self): def test_insert_with_curor_closed(self):
"""test_insert_with_curor_closed""" """test_insert_with_curor_closed"""
@ -123,15 +124,16 @@ class CursorTest(unittest.TestCase):
cursor.close() cursor.close()
cursor_txn.commit() cursor_txn.commit()
data = Data(str(2),'surname2','name2') data = Data(str(2), 'surname2', 'name2')
the_txn = self.env.txn_begin() the_txn = self.env.txn_begin()
self.person_map.put(data.handle,data,txn=the_txn) self.person_map.put(data.handle, data, txn=the_txn)
the_txn.commit() the_txn.commit()
v = self.person_map.get(data.handle) v = self.person_map.get(data.handle)
assert v.handle == data.handle self.assertEqual(v.handle, data.handle)
@unittest.skip("Insert expected to fail with open cursor")
def test_insert_with_curor_open(self): def test_insert_with_curor_open(self):
"""test_insert_with_curor_open""" """test_insert_with_curor_open"""
@ -140,9 +142,9 @@ class CursorTest(unittest.TestCase):
cursor.first() cursor.first()
cursor.next() cursor.next()
data = Data(str(2),'surname2','name2') data = Data(str(2),'surname2', 'name2')
the_txn = self.env.txn_begin() the_txn = self.env.txn_begin()
self.person_map.put(data.handle,data,txn=the_txn) self.person_map.put(data.handle, data, txn=the_txn)
the_txn.commit() the_txn.commit()
cursor.close() cursor.close()
@ -150,9 +152,10 @@ class CursorTest(unittest.TestCase):
v = self.person_map.get(data.handle) v = self.person_map.get(data.handle)
assert v.handle == data.handle self.assertEqual(v.handle, data.handle)
def xtest_insert_with_curor_open_and_db_open(self): @unittest.skip("Insert expected to fail with open cursor")
def test_insert_with_curor_open_and_db_open(self):
"""test_insert_with_curor_open_and_db_open""" """test_insert_with_curor_open_and_db_open"""
(person2,surnames2) = self._open_tables() (person2,surnames2) = self._open_tables()
@ -162,9 +165,9 @@ class CursorTest(unittest.TestCase):
cursor.first() cursor.first()
cursor.next() cursor.next()
data = Data(str(2),'surname2','name2') data = Data(str(2),'surname2', 'name2')
the_txn = self.env.txn_begin() the_txn = self.env.txn_begin()
self.person_map.put(data.handle,data,txn=the_txn) self.person_map.put(data.handle, data, txn=the_txn)
the_txn.commit() the_txn.commit()
cursor.close() cursor.close()
@ -172,11 +175,11 @@ class CursorTest(unittest.TestCase):
v = self.person_map.get(data.handle) v = self.person_map.get(data.handle)
assert v.handle == data.handle self.assertEqual(v.handle, data.handle)
def testSuite(): def testSuite():
suite = unittest.makeSuite(CursorTest,'test') suite = unittest.makeSuite(CursorTest, 'test')
return suite return suite

View File

@ -18,31 +18,21 @@
# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA # Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
# #
# test/GrampsDb/GrampsDbTestBase.py
# $Id$ # $Id$
import unittest import unittest
import logging
import os
import tempfile import tempfile
import shutil import shutil
import time
import traceback
import sys
sys.path.append('../gramps')
try: try:
set() set()
except NameError: except NameError:
from sets import Set as set from sets import Set as set
from gramps.gen.db import DbBsddb
from gramps.cli.clidbman import CLIDbManager
import gramps.gen.const
import gramps.gen.lib
logger = logging.getLogger('Gramps.GrampsDbTestBase') from gramps.gen.db import DbBsddb, DbTxn
from gramps.cli.clidbman import CLIDbManager
from gramps.gen.lib import (Source, RepoRef, Citation, Repository, Person,
Family, Event, Place, MediaObject)
class GrampsDbBaseTest(unittest.TestCase): class GrampsDbBaseTest(unittest.TestCase):
"""Base class for unittest that need to be able to create """Base class for unittest that need to be able to create
@ -52,7 +42,6 @@ class GrampsDbBaseTest(unittest.TestCase):
def dummy_callback(dummy): def dummy_callback(dummy):
pass pass
self._tmpdir = tempfile.mkdtemp() self._tmpdir = tempfile.mkdtemp()
#self._filename = os.path.join(self._tmpdir,'test.grdb')
self._db = DbBsddb() self._db = DbBsddb()
dbman = CLIDbManager(None) dbman = CLIDbManager(None)
@ -107,79 +96,77 @@ class GrampsDbBaseTest(unittest.TestCase):
def _add_source(self,repos=None): def _add_source(self,repos=None):
# Add a Source # Add a Source
tran = self._db.transaction_begin()
source = gen.lib.Source()
if repos is not None:
repo_ref = gen.lib.RepoRef()
repo_ref.set_reference_handle(repos.get_handle())
source.add_repo_reference(repo_ref)
self._db.add_source(source,tran)
self._db.commit_source(source,tran)
self._db.transaction_commit(tran, "Add Source")
return source with DbTxn("Add Source and Citation", self._db) as tran:
source = Source()
if repos is not None:
repo_ref = RepoRef()
repo_ref.set_reference_handle(repos.get_handle())
source.add_repo_reference(repo_ref)
self._db.add_source(source, tran)
self._db.commit_source(source, tran)
citation = Citation()
citation.set_reference_handle(source.get_handle())
self._db.add_citation(citation, tran)
self._db.commit_citation(citation, tran)
return citation
def _add_repository(self): def _add_repository(self):
# Add a Repository # Add a Repository
tran = self._db.transaction_begin() with DbTxn("Add Repository", self._db) as tran:
repos = gen.lib.Repository() repos = Repository()
self._db.add_repository(repos,tran) self._db.add_repository(repos, tran)
self._db.commit_repository(repos,tran) self._db.commit_repository(repos, tran)
self._db.transaction_commit(tran, "Add Repository")
return repos return repos
def _add_object_with_source(self,sources, object_class,add_method,commit_method): def _add_object_with_source(self, citations, object_class, add_method,
commit_method):
object = object_class() object = object_class()
for source in sources: with DbTxn("Add Object", self._db) as tran:
src_ref = gen.lib.SourceRef() for citation in citations:
src_ref.set_reference_handle(source.get_handle()) object.add_citation(citation.get_handle())
object.add_source_reference(src_ref) add_method(object, tran)
commit_method(object, tran)
tran = self._db.transaction_begin()
add_method(object,tran)
commit_method(object,tran)
self._db.transaction_commit(tran, "Add Object")
return object return object
def _add_person_with_sources(self,sources): def _add_person_with_sources(self, citations):
return self._add_object_with_source(sources, return self._add_object_with_source(citations,
gen.lib.Person, Person,
self._db.add_person, self._db.add_person,
self._db.commit_person) self._db.commit_person)
def _add_family_with_sources(self,sources): def _add_family_with_sources(self, citations):
return self._add_object_with_source(sources, return self._add_object_with_source(citations,
gen.lib.Family, Family,
self._db.add_family, self._db.add_family,
self._db.commit_family) self._db.commit_family)
def _add_event_with_sources(self,sources): def _add_event_with_sources(self, citations):
return self._add_object_with_source(sources, return self._add_object_with_source(citations,
gen.lib.Event, Event,
self._db.add_event, self._db.add_event,
self._db.commit_event) self._db.commit_event)
def _add_place_with_sources(self,sources): def _add_place_with_sources(self, citations):
return self._add_object_with_source(sources, return self._add_object_with_source(citations,
gen.lib.Place, Place,
self._db.add_place, self._db.add_place,
self._db.commit_place) self._db.commit_place)
def _add_media_object_with_sources(self,sources): def _add_media_object_with_sources(self, citations):
return self._add_object_with_source(sources, return self._add_object_with_source(citations,
gen.lib.MediaObject, MediaObject,
self._db.add_object, self._db.add_object,
self._db.commit_media_object) self._db.commit_media_object)

View File

@ -18,32 +18,25 @@
# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA # Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
# #
# test/GrampsDb/GrampsDbBase_Test.py
# $Id$ # $Id$
import unittest import unittest
import logging import logging
import os
import tempfile
import shutil
import time import time
import traceback
import sys
sys.path.append(os.path.join(os.path.dirname(__file__), '../../gramps'))
try: try:
set() set()
except NameError: except NameError:
from sets import Set as set from sets import Set as set
import gramps.gen.lib from .. import DbTxn
from ...lib import Person, Event, Source, Citation
logger = logging.getLogger('Gramps.GrampsDbBase_Test') logger = logging.getLogger('Gramps.GrampsDbBase_Test')
from GrampsDbTestBase import GrampsDbBaseTest from grampsdbtestbase import GrampsDbBaseTest
class ReferenceMapTest (GrampsDbBaseTest): class ReferenceMapTest(GrampsDbBaseTest):
"""Test methods on the GrampsDbBase class that are related to the reference_map """Test methods on the GrampsDbBase class that are related to the reference_map
index implementation.""" index implementation."""
@ -52,74 +45,83 @@ class ReferenceMapTest (GrampsDbBaseTest):
a lookup for the reference returns the original a lookup for the reference returns the original
record.""" record."""
source = self._add_source() citation = self._add_source()
person = self._add_person_with_sources([source]) person = self._add_person_with_sources([citation])
references = list(self._db.find_backlink_handles(source.get_handle())) references = list(self._db.find_backlink_handles(citation.get_handle()))
assert len(references) == 1 self.assertEqual(len(references), 1)
assert references[0] == (gen.lib.Person.__name__,person.get_handle()) self.assertEqual(references[0], (Person.__name__, person.get_handle()))
def test_backlink_for_repository(self): def test_backlink_for_repository(self):
"""check that the source / repos backlink lookup works.""" """check that the citation /source / repos backlink lookup works."""
repos = self._add_repository() repos = self._add_repository()
source = self._add_source(repos=repos) citation = self._add_source(repos=repos)
references = list(self._db.find_backlink_handles(repos.get_handle())) references = list(self._db.find_backlink_handles(repos.get_handle()))
assert len(references) == 1 self.assertEqual(len(references), 1)
assert references[0] == (gen.lib.Source.__name__,source.get_handle()) self.assertEqual(references[0][0], Source.__name__)
references = list(self._db.find_backlink_handles(references[0][1]))
self.assertEqual(len(references), 1)
self.assertEqual(references[0],
(Citation.__name__, citation.get_handle()))
def test_class_limited_lookup(self): def test_class_limited_lookup(self):
"""check that class limited lookups work.""" """check that class limited lookups work."""
source = self._add_source() citation = self._add_source()
person = self._add_person_with_sources([source]) person = self._add_person_with_sources([citation])
self._add_family_with_sources([source]) self._add_family_with_sources([citation])
self._add_event_with_sources([source]) self._add_event_with_sources([citation])
self._add_place_with_sources([source]) self._add_place_with_sources([citation])
self._add_media_object_with_sources([source]) self._add_media_object_with_sources([citation])
# make sure that we have the correct number of references (one for each object) # make sure that we have the correct number of references (one for each object)
references = list(self._db.find_backlink_handles(source.get_handle())) references = list(self._db.find_backlink_handles(citation.get_handle()))
assert len(references) == 5, "len(references) == %s " % str(len(references)) self.assertEqual(len(references), 5,
"len(references) == %s " % str(len(references)))
# should just return the person reference # should just return the person reference
references = [ ref for ref in self._db.find_backlink_handles(source.get_handle(),(gen.lib.Person.__name__,)) ] references = [ref for ref in self._db.find_backlink_handles(citation.get_handle(), (Person.__name__,))]
assert len(references) == 1, "len(references) == %s " % str(len(references)) self.assertEqual(len(references), 1,
assert references[0][0] == gen.lib.Person.__name__, "references = %s" % repr(references) "len(references) == %s " % str(len(references)))
self.assertEqual(references[0][0], Person.__name__,
"references = %s" % repr(references))
# should just return the person and event reference # should just return the person and event reference
references = list(self._db.find_backlink_handles(source.get_handle(), references = list(self._db.find_backlink_handles(citation.get_handle(),
(gen.lib.Person.__name__, gen.lib.Event.__name__))) (Person.__name__, Event.__name__)))
assert len(references) == 2, "len(references) == %s " % str(len(references)) self.assertEqual(len(references), 2,
assert references[0][0] == gen.lib.Person.__name__, "references = %s" % repr(references) "len(references) == %s " % str(len(references)))
assert references[1][0] == gen.lib.Event.__name__, "references = %s" % repr(references) self.assertEqual(references[0][0], Person.__name__,
"references = %s" % repr(references))
self.assertEqual(references[1][0], Event.__name__,
"references = %s" % repr(references))
def test_delete_primary(self): def test_delete_primary(self):
"""check that deleting a primary will remove the backreferences """check that deleting a primary will remove the backreferences
from the reference_map""" from the reference_map"""
source = self._add_source() citation = self._add_source()
person = self._add_person_with_sources([source]) person = self._add_person_with_sources([citation])
assert self._db.get_person_from_handle(person.get_handle()) is not None self.assertIsNotNone(self._db.get_person_from_handle(person.get_handle()))
tran = self._db.transaction_begin() with DbTxn("Del Person", self._db) as tran:
self._db.remove_person(person.get_handle(),tran) self._db.remove_person(person.get_handle(),tran)
self._db.transaction_commit(tran, "Del Person")
assert self._db.get_person_from_handle(person.get_handle()) is None self.assertIsNone(self._db.get_person_from_handle(person.get_handle()))
references = list(self._db.find_backlink_handles(source.get_handle())) references = list(self._db.find_backlink_handles(citation.get_handle()))
assert len(references) == 0, "len(references) == %s " % str(len(references))
self.assertEqual(len(references), 0,
"len(references) == %s " % str(len(references)))
def test_reindex_reference_map(self): def test_reindex_reference_map(self):
"""Test that the reindex function works.""" """Test that the reindex function works."""
@ -130,28 +132,28 @@ class ReferenceMapTest (GrampsDbBaseTest):
# unhook the reference_map update function so that we # unhook the reference_map update function so that we
# can insert some records without the reference_map being updated. # can insert some records without the reference_map being updated.
update_method = self._db.update_reference_map update_method = self._db.update_reference_map
self._db._update_reference_map = lambda x,y: 1 self._db.update_reference_map = lambda x,y,z: 1
# Insert a person/source pair. # Insert a person/source pair.
source = self._add_source() citation = self._add_source()
person = self._add_person_with_sources([source]) person = self._add_person_with_sources([citation])
# Check that the reference map does not contain the reference. # Check that the reference map does not contain the reference.
references = list(self._db.find_backlink_handles(source.get_handle())) references = list(self._db.find_backlink_handles(citation.get_handle()))
assert len(references) == 0, "len(references) == %s " % str(len(references)) self.assertEqual(len(references), 0,
"len(references) == %s " % str(len(references)))
# Reinstate the reference_map method and reindex the database # Reinstate the reference_map method and reindex the database
self._db._update_reference_map = update_method self._db.update_reference_map = update_method
self._db.reindex_reference_map(cb) self._db.reindex_reference_map(cb)
# Check that the reference now appears in the reference_map # Check that the reference now appears in the reference_map
references = list(self._db.find_backlink_handles(source.get_handle())) references = list(self._db.find_backlink_handles(citation.get_handle()))
assert len(references) == 1, "len(references) == %s " % str(len(references)) self.assertEqual(len(references), 1,
"len(references) == %s " % str(len(references)))
def perf_simple_search_speed(self): def perf_simple_search_speed(self):
num_sources = 100 num_sources = 100
@ -211,8 +213,9 @@ class ReferenceMapTest (GrampsDbBaseTest):
logger.info("with refs %s\n", str(with_reference_map)) logger.info("with refs %s\n", str(with_reference_map))
logger.info("without refs %s\n", str(without_reference_map)) logger.info("without refs %s\n", str(without_reference_map))
assert with_reference_map < (without_reference_map / 10), "Reference_map should an order of magnitude faster." self.assertLess(with_reference_map, without_reference_map / 10,
"Reference_map should an order of magnitude faster.")
def testSuite(): def testSuite():
suite = unittest.makeSuite(ReferenceMapTest,'test') suite = unittest.makeSuite(ReferenceMapTest,'test')
return suite return suite