Fix and move db unit tests
svn: r22768
This commit is contained in:
parent
51cdc1f097
commit
4760c6bd21
@ -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|\
|
||||||
@ -110,7 +111,7 @@ 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 test_insert_with_curor_closed(self):
|
def test_insert_with_curor_closed(self):
|
||||||
"""test_insert_with_curor_closed"""
|
"""test_insert_with_curor_closed"""
|
||||||
@ -130,8 +131,9 @@ 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)
|
||||||
|
|
||||||
|
@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"""
|
||||||
|
|
||||||
@ -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()
|
||||||
@ -172,7 +175,7 @@ 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():
|
@ -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.gen.db import DbBsddb, DbTxn
|
||||||
from gramps.cli.clidbman import CLIDbManager
|
from gramps.cli.clidbman import CLIDbManager
|
||||||
import gramps.gen.const
|
from gramps.gen.lib import (Source, RepoRef, Citation, Repository, Person,
|
||||||
import gramps.gen.lib
|
Family, Event, Place, MediaObject)
|
||||||
|
|
||||||
logger = logging.getLogger('Gramps.GrampsDbTestBase')
|
|
||||||
|
|
||||||
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)
|
||||||
@ -108,78 +97,76 @@ 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()
|
with DbTxn("Add Source and Citation", self._db) as tran:
|
||||||
source = gen.lib.Source()
|
source = Source()
|
||||||
if repos is not None:
|
if repos is not None:
|
||||||
repo_ref = gen.lib.RepoRef()
|
repo_ref = RepoRef()
|
||||||
repo_ref.set_reference_handle(repos.get_handle())
|
repo_ref.set_reference_handle(repos.get_handle())
|
||||||
source.add_repo_reference(repo_ref)
|
source.add_repo_reference(repo_ref)
|
||||||
self._db.add_source(source, tran)
|
self._db.add_source(source, tran)
|
||||||
self._db.commit_source(source, tran)
|
self._db.commit_source(source, tran)
|
||||||
self._db.transaction_commit(tran, "Add Source")
|
citation = Citation()
|
||||||
|
citation.set_reference_handle(source.get_handle())
|
||||||
|
self._db.add_citation(citation, tran)
|
||||||
|
self._db.commit_citation(citation, tran)
|
||||||
|
|
||||||
return source
|
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)
|
|
||||||
|
|
||||||
|
|
||||||
tran = self._db.transaction_begin()
|
|
||||||
add_method(object, tran)
|
add_method(object, tran)
|
||||||
commit_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)
|
@ -18,30 +18,23 @@
|
|||||||
# 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
|
||||||
@ -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,27 +132,27 @@ 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):
|
||||||
|
|
||||||
@ -211,7 +213,8 @@ 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')
|
Loading…
Reference in New Issue
Block a user