* src/GrampsDbBase.py: fixed UNDO buffer issue

* test/GrampsDbBase_Test.py: improved performance test
	* test/RunAllTests.py: added -p cmdline flag


svn: r5571
This commit is contained in:
Richard Taylor 2005-12-17 21:13:45 +00:00
parent 9385212033
commit a2a230411a
4 changed files with 74 additions and 18 deletions

View File

@ -1,3 +1,8 @@
2005-12-17 Richard Taylor <rjt-gramps@thegrindstone.me.uk>
* src/GrampsDbBase.py: fixed UNDO buffer issue
* test/GrampsDbBase_Test.py: improved performance test
* test/RunAllTests.py: added -p cmdline flag
2005-12-17 Richard Taylor <rjt-gramps@thegrindstone.me.uk> 2005-12-17 Richard Taylor <rjt-gramps@thegrindstone.me.uk>
* src/GrampsBSDDB.py: added work around for cursor set not * src/GrampsBSDDB.py: added work around for cursor set not
returing None. returing None.

View File

@ -1026,9 +1026,9 @@ class GrampsDbBase(GrampsDBCallback.GrampsDBCallback):
if not len(transaction) or self.readonly: if not len(transaction) or self.readonly:
return return
transaction.set_description(msg) transaction.set_description(msg)
self.undoindex += 1 self.undoindex += 1
if self.undoindex == _UNDO_SIZE: if self.undoindex >= _UNDO_SIZE:
self.translist = transaction[0:-1] + [ transaction ] self.translist = self.translist[0:-1] + [ transaction ]
else: else:
self.translist[self.undoindex] = transaction self.translist[self.undoindex] = transaction

View File

@ -4,10 +4,16 @@ import os
import tempfile import tempfile
import shutil import shutil
import time import time
import traceback
import sys import sys
sys.path.append('../src') sys.path.append('../src')
try:
set()
except NameError:
from set import Set as set
import GrampsBSDDB import GrampsBSDDB
import RelLib import RelLib
@ -24,6 +30,7 @@ class ReferenceMapTest (unittest.TestCase):
None, # callback None, # callback
"w") "w")
def tearDown(self): def tearDown(self):
shutil.rmtree(self._tmpdir) shutil.rmtree(self._tmpdir)
@ -60,7 +67,12 @@ class ReferenceMapTest (unittest.TestCase):
lnk_sources.add(sources[source_idx-1]) lnk_sources.add(sources[source_idx-1])
source_idx = (source_idx+1) % len(sources) source_idx = (source_idx+1) % len(sources)
add_func(lnk_sources) try:
add_func(lnk_sources)
except:
print "person_idx = ", person_idx
print "lnk_sources = ", repr(lnk_sources)
raise
return return
@ -199,15 +211,23 @@ class ReferenceMapTest (unittest.TestCase):
return end - start return end - start
def test_performance(self): def perf_simple_search_speed(self):
num_sources = 100
num_persons = 1000
num_families = 10
num_events = 10
num_places = 10
num_media_objects = 10
num_links = 10
self._populate_database(num_sources = 100, self._populate_database(num_sources,
num_persons = 80, num_persons,
num_families = 10, num_families,
num_events = 10, num_events,
num_places = 10, num_places,
num_media_objects = 10, num_media_objects,
num_links = 10) num_links)
# time searching for source backrefs with and without reference_map # time searching for source backrefs with and without reference_map
@ -232,7 +252,21 @@ class ReferenceMapTest (unittest.TestCase):
without_reference_map = end - start without_reference_map = end - start
self._db.__class__.find_backlink_handles = remember self._db.__class__.find_backlink_handles = remember
logger.info("search test with following data: \n"
"num_sources = %d \n"
"num_persons = %d \n"
"num_families = %d \n"
"num_events = %d \n"
"num_places = %d \n"
"num_media_objects = %d \n"
"num_links = %d" % (num_sources,
num_persons,
num_families,
num_events,
num_places,
num_media_objects,
num_links))
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))
@ -241,5 +275,8 @@ class ReferenceMapTest (unittest.TestCase):
def testSuite(): def testSuite():
return unittest.makeSuite(ReferenceMapTest,'test') return unittest.makeSuite(ReferenceMapTest,'test')
def perfSuite():
return unittest.makeSuite(ReferenceMapTest,'perf')
if __name__ == '__main__': if __name__ == '__main__':
unittest.TextTestRunner().run(testSuite()) unittest.TextTestRunner().run(testSuite())

View File

@ -13,6 +13,8 @@ def make_parser():
parser = OptionParser(usage) parser = OptionParser(usage)
parser.add_option("-v", "--verbosity", type="int", dest="verbose_level", default=0, parser.add_option("-v", "--verbosity", type="int", dest="verbose_level", default=0,
help="Level of verboseness") help="Level of verboseness")
parser.add_option("-p", "--performance", action="store_true", dest="performance", default=False,
help="Run the performance tests.")
return parser return parser
@ -21,15 +23,23 @@ def getTestSuites():
test_modules = [ i for i in os.listdir('.') if i[-8:] == "_Test.py" ] test_modules = [ i for i in os.listdir('.') if i[-8:] == "_Test.py" ]
test_suites = [] test_suites = []
perf_suites = []
for module in test_modules: for module in test_modules:
mod = __import__(module[:-3]) mod = __import__(module[:-3])
test_suites.append(mod.testSuite()) test_suites.append(mod.testSuite())
try:
perf_suites.append(mod.perfSuite())
except:
pass
return test_suites return (test_suites,perf_suites)
def allTheTests(): def allTheTests():
return unittest.TestSuite(getTestSuites()) return unittest.TestSuite(getTestSuites()[0])
def perfTests():
return unittest.TestSuite(getTestSuites()[1])
if __name__ == '__main__': if __name__ == '__main__':
console = logging.StreamHandler() console = logging.StreamHandler()
@ -57,5 +67,9 @@ if __name__ == '__main__':
else: else:
logger.setLevel(logging.ERROR) logger.setLevel(logging.ERROR)
console.setLevel(logging.ERROR) console.setLevel(logging.ERROR)
unittest.TextTestRunner(verbosity=options.verbose_level).run(allTheTests())
if options.performance:
unittest.TextTestRunner(verbosity=options.verbose_level).run(perfTests())
else:
unittest.TextTestRunner(verbosity=options.verbose_level).run(allTheTests())