1
0
mirror of https://github.com/trezor/trezor-firmware.git synced 2025-01-18 19:31:04 +00:00

feat(tests): improve screenshot diffs

[no changelog]
This commit is contained in:
cepetr 2024-03-13 12:52:20 +01:00 committed by cepetr
parent b5b29daad1
commit dff12a32c1
4 changed files with 19 additions and 9 deletions

View File

@ -3,7 +3,7 @@ from typing import Any
import dominate import dominate
import dominate.tags as t import dominate.tags as t
from dominate.tags import a, h1, hr, i, p, table, td, th, tr from dominate.tags import a, h1, hr, i, p, script, table, td, th, tr
from ..common import ( from ..common import (
UI_TESTS_DIR, UI_TESTS_DIR,
@ -179,17 +179,23 @@ def _differing_screens_report(
model = "" model = ""
doc = document(title="Master differing screens", model=model) doc = document(title="Master differing screens", model=model)
with doc.head:
script(
type="text/javascript", src="https://cdn.jsdelivr.net/npm/pixelmatch@5.3.0"
)
with doc: with doc:
with table(border=1, width=600): with table(border=1, width=600):
with tr(): with tr():
th("Expected") th("Expected")
th("Actual") th("Actual")
th("Diff")
th("Testcase (link)") th("Testcase (link)")
for (master, current), testcase in unique_differing_screens.items(): for (master, current), testcase in unique_differing_screens.items():
with tr(bgcolor="red"): with tr(bgcolor="red"):
html.image_column(master, base_dir) html.image_column(master, base_dir)
html.image_column(current, base_dir) html.image_column(current, base_dir)
html.diff_column()
with td(): with td():
with a(href=f"diff/{testcase}.html"): with a(href=f"diff/{testcase}.html"):
i(testcase) i(testcase)

View File

@ -59,7 +59,7 @@ def image_column(hash: str | None, cur_dir: Path, img_id: str | None = None) ->
def diff_column() -> None: def diff_column() -> None:
"""Put diff image into table as one cell.""" """Put diff image into table as one cell."""
with td(bgcolor="white"): with td(bgcolor="white"):
a("Click to show") a("N/A")
def _relative_path(cur_dir: Path, path_to: Path) -> str: def _relative_path(cur_dir: Path, path_to: Path) -> str:
@ -88,6 +88,7 @@ def image_link(
src=_relative_path(cur_dir, path), src=_relative_path(cur_dir, path),
title=title, title=title,
loading="lazy", loading="lazy",
onload="imageLoaded(this)",
) )

View File

@ -183,12 +183,9 @@ function getImageData(image) {
} }
function createTableDiff(table) { function imageLoaded(img) {
// Process all rows in the table\ let row = img.closest("tr");
// (if the row doesn't contain two images, it's skipped) createRowDiff(row);
table.querySelectorAll("tr").forEach((row) => {
createRowDiff(row);
});
} }
function createRowDiff(row) { function createRowDiff(row) {

View File

@ -246,11 +246,16 @@ def differing_screens() -> None:
model = recent_ui_failures[0].test.model if recent_ui_failures else None model = recent_ui_failures[0].test.model if recent_ui_failures else None
doc = document(title="Differing screens", model=model) doc = document(title="Differing screens", model=model)
with doc.head:
script(
type="text/javascript", src="https://cdn.jsdelivr.net/npm/pixelmatch@5.3.0"
)
with doc: with doc:
with table(border=1, width=600): with table(border=1, width=600):
with tr(): with tr():
th("Expected") th("Expected")
th("Actual") th("Actual")
th("Diff")
th("Testcase (link)") th("Testcase (link)")
for ui_failure in recent_ui_failures: for ui_failure in recent_ui_failures:
@ -260,6 +265,7 @@ def differing_screens() -> None:
with tr(bgcolor="red"): with tr(bgcolor="red"):
html.image_column(recorded, TESTREPORT_PATH) html.image_column(recorded, TESTREPORT_PATH)
html.image_column(actual, TESTREPORT_PATH) html.image_column(actual, TESTREPORT_PATH)
html.diff_column()
with td(): with td():
with a(href=f"failed/{ui_failure.test.id}.html"): with a(href=f"failed/{ui_failure.test.id}.html"):
i(ui_failure.test.id) i(ui_failure.test.id)
@ -374,7 +380,7 @@ def failed(result: TestResult) -> Path:
strong("WARNING:") strong("WARNING:")
text(" failed to download recorded fixtures. Is this a new test case?") text(" failed to download recorded fixtures. Is this a new test case?")
with table(border=1, width=600, onclick="createTableDiff(this)"): with table(border=1, width=600):
with tr(): with tr():
th("Expected") th("Expected")
th("Actual") th("Actual")