[test] Always fail subset tests if hashes don’t match
Regardless of the pre sentience or absence of fonttools.
This commit is contained in:
parent
e80c86ffa6
commit
f698fe5aee
|
@ -69,50 +69,41 @@ def run_test (test, should_check_ots):
|
||||||
actual_hash = hashlib.sha224(fp.read()).hexdigest()
|
actual_hash = hashlib.sha224(fp.read()).hexdigest()
|
||||||
|
|
||||||
if expected_hash == actual_hash:
|
if expected_hash == actual_hash:
|
||||||
return 0
|
|
||||||
|
|
||||||
if TTFont is None:
|
|
||||||
print ("fonttools is not present, skipping test.")
|
|
||||||
sys.exit (77)
|
|
||||||
|
|
||||||
expected_ttx = io.StringIO ()
|
|
||||||
try:
|
|
||||||
with TTFont (expected_file) as font:
|
|
||||||
font.saveXML (expected_ttx)
|
|
||||||
except Exception as e:
|
|
||||||
print (e)
|
|
||||||
return fail_test (test, cli_args, "ttx failed to parse the expected result")
|
|
||||||
|
|
||||||
actual_ttx = io.StringIO ()
|
|
||||||
try:
|
|
||||||
with TTFont (out_file) as font:
|
|
||||||
font.saveXML (actual_ttx)
|
|
||||||
except Exception as e:
|
|
||||||
print (e)
|
|
||||||
return fail_test (test, cli_args, "ttx failed to parse the actual result")
|
|
||||||
|
|
||||||
expected_ttx_text = strip_check_sum (expected_ttx.getvalue ())
|
|
||||||
expected_ttx.close ()
|
|
||||||
actual_ttx_text = strip_check_sum (actual_ttx.getvalue ())
|
|
||||||
actual_ttx.close ()
|
|
||||||
|
|
||||||
if not actual_ttx_text == expected_ttx_text:
|
|
||||||
for line in unified_diff (expected_ttx_text.splitlines (1), actual_ttx_text.splitlines (1)):
|
|
||||||
sys.stdout.write (line)
|
|
||||||
sys.stdout.flush ()
|
|
||||||
return fail_test (test, cli_args, 'ttx for expected and actual does not match.')
|
|
||||||
|
|
||||||
if should_check_ots:
|
if should_check_ots:
|
||||||
print ("Checking output with ots-sanitize.")
|
print ("Checking output with ots-sanitize.")
|
||||||
if not check_ots (out_file):
|
if not check_ots (out_file):
|
||||||
return fail_test (test, cli_args, 'ots for subsetted file fails.')
|
return fail_test (test, cli_args, 'ots for subsetted file fails.')
|
||||||
|
|
||||||
return 0
|
return 0
|
||||||
|
|
||||||
def strip_check_sum (ttx_string):
|
if TTFont is None:
|
||||||
return re.sub ('checkSumAdjustment value=["]0x([0-9a-fA-F])+["]',
|
print ("fonttools is not present, skipping TTX diff.")
|
||||||
'checkSumAdjustment value="0x00000000"',
|
return fail_test (test, cli_args, "hash for expected and actual does not match.")
|
||||||
ttx_string, count=1)
|
|
||||||
|
with io.StringIO () as fp:
|
||||||
|
try:
|
||||||
|
with TTFont (expected_file) as font:
|
||||||
|
font.saveXML (fp)
|
||||||
|
except Exception as e:
|
||||||
|
print (e)
|
||||||
|
return fail_test (test, cli_args, "ttx failed to parse the expected result")
|
||||||
|
expected_ttx = fp.getvalue ()
|
||||||
|
|
||||||
|
with io.StringIO () as fp:
|
||||||
|
try:
|
||||||
|
with TTFont (out_file) as font:
|
||||||
|
font.saveXML (fp)
|
||||||
|
except Exception as e:
|
||||||
|
print (e)
|
||||||
|
return fail_test (test, cli_args, "ttx failed to parse the actual result")
|
||||||
|
actual_ttx = fp.getvalue ()
|
||||||
|
|
||||||
|
if actual_ttx != expected_ttx:
|
||||||
|
for line in unified_diff (expected_ttx.splitlines (1), actual_ttx.splitlines (1)):
|
||||||
|
sys.stdout.write (line)
|
||||||
|
sys.stdout.flush ()
|
||||||
|
return fail_test (test, cli_args, 'ttx for expected and actual does not match.')
|
||||||
|
|
||||||
|
return 1
|
||||||
|
|
||||||
def has_ots ():
|
def has_ots ():
|
||||||
if not ots_sanitize:
|
if not ots_sanitize:
|
||||||
|
|
Loading…
Reference in New Issue