mirror of
https://github.com/trezor/trezor-firmware.git
synced 2025-01-11 16:00:57 +00:00
tests/ui: introduce diff html
This commit is contained in:
parent
a70b347590
commit
15069f3e25
@ -30,6 +30,7 @@ from trezorlib.messages.PassphraseSourceType import HOST as PASSPHRASE_ON_HOST
|
||||
from trezorlib.transport import enumerate_devices, get_transport
|
||||
|
||||
from .device_handler import BackgroundDeviceHandler
|
||||
from .ui_tests import create_diff_html
|
||||
|
||||
|
||||
def get_device():
|
||||
@ -101,8 +102,8 @@ def _hash_files(files):
|
||||
return hasher.digest().hex()
|
||||
|
||||
|
||||
def _process_tested(screen_path, test_name):
|
||||
hash_file = screen_path / "../hash.txt"
|
||||
def _process_tested(fixture_test_path, test_name):
|
||||
hash_file = fixture_test_path / "hash.txt"
|
||||
|
||||
if not hash_file.exists():
|
||||
raise ValueError("File hash.txt not found.")
|
||||
@ -110,17 +111,22 @@ def _process_tested(screen_path, test_name):
|
||||
with open(hash_file, "r") as f:
|
||||
expected_hash = f.read()
|
||||
|
||||
_rename_records(screen_path)
|
||||
actual_path = fixture_test_path / "actual"
|
||||
_rename_records(actual_path)
|
||||
|
||||
records = sorted(screen_path.iterdir())
|
||||
records = sorted(actual_path.iterdir())
|
||||
actual_hash = _hash_files(records)
|
||||
|
||||
if actual_hash != expected_hash:
|
||||
create_diff_html(fixture_test_path, test_name, actual_hash, expected_hash)
|
||||
pytest.fail(
|
||||
"Hash of {} differs.\nExpected: {}\nActual: {}".format(
|
||||
test_name, expected_hash, actual_hash
|
||||
)
|
||||
)
|
||||
else:
|
||||
if (fixture_test_path / "diff.html").exists():
|
||||
(fixture_test_path / "diff.html").unlink()
|
||||
|
||||
|
||||
@contextmanager
|
||||
@ -155,7 +161,7 @@ def _screen_recording(client, request):
|
||||
if test_screen == "record":
|
||||
_process_recorded(screen_path)
|
||||
elif test_screen == "test":
|
||||
_process_tested(screen_path, test_name)
|
||||
_process_tested(fixture_test_path, test_name)
|
||||
else:
|
||||
raise ValueError("Invalid test_screen option.")
|
||||
|
||||
|
54
tests/ui_tests.py
Normal file
54
tests/ui_tests.py
Normal file
@ -0,0 +1,54 @@
|
||||
import filecmp
|
||||
from itertools import zip_longest
|
||||
|
||||
import dominate
|
||||
from dominate.tags import div, h1, hr, i, img, p, table, td, th, tr
|
||||
|
||||
|
||||
def create_diff_html(fixture_test_path, test_name, actual_hash, expected_hash):
|
||||
doc = dominate.document(title=test_name)
|
||||
recorded_path = fixture_test_path / "recorded"
|
||||
actual_path = fixture_test_path / "actual"
|
||||
|
||||
if not recorded_path.exists():
|
||||
return
|
||||
|
||||
recorded = sorted(recorded_path.iterdir())
|
||||
actual = sorted(actual_path.iterdir())
|
||||
|
||||
if not recorded:
|
||||
return
|
||||
|
||||
with doc:
|
||||
h1(test_name)
|
||||
with div():
|
||||
p("This test failed on UI comparison.")
|
||||
p("Expected: ", expected_hash)
|
||||
p("Actual: ", actual_hash)
|
||||
hr()
|
||||
|
||||
with table(border=1, width=600):
|
||||
with tr():
|
||||
th("Expected")
|
||||
th("Actual")
|
||||
|
||||
for r, a in zip_longest(recorded, actual):
|
||||
if r and a and filecmp.cmp(a, r):
|
||||
background = "white"
|
||||
else:
|
||||
background = "red"
|
||||
with tr(bgcolor=background):
|
||||
_image(r, fixture_test_path)
|
||||
_image(a, fixture_test_path)
|
||||
|
||||
with open(fixture_test_path / "diff.html", "w") as f:
|
||||
f.write(doc.render())
|
||||
f.close()
|
||||
|
||||
|
||||
def _image(src, fixture_test_path):
|
||||
with td():
|
||||
if src:
|
||||
img(src=src.relative_to(fixture_test_path))
|
||||
else:
|
||||
i("missing")
|
1
tests/ui_tests/.gitignore
vendored
1
tests/ui_tests/.gitignore
vendored
@ -1 +1,2 @@
|
||||
*.png
|
||||
*.html
|
||||
|
Loading…
Reference in New Issue
Block a user