Move date tests from TestcaseGenerator to seperate plugin
svn: r9352
This commit is contained in:
parent
df3c42318b
commit
68129b0525
@ -1,6 +1,9 @@
|
||||
2007-11-16 Martin Hawlisch <Martin.Hawlisch@gmx.de>
|
||||
* src/Config/_GrampsConfigKeys.py: Add keys for the PedigreeView
|
||||
* src/DataViews/_PedigreeView.py: Remember tree settings in config
|
||||
* src/plugins/TestcaseGenerator.py: Remove date tests
|
||||
* src/plugins/DateParserDisplayTest.py: New plugin split out from
|
||||
TestcaseGenerator
|
||||
|
||||
2007-11-13 Brian Matherly <brian@gramps-project.org>
|
||||
* src/plugins/NarrativeWeb.py: Fix 0001369: Cannot translate (LivingProxy)
|
||||
|
241
src/plugins/DateParserDisplayTest.py
Normal file
241
src/plugins/DateParserDisplayTest.py
Normal file
@ -0,0 +1,241 @@
|
||||
# -*- coding: utf-8 -*-
|
||||
#
|
||||
# Gramps - a GTK+/GNOME based genealogy program
|
||||
#
|
||||
# Copyright (C) 2000-2006 Martin Hawlisch, Donald N. Allingham
|
||||
#
|
||||
# This program is free software; you can redistribute it and/or modify
|
||||
# it under the terms of the GNU General Public License as published by
|
||||
# the Free Software Foundation; either version 2 of the License, or
|
||||
# (at your option) any later version.
|
||||
#
|
||||
# This program is distributed in the hope that it will be useful,
|
||||
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
# GNU General Public License for more details.
|
||||
#
|
||||
# You should have received a copy of the GNU General Public License
|
||||
# along with this program; if not, write to the Free Software
|
||||
# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
||||
#
|
||||
|
||||
# $Id: DateParserDisplayTest.py 9289 2007-11-01 21:41:18Z LosHawlos $
|
||||
|
||||
"Validate localized date parser and displayer"
|
||||
|
||||
#-------------------------------------------------------------------------
|
||||
#
|
||||
# standard python modules
|
||||
#
|
||||
#-------------------------------------------------------------------------
|
||||
import traceback
|
||||
import sys
|
||||
|
||||
#-------------------------------------------------------------------------
|
||||
#
|
||||
# GRAMPS modules
|
||||
#
|
||||
#-------------------------------------------------------------------------
|
||||
import Errors
|
||||
import gen.lib
|
||||
from PluginUtils import Tool, register_tool
|
||||
import Utils
|
||||
from QuestionDialog import QuestionDialog,ErrorDialog
|
||||
from DateHandler import parser as _dp
|
||||
from DateHandler import displayer as _dd
|
||||
|
||||
#-------------------------------------------------------------------------
|
||||
#
|
||||
#
|
||||
#
|
||||
#-------------------------------------------------------------------------
|
||||
class DateParserDisplayTest(Tool.Tool):
|
||||
|
||||
def __init__(self, dbstate, uistate, options_class, name, callback=None):
|
||||
|
||||
Tool.Tool.__init__(self, dbstate, options_class, name)
|
||||
if uistate:
|
||||
# Running with gui -> Show message
|
||||
QuestionDialog("Start date test?","This test will create many persons and events in the current database. Do you really want to run this test?","Run test",self.run_tool)
|
||||
else:
|
||||
self.run_tool()
|
||||
|
||||
|
||||
def run_tool(self):
|
||||
self.progress = Utils.ProgressMeter(_('Running date test'),'')
|
||||
self.progress.set_pass(_('Generating dates'),
|
||||
4)
|
||||
dates = []
|
||||
# first some valid dates
|
||||
calendar = gen.lib.Date.CAL_GREGORIAN
|
||||
for quality in (gen.lib.Date.QUAL_NONE, gen.lib.Date.QUAL_ESTIMATED,
|
||||
gen.lib.Date.QUAL_CALCULATED):
|
||||
for modifier in (gen.lib.Date.MOD_NONE, gen.lib.Date.MOD_BEFORE,
|
||||
gen.lib.Date.MOD_AFTER, gen.lib.Date.MOD_ABOUT):
|
||||
for slash1 in (False,True):
|
||||
for month in range(1,13):
|
||||
for day in (5,27):
|
||||
d = gen.lib.Date()
|
||||
d.set(quality,modifier,calendar,(day,month,1789,slash1),"Text comment")
|
||||
dates.append( d)
|
||||
for modifier in (gen.lib.Date.MOD_RANGE, gen.lib.Date.MOD_SPAN):
|
||||
for slash1 in (False,True):
|
||||
for slash2 in (False,True):
|
||||
for month in range(1,13):
|
||||
for day in (5,27):
|
||||
d = gen.lib.Date()
|
||||
d.set(quality,modifier,calendar,(day,month,1789,slash1,day,month,1876,slash2),"Text comment")
|
||||
dates.append( d)
|
||||
d = gen.lib.Date()
|
||||
d.set(quality,modifier,calendar,(day,month,1789,slash1,day,13-month,1876,slash2),"Text comment")
|
||||
dates.append( d)
|
||||
d = gen.lib.Date()
|
||||
d.set(quality,modifier,calendar,(day,month,1789,slash1,32-day,month,1876,slash2),"Text comment")
|
||||
dates.append( d)
|
||||
d = gen.lib.Date()
|
||||
d.set(quality,modifier,calendar,(day,month,1789,slash1,32-day,13-month,1876,slash2),"Text comment")
|
||||
dates.append( d)
|
||||
modifier = gen.lib.Date.MOD_TEXTONLY
|
||||
d = gen.lib.Date()
|
||||
d.set(quality,modifier,calendar,gen.lib.Date.EMPTY,
|
||||
"This is a textual date")
|
||||
dates.append( d)
|
||||
self.progress.step()
|
||||
|
||||
# test invalid dates
|
||||
#dateval = (4,7,1789,False,5,8,1876,False)
|
||||
#for l in range(1,len(dateval)):
|
||||
# d = gen.lib.Date()
|
||||
# try:
|
||||
# d.set(gen.lib.Date.QUAL_NONE,gen.lib.Date.MOD_NONE,
|
||||
# gen.lib.Date.CAL_GREGORIAN,dateval[:l],"Text comment")
|
||||
# dates.append( d)
|
||||
# except Errors.DateError, e:
|
||||
# d.set_as_text("Date identified value correctly as invalid.\n%s" % e)
|
||||
# dates.append( d)
|
||||
# except:
|
||||
# d = gen.lib.Date()
|
||||
# d.set_as_text("Date.set Exception %s" % ("".join(traceback.format_exception(*sys.exc_info())),))
|
||||
# dates.append( d)
|
||||
#for l in range(1,len(dateval)):
|
||||
# d = gen.lib.Date()
|
||||
# try:
|
||||
# d.set(gen.lib.Date.QUAL_NONE,gen.lib.Date.MOD_SPAN,gen.lib.Date.CAL_GREGORIAN,dateval[:l],"Text comment")
|
||||
# dates.append( d)
|
||||
# except Errors.DateError, e:
|
||||
# d.set_as_text("Date identified value correctly as invalid.\n%s" % e)
|
||||
# dates.append( d)
|
||||
# except:
|
||||
# d = gen.lib.Date()
|
||||
# d.set_as_text("Date.set Exception %s" % ("".join(traceback.format_exception(*sys.exc_info())),))
|
||||
# dates.append( d)
|
||||
#self.progress.step()
|
||||
#d = gen.lib.Date()
|
||||
#d.set(gen.lib.Date.QUAL_NONE,gen.lib.Date.MOD_NONE,
|
||||
# gen.lib.Date.CAL_GREGORIAN,(44,7,1789,False),"Text comment")
|
||||
#dates.append( d)
|
||||
#d = gen.lib.Date()
|
||||
#d.set(gen.lib.Date.QUAL_NONE,gen.lib.Date.MOD_NONE,
|
||||
# gen.lib.Date.CAL_GREGORIAN,(4,77,1789,False),"Text comment")
|
||||
#dates.append( d)
|
||||
#d = gen.lib.Date()
|
||||
#d.set(gen.lib.Date.QUAL_NONE,gen.lib.Date.MOD_SPAN,
|
||||
# gen.lib.Date.CAL_GREGORIAN,
|
||||
# (4,7,1789,False,55,8,1876,False),"Text comment")
|
||||
#dates.append( d)
|
||||
#d = gen.lib.Date()
|
||||
#d.set(gen.lib.Date.QUAL_NONE,gen.lib.Date.MOD_SPAN,
|
||||
# gen.lib.Date.CAL_GREGORIAN,
|
||||
# (4,7,1789,False,5,88,1876,False),"Text comment")
|
||||
#dates.append( d)
|
||||
|
||||
trans = self.db.transaction_begin("",batch=True)
|
||||
self.db.disable_signals()
|
||||
self.progress.set_pass(_('Generating dates'),
|
||||
len(dates))
|
||||
# now add them as birth to new persons
|
||||
i = 1
|
||||
for dateval in dates:
|
||||
person = gen.lib.Person()
|
||||
name = gen.lib.Name()
|
||||
name.set_surname("DateTest")
|
||||
name.set_first_name("Test %d" % i)
|
||||
person.set_primary_name( name)
|
||||
self.db.add_person(person,trans)
|
||||
bevent = gen.lib.Event()
|
||||
bevent.set_type(gen.lib.EventType.BIRTH)
|
||||
bevent.set_date_object(dateval)
|
||||
bevent.set_description("Date Test %d (source)" % i)
|
||||
bevent_h = self.db.add_event(bevent,trans)
|
||||
bevent_ref = gen.lib.EventRef()
|
||||
bevent_ref.set_reference_handle(bevent_h)
|
||||
# for the death event display the date as text and parse it back to a new date
|
||||
ndate = None
|
||||
try:
|
||||
datestr = _dd.display( dateval)
|
||||
try:
|
||||
ndate = _dp.parse( datestr)
|
||||
if not ndate:
|
||||
ndate = gen.lib.Date()
|
||||
ndate.set_as_text("DateParser None")
|
||||
person.set_marker(gen.lib.MarkerType.TODO_TYPE)
|
||||
else:
|
||||
person.set_marker(gen.lib.MarkerType.COMPLETE)
|
||||
except:
|
||||
ndate = gen.lib.Date()
|
||||
ndate.set_as_text("DateParser Exception %s" % ("".join(traceback.format_exception(*sys.exc_info())),))
|
||||
person.set_marker(gen.lib.MarkerType.TODO_TYPE)
|
||||
except:
|
||||
ndate = gen.lib.Date()
|
||||
ndate.set_as_text("DateDisplay Exception: %s" % ("".join(traceback.format_exception(*sys.exc_info())),))
|
||||
person.set_marker(gen.lib.MarkerType.TODO_TYPE)
|
||||
|
||||
if dateval.get_modifier() != gen.lib.Date.MOD_TEXTONLY \
|
||||
and ndate.get_modifier() == gen.lib.Date.MOD_TEXTONLY:
|
||||
# parser was unable to correctly parse the string
|
||||
ndate.set_as_text( "TEXTONLY: "+ndate.get_text())
|
||||
person.set_marker(gen.lib.MarkerType.TODO_TYPE)
|
||||
if dateval.get_modifier() == gen.lib.Date.MOD_TEXTONLY \
|
||||
and dateval.get_text().count("Traceback") \
|
||||
and person.get_marker() == gen.lib.MarkerType.COMPLETE:
|
||||
person.set_marker(gen.lib.MarkerType.TODO_TYPE)
|
||||
|
||||
devent = gen.lib.Event()
|
||||
devent.set_type(gen.lib.EventType.DEATH)
|
||||
devent.set_date_object(ndate)
|
||||
devent.set_description("Date Test %d (result)" % i)
|
||||
devent_h = self.db.add_event(devent,trans)
|
||||
devent_ref = gen.lib.EventRef()
|
||||
devent_ref.set_reference_handle(devent_h)
|
||||
person.set_birth_ref(bevent_ref)
|
||||
person.set_death_ref(devent_ref)
|
||||
self.db.commit_person(person,trans)
|
||||
i = i + 1
|
||||
self.progress.step()
|
||||
self.db.transaction_commit(trans, _("Date Test Plugin"))
|
||||
self.db.enable_signals()
|
||||
self.db.request_rebuild()
|
||||
self.progress.close()
|
||||
|
||||
#-------------------------------------------------------------------------
|
||||
#
|
||||
#
|
||||
#
|
||||
#-------------------------------------------------------------------------
|
||||
|
||||
register_tool(
|
||||
name = 'test_for_date_parser_and_displayer',
|
||||
category = Tool.TOOL_DEBUG,
|
||||
tool_class = DateParserDisplayTest,
|
||||
options_class = None,
|
||||
modes = Tool.MODE_GUI | Tool.MODE_CLI,
|
||||
translated_name = _("Check localized date displayer and parser"),
|
||||
status = _("Beta"),
|
||||
author_name = "Martin Hawlisch",
|
||||
author_email = "martin@hawlisch.de",
|
||||
description = _("This test tool will create many people showing all different"
|
||||
" date variants as birth. The death date is created by"
|
||||
" parsing the result of the date displayer for the birth"
|
||||
" date. This way you can ensure that dates printed can"
|
||||
" be parsed back in correctly.")
|
||||
)
|
@ -53,8 +53,6 @@ import const
|
||||
import Utils
|
||||
import LdsUtils
|
||||
from QuestionDialog import ErrorDialog
|
||||
from DateHandler import parser as _dp
|
||||
from DateHandler import displayer as _dd
|
||||
|
||||
#-------------------------------------------------------------------------
|
||||
#
|
||||
@ -137,10 +135,6 @@ class TestcaseGenerator(Tool.Tool):
|
||||
self.check_bugs.set_active( self.options.handler.options_dict['bugs'])
|
||||
self.top.vbox.pack_start(self.check_bugs,0,0,5)
|
||||
|
||||
self.check_dates = gtk.CheckButton( _("Generate date tests"))
|
||||
self.check_dates.set_active( self.options.handler.options_dict['dates'])
|
||||
self.top.vbox.pack_start(self.check_dates,0,0,5)
|
||||
|
||||
self.check_persons = gtk.CheckButton( _("Generate dummy families"))
|
||||
self.check_persons.set_active( self.options.handler.options_dict['persons'])
|
||||
self.top.vbox.pack_start(self.check_persons,0,0,5)
|
||||
@ -177,8 +171,6 @@ class TestcaseGenerator(Tool.Tool):
|
||||
response = self.top.run()
|
||||
self.options.handler.options_dict['bugs'] = int(
|
||||
self.check_bugs.get_active())
|
||||
self.options.handler.options_dict['dates'] = int(
|
||||
self.check_dates.get_active())
|
||||
self.options.handler.options_dict['persons'] = int(
|
||||
self.check_persons.get_active())
|
||||
self.options.handler.options_dict['no_trans'] = int(
|
||||
@ -342,9 +334,6 @@ class TestcaseGenerator(Tool.Tool):
|
||||
if self.options.handler.options_dict['bugs']:
|
||||
self.generate_broken_relations()
|
||||
|
||||
if self.options.handler.options_dict['dates']:
|
||||
self.generate_date_tests()
|
||||
|
||||
if self.options.handler.options_dict['persons']:
|
||||
while True:
|
||||
if not self.persons_todo:
|
||||
@ -628,136 +617,6 @@ class TestcaseGenerator(Tool.Tool):
|
||||
self.commit_transaction() # COMMIT TRANSACTION STEP
|
||||
|
||||
|
||||
def generate_date_tests(self):
|
||||
dates = []
|
||||
# first some valid dates
|
||||
calendar = gen.lib.Date.CAL_GREGORIAN
|
||||
for quality in (gen.lib.Date.QUAL_NONE, gen.lib.Date.QUAL_ESTIMATED,
|
||||
gen.lib.Date.QUAL_CALCULATED):
|
||||
for modifier in (gen.lib.Date.MOD_NONE, gen.lib.Date.MOD_BEFORE,
|
||||
gen.lib.Date.MOD_AFTER, gen.lib.Date.MOD_ABOUT):
|
||||
for slash1 in (False,True):
|
||||
d = gen.lib.Date()
|
||||
d.set(quality,modifier,calendar,(4,7,1789,slash1),"Text comment")
|
||||
dates.append( d)
|
||||
for modifier in (gen.lib.Date.MOD_RANGE, gen.lib.Date.MOD_SPAN):
|
||||
for slash1 in (False,True):
|
||||
for slash2 in (False,True):
|
||||
d = gen.lib.Date()
|
||||
d.set(quality,modifier,calendar,(4,7,1789,slash1,5,8,1876,slash2),"Text comment")
|
||||
dates.append( d)
|
||||
modifier = gen.lib.Date.MOD_TEXTONLY
|
||||
d = gen.lib.Date()
|
||||
d.set(quality,modifier,calendar,gen.lib.Date.EMPTY,
|
||||
"This is a textual date")
|
||||
dates.append( d)
|
||||
|
||||
# test invalid dates
|
||||
dateval = (4,7,1789,False,5,8,1876,False)
|
||||
for l in range(1,len(dateval)):
|
||||
d = gen.lib.Date()
|
||||
try:
|
||||
d.set(gen.lib.Date.QUAL_NONE,gen.lib.Date.MOD_NONE,
|
||||
gen.lib.Date.CAL_GREGORIAN,dateval[:l],"Text comment")
|
||||
dates.append( d)
|
||||
except Errors.DateError, e:
|
||||
d.set_as_text("Date identified value correctly as invalid.\n%s" % e)
|
||||
dates.append( d)
|
||||
except:
|
||||
d = gen.lib.Date()
|
||||
d.set_as_text("Date.set Exception %s" % ("".join(traceback.format_exception(*sys.exc_info())),))
|
||||
dates.append( d)
|
||||
for l in range(1,len(dateval)):
|
||||
d = gen.lib.Date()
|
||||
try:
|
||||
d.set(gen.lib.Date.QUAL_NONE,gen.lib.Date.MOD_SPAN,gen.lib.Date.CAL_GREGORIAN,dateval[:l],"Text comment")
|
||||
dates.append( d)
|
||||
except Errors.DateError, e:
|
||||
d.set_as_text("Date identified value correctly as invalid.\n%s" % e)
|
||||
dates.append( d)
|
||||
except:
|
||||
d = gen.lib.Date()
|
||||
d.set_as_text("Date.set Exception %s" % ("".join(traceback.format_exception(*sys.exc_info())),))
|
||||
dates.append( d)
|
||||
d = gen.lib.Date()
|
||||
d.set(gen.lib.Date.QUAL_NONE,gen.lib.Date.MOD_NONE,
|
||||
gen.lib.Date.CAL_GREGORIAN,(44,7,1789,False),"Text comment")
|
||||
dates.append( d)
|
||||
d = gen.lib.Date()
|
||||
d.set(gen.lib.Date.QUAL_NONE,gen.lib.Date.MOD_NONE,
|
||||
gen.lib.Date.CAL_GREGORIAN,(4,77,1789,False),"Text comment")
|
||||
dates.append( d)
|
||||
d = gen.lib.Date()
|
||||
d.set(gen.lib.Date.QUAL_NONE,gen.lib.Date.MOD_SPAN,
|
||||
gen.lib.Date.CAL_GREGORIAN,
|
||||
(4,7,1789,False,55,8,1876,False),"Text comment")
|
||||
dates.append( d)
|
||||
d = gen.lib.Date()
|
||||
d.set(gen.lib.Date.QUAL_NONE,gen.lib.Date.MOD_SPAN,
|
||||
gen.lib.Date.CAL_GREGORIAN,
|
||||
(4,7,1789,False,5,88,1876,False),"Text comment")
|
||||
dates.append( d)
|
||||
|
||||
# now add them as birth to new persons
|
||||
i = 1
|
||||
for dateval in dates:
|
||||
person = gen.lib.Person()
|
||||
name = gen.lib.Name()
|
||||
name.set_surname("DateTest")
|
||||
name.set_first_name("Test %d" % i)
|
||||
person.set_primary_name( name)
|
||||
self.db.add_person(person,self.trans)
|
||||
bevent = gen.lib.Event()
|
||||
bevent.set_type(gen.lib.EventType.BIRTH)
|
||||
bevent.set_date_object(dateval)
|
||||
bevent_h = self.db.add_event(bevent,self.trans)
|
||||
self.generated_events.append(bevent_h)
|
||||
bevent_ref = gen.lib.EventRef()
|
||||
bevent_ref.set_reference_handle(bevent_h)
|
||||
# for the death event display the date as text and parse it back to a new date
|
||||
ndate = None
|
||||
try:
|
||||
datestr = _dd.display( dateval)
|
||||
try:
|
||||
ndate = _dp.parse( datestr)
|
||||
if not ndate:
|
||||
ndate = gen.lib.Date()
|
||||
ndate.set_as_text("DateParser None")
|
||||
person.set_marker(gen.lib.MarkerType.TODO_TYPE)
|
||||
else:
|
||||
person.set_marker(gen.lib.MarkerType.COMPLETE)
|
||||
except:
|
||||
ndate = gen.lib.Date()
|
||||
ndate.set_as_text("DateParser Exception %s" % ("".join(traceback.format_exception(*sys.exc_info())),))
|
||||
person.set_marker(gen.lib.MarkerType.TODO_TYPE)
|
||||
except:
|
||||
ndate = gen.lib.Date()
|
||||
ndate.set_as_text("DateDisplay Exception: %s" % ("".join(traceback.format_exception(*sys.exc_info())),))
|
||||
person.set_marker(gen.lib.MarkerType.TODO_TYPE)
|
||||
|
||||
if dateval.get_modifier() != gen.lib.Date.MOD_TEXTONLY \
|
||||
and ndate.get_modifier() == gen.lib.Date.MOD_TEXTONLY:
|
||||
# parser was unable to correctly parse the string
|
||||
ndate.set_as_text( "TEXTONLY: "+ndate.get_text())
|
||||
person.set_marker(gen.lib.MarkerType.TODO_TYPE)
|
||||
if dateval.get_modifier() == gen.lib.Date.MOD_TEXTONLY \
|
||||
and dateval.get_text().count("Traceback") \
|
||||
and person.get_marker() == gen.lib.MarkerType.COMPLETE:
|
||||
person.set_marker(gen.lib.MarkerType.TODO_TYPE)
|
||||
|
||||
devent = gen.lib.Event()
|
||||
devent.set_type(gen.lib.EventType.DEATH)
|
||||
devent.set_date_object(ndate)
|
||||
devent_h = self.db.add_event(devent,self.trans)
|
||||
self.generated_events.append(devent_h)
|
||||
devent_ref = gen.lib.EventRef()
|
||||
devent_ref.set_reference_handle(devent_h)
|
||||
person.set_birth_ref(bevent_ref)
|
||||
person.set_death_ref(devent_ref)
|
||||
self.db.commit_person(person,self.trans)
|
||||
i = i + 1
|
||||
self.commit_transaction() # COMMIT TRANSACTION STEP
|
||||
|
||||
def generate_person(self,gender=None,lastname=None,note=None, alive_in_year=None):
|
||||
if not self.cli:
|
||||
self.progress.set_fraction(min(1.0,max(0.0, 1.0*self.person_count/self.options.handler.options_dict['person_count'])))
|
||||
@ -1488,7 +1347,6 @@ class TestcaseGeneratorOptions(Tool.ToolOptions):
|
||||
# Options specific for this report
|
||||
self.options_dict = {
|
||||
'bugs' : 0,
|
||||
'dates' : 1,
|
||||
'persons' : 1,
|
||||
'person_count' : 2000,
|
||||
'no_trans' : 0,
|
||||
@ -1502,10 +1360,6 @@ class TestcaseGeneratorOptions(Tool.ToolOptions):
|
||||
"Whether to create invalid database references.",
|
||||
["Skip test","Create invalid Database references"],
|
||||
True),
|
||||
'dates' : ("=0/1",
|
||||
"Whether to create test for date handling.",
|
||||
["Skip test","Create date tests"],
|
||||
True),
|
||||
'persons' : ("=0/1",
|
||||
"Whether to create a bunch of dummy persons",
|
||||
["Dont create persons","Create dummy persons"],
|
||||
|
Loading…
x
Reference in New Issue
Block a user