2005-12-19 13:45:05 +00:00
|
|
|
import unittest
|
|
|
|
import logging
|
|
|
|
import os
|
|
|
|
import tempfile
|
|
|
|
import shutil
|
|
|
|
import time
|
|
|
|
import traceback
|
|
|
|
import sys
|
|
|
|
|
|
|
|
sys.path.append('../src')
|
|
|
|
|
|
|
|
try:
|
|
|
|
set()
|
|
|
|
except NameError:
|
|
|
|
from sets import Set as set
|
|
|
|
|
2005-12-21 11:27:05 +00:00
|
|
|
import GrampsDb
|
|
|
|
import const
|
2005-12-19 13:45:05 +00:00
|
|
|
import RelLib
|
|
|
|
|
|
|
|
logger = logging.getLogger('Gramps.GrampsDbTestBase')
|
|
|
|
|
|
|
|
class GrampsDbBaseTest(unittest.TestCase):
|
|
|
|
"""Base class for unittest that need to be able to create
|
|
|
|
test databases."""
|
|
|
|
|
|
|
|
def setUp(self):
|
2006-11-11 21:46:22 +00:00
|
|
|
def dummy_callback(dummy):
|
|
|
|
pass
|
2005-12-19 13:45:05 +00:00
|
|
|
self._tmpdir = tempfile.mkdtemp()
|
|
|
|
self._filename = os.path.join(self._tmpdir,'test.grdb')
|
|
|
|
|
2005-12-21 11:27:05 +00:00
|
|
|
self._db = GrampsDb.gramps_db_factory(const.app_gramps)()
|
2006-11-11 21:46:22 +00:00
|
|
|
self._db.load(self._filename, dummy_callback, "w")
|
2005-12-19 13:45:05 +00:00
|
|
|
|
|
|
|
|
|
|
|
def tearDown(self):
|
2006-11-24 05:21:57 +00:00
|
|
|
self._db.close()
|
2005-12-19 13:45:05 +00:00
|
|
|
shutil.rmtree(self._tmpdir)
|
|
|
|
|
|
|
|
def _populate_database(self,
|
|
|
|
num_sources = 1,
|
|
|
|
num_persons = 0,
|
|
|
|
num_families = 0,
|
|
|
|
num_events = 0,
|
|
|
|
num_places = 0,
|
|
|
|
num_media_objects = 0,
|
|
|
|
num_links = 1):
|
|
|
|
|
|
|
|
# start with sources
|
|
|
|
sources = []
|
2008-02-24 13:55:55 +00:00
|
|
|
for i in xrange(0, num_sources):
|
2005-12-19 13:45:05 +00:00
|
|
|
sources.append(self._add_source())
|
|
|
|
|
|
|
|
# now for each of the other tables. Give each entry a link
|
|
|
|
# to num_link sources, sources are chosen on a round robin
|
|
|
|
# basis
|
|
|
|
|
|
|
|
for num, add_func in ((num_persons, self._add_person_with_sources),
|
|
|
|
(num_families, self._add_family_with_sources),
|
|
|
|
(num_events, self._add_event_with_sources),
|
|
|
|
(num_places, self._add_place_with_sources),
|
|
|
|
(num_media_objects, self._add_media_object_with_sources)):
|
|
|
|
|
|
|
|
source_idx = 1
|
2008-02-24 13:55:55 +00:00
|
|
|
for person_idx in xrange(0, num):
|
2005-12-19 13:45:05 +00:00
|
|
|
|
|
|
|
# Get the list of sources to link
|
|
|
|
lnk_sources = set()
|
2008-02-24 13:55:55 +00:00
|
|
|
for i in xrange(0, num_links):
|
2005-12-19 13:45:05 +00:00
|
|
|
lnk_sources.add(sources[source_idx-1])
|
|
|
|
source_idx = (source_idx+1) % len(sources)
|
|
|
|
|
|
|
|
try:
|
|
|
|
add_func(lnk_sources)
|
|
|
|
except:
|
|
|
|
print "person_idx = ", person_idx
|
|
|
|
print "lnk_sources = ", repr(lnk_sources)
|
|
|
|
raise
|
|
|
|
|
|
|
|
return
|
|
|
|
|
2005-12-22 12:02:06 +00:00
|
|
|
def _add_source(self,repos=None):
|
2005-12-19 13:45:05 +00:00
|
|
|
# Add a Source
|
|
|
|
|
|
|
|
tran = self._db.transaction_begin()
|
|
|
|
source = RelLib.Source()
|
2009-02-23 19:11:46 +00:00
|
|
|
if repos is not None:
|
2005-12-22 12:02:06 +00:00
|
|
|
repo_ref = RelLib.RepoRef()
|
|
|
|
repo_ref.set_reference_handle(repos.get_handle())
|
|
|
|
source.add_repo_reference(repo_ref)
|
2005-12-19 13:45:05 +00:00
|
|
|
self._db.add_source(source,tran)
|
|
|
|
self._db.commit_source(source,tran)
|
|
|
|
self._db.transaction_commit(tran, "Add Source")
|
|
|
|
|
|
|
|
return source
|
|
|
|
|
2005-12-22 12:02:06 +00:00
|
|
|
def _add_repository(self):
|
|
|
|
# Add a Repository
|
|
|
|
|
|
|
|
tran = self._db.transaction_begin()
|
|
|
|
repos = RelLib.Repository()
|
|
|
|
self._db.add_repository(repos,tran)
|
|
|
|
self._db.commit_repository(repos,tran)
|
|
|
|
self._db.transaction_commit(tran, "Add Repository")
|
|
|
|
|
|
|
|
return repos
|
|
|
|
|
2005-12-19 13:45:05 +00:00
|
|
|
|
2008-02-24 13:55:55 +00:00
|
|
|
def _add_object_with_source(self,sources, object_class,add_method,commit_method):
|
2005-12-19 13:45:05 +00:00
|
|
|
|
|
|
|
object = object_class()
|
|
|
|
|
|
|
|
for source in sources:
|
|
|
|
src_ref = RelLib.SourceRef()
|
2006-11-16 04:02:28 +00:00
|
|
|
src_ref.set_reference_handle(source.get_handle())
|
2005-12-19 13:45:05 +00:00
|
|
|
object.add_source_reference(src_ref)
|
|
|
|
|
|
|
|
|
|
|
|
tran = self._db.transaction_begin()
|
|
|
|
add_method(object,tran)
|
|
|
|
commit_method(object,tran)
|
|
|
|
self._db.transaction_commit(tran, "Add Object")
|
|
|
|
|
|
|
|
return object
|
|
|
|
|
|
|
|
def _add_person_with_sources(self,sources):
|
|
|
|
|
|
|
|
return self._add_object_with_source(sources,
|
|
|
|
RelLib.Person,
|
|
|
|
self._db.add_person,
|
|
|
|
self._db.commit_person)
|
|
|
|
|
|
|
|
def _add_family_with_sources(self,sources):
|
|
|
|
|
|
|
|
return self._add_object_with_source(sources,
|
|
|
|
RelLib.Family,
|
|
|
|
self._db.add_family,
|
|
|
|
self._db.commit_family)
|
|
|
|
|
|
|
|
def _add_event_with_sources(self,sources):
|
|
|
|
|
|
|
|
return self._add_object_with_source(sources,
|
|
|
|
RelLib.Event,
|
|
|
|
self._db.add_event,
|
|
|
|
self._db.commit_event)
|
|
|
|
|
|
|
|
def _add_place_with_sources(self,sources):
|
|
|
|
|
|
|
|
return self._add_object_with_source(sources,
|
|
|
|
RelLib.Place,
|
|
|
|
self._db.add_place,
|
|
|
|
self._db.commit_place)
|
|
|
|
|
|
|
|
def _add_media_object_with_sources(self,sources):
|
|
|
|
|
|
|
|
return self._add_object_with_source(sources,
|
|
|
|
RelLib.MediaObject,
|
|
|
|
self._db.add_object,
|
|
|
|
self._db.commit_media_object)
|