Individual test can be selected by sequence number

polishing, slightly more elaborate debugging
This commit is contained in:
Philip Eisenlohr 2016-11-30 18:18:03 -05:00
parent cb95f3b244
commit e42db0ea25
1 changed files with 25 additions and 14 deletions

View File

@ -58,11 +58,11 @@ class Test():
self.parser.add_option("--ok", "--accept", self.parser.add_option("--ok", "--accept",
action = "store_true", action = "store_true",
dest = "accept", dest = "accept",
help = "calculate results but always consider test as successfull") help = "calculate results but always consider test as successful")
self.parser.add_option("-l", "--list", self.parser.add_option("-l", "--list",
action = "store_true", action = "store_true",
dest = "show", dest = "show",
help = "show all test variants and do no calculation") help = "show all test variants without actual calculation")
self.parser.add_option("-s", "--select", self.parser.add_option("-s", "--select",
dest = "select", dest = "select",
help = "run test of given name only") help = "run test of given name only")
@ -83,8 +83,9 @@ class Test():
for variant,name in enumerate(self.variants): for variant,name in enumerate(self.variants):
if self.options.show: if self.options.show:
logging.critical('{}: {}'.format(variant,name)) logging.critical('{}: {}'.format(variant+1,name))
elif self.options.select is not None and name != self.options.select: elif self.options.select is not None \
and not (name == self.options.select or str(variant+1) == self.options.select):
pass pass
else: else:
try: try:
@ -93,14 +94,15 @@ class Test():
self.run(variant) self.run(variant)
self.postprocess(variant) self.postprocess(variant)
self.compare(variant)
if self.options.update: if self.options.update:
if self.update(variant) != 0: logging.critical('update for "{}" failed.'.format(name)) if self.update(variant) != 0: logging.critical('update for "{}" failed.'.format(name))
elif not (self.options.accept or self.compare(variant)): # no update, do comparison elif not (self.options.accept or self.compare(variant)): # no update, do comparison
return variant+1 # return culprit return variant+1 # return culprit
except Exception as e : except Exception as e:
logging.critical('exception during variant execution: {}'.format(e)) logging.critical('exception during variant execution: "{}"'.format(e.message))
return variant+1 # return culprit return variant+1 # return culprit
return 0 return 0
@ -465,7 +467,7 @@ class Test():
mean = np.amax(np.abs(np.mean(normedDelta,0))) mean = np.amax(np.abs(np.mean(normedDelta,0)))
std = np.amax(np.std(normedDelta,0)) std = np.amax(np.std(normedDelta,0))
logging.info('mean: {:f}'.format(mean)) logging.info('mean: {:f}'.format(mean))
logging.info('std: {:f}'.format(std)) logging.info('std: {:f}'.format(std))
return (mean<meanTol) & (std < stdTol) return (mean<meanTol) & (std < stdTol)
@ -514,7 +516,7 @@ class Test():
table.close() # ... close table.close() # ... close
for j,label in enumerate(labels): # iterate over object labels for j,label in enumerate(labels): # iterate over object labels
maximum[j] = np.maximum(\ maximum[j] = np.maximum(
maximum[j], maximum[j],
np.amax(np.linalg.norm(table.data[:,table.label_indexrange(label)], np.amax(np.linalg.norm(table.data[:,table.label_indexrange(label)],
axis=1)) axis=1))
@ -525,12 +527,21 @@ class Test():
for i in range(len(data)): for i in range(len(data)):
data[i] /= maximum # normalize each table data[i] /= maximum # normalize each table
logging.info('shape of data {}: {}'.format(i,data[i].shape))
if debug: if debug:
logging.debug(str(maximum)) violators = np.absolute(data[0]-data[1]) > atol + rtol*np.absolute(data[1])
allclose = np.absolute(data[0]-data[1]) <= (atol + rtol*np.absolute(data[1])) logging.info('shape of violators: {}'.format(violators.shape))
for ok,valA,valB in zip(allclose,data[0],data[1]): for j,culprits in enumerate(violators):
logging.debug('{}:\n{}\n{}'.format(ok,valA,valB)) goodguys = np.logical_not(culprits)
if culprits.any():
logging.info('{} has {}'.format(j,np.sum(culprits)))
logging.info('deviation: {}'.format(np.absolute(data[0][j]-data[1][j])[culprits]))
logging.info('data : {}'.format(np.absolute(data[1][j])[culprits]))
logging.info('deviation: {}'.format(np.absolute(data[0][j]-data[1][j])[goodguys]))
logging.info('data : {}'.format(np.absolute(data[1][j])[goodguys]))
# for ok,valA,valB in zip(allclose,data[0],data[1]):
# logging.debug('{}:\n{}\n{}'.format(ok,valA,valB))
allclose = True # start optimistic allclose = True # start optimistic
for i in range(1,len(data)): for i in range(1,len(data)):
@ -565,7 +576,7 @@ class Test():
ret = culprit ret = culprit
if culprit == 0: if culprit == 0:
msg = 'The test passed' if len(self.variants) == 1 \ msg = 'The test passed.' if (self.options.select is not None or len(self.variants) == 1) \
else 'All {} tests passed.'.format(len(self.variants)) else 'All {} tests passed.'.format(len(self.variants))
elif culprit == -1: elif culprit == -1:
msg = 'Warning: Could not start test...' msg = 'Warning: Could not start test...'