Skip to content

Commit

Permalink
meta: Add some comparison testing.
Browse files Browse the repository at this point in the history
  • Loading branch information
Gorash authored Sep 20, 2024
1 parent 079181a commit 65fd403
Show file tree
Hide file tree
Showing 14 changed files with 672 additions and 176 deletions.
1 change: 1 addition & 0 deletions .gitignore
Original file line number Diff line number Diff line change
@@ -1,5 +1,6 @@
.cutekit/
__pycache__/
tmp/
.vscode/
.DS_Store
.python-version
Expand Down
2 changes: 1 addition & 1 deletion ck
Original file line number Diff line number Diff line change
Expand Up @@ -65,7 +65,7 @@ if [ ! -f .cutekit/tools-ready ]; then
mkdir -p .cutekit
if [ ! -d .cutekit/venv ]; then
echo "Setting up Python virtual environment..."
python3 -m venv .cutekit/venv
python3.11 -m venv .cutekit/venv
fi
source .cutekit/venv/bin/activate

Expand Down
122 changes: 103 additions & 19 deletions meta/plugins/reftest.py
Original file line number Diff line number Diff line change
@@ -1,8 +1,8 @@
from cutekit import shell, vt100, cli, builder, model
from pathlib import Path
import dataclasses as dt
from dataclasses_json import DataClassJsonMixin
import tempfile
import re
import textwrap
import difflib


def buildPaperMuncher(args: model.TargetArgs) -> builder.ProductScope:
Expand All @@ -17,24 +17,108 @@ def buildPaperMuncher(args: model.TargetArgs) -> builder.ProductScope:
def _(args: model.TargetArgs):
paperMuncher = buildPaperMuncher(args)

for file in shell.find("tests", ["*.html", "*.xhtml"]):
print(f"Running reftest {file}...")
path = Path(file)
test_tmp_folder = Path(__file__).parent.parent.parent / 'tests/tmp'
test_tmp_folder.mkdir(parents=True, exist_ok=True)
for temp in test_tmp_folder.glob('*.*'):
temp.unlink()

refPath = path.parent / ".ref" / (path.name + ".ref")
output = paperMuncher.popen("print", "-sdlpo", "/dev/null", file)
temp_file = test_tmp_folder / 'reftest.xhtml'
def update_temp_file(container, rendering):
# write xhtml into the temporary file
xhtml = container.replace("<slot/>", rendering) if container else rendering
with temp_file.open("w") as f:
f.write(f"<!DOCTYPE html>\n{textwrap.dedent(xhtml)}")

if not refPath.exists():
vt100.warning(f"{refPath} not found, creating reference")
refPath.parent.mkdir(parents=True, exist_ok=True)
with refPath.open("x") as ref:
ref.write(output)
for file in shell.find("tests", ["*.xhtml"]):
if '/tmp/' in file:
continue

with refPath.open() as ref:
refContent = ref.read()
print(f"Running comparison test {file}...")

if refContent == output:
print(f"{vt100.GREEN}Passed{vt100.RESET}")
else:
print(f"{vt100.RED}Failed{vt100.RESET}")
with Path(file).open() as f:
content = f.read()

Num = 0
for id, name, test in re.findall(r"""<test\s*(?:id=['"]([^'"]+)['"])?\s*(?:name=['"]([^'"]+)['"])?\s*>([\w\W]+?)</test>""", content):
print(f"{vt100.WHITE}Test {name!r}{vt100.RESET}")
Num += 1
temp_file_name = re.sub(r"[^\w.-]", "_", f"{file}-{id or Num}")

search = re.search(r"""<container>([\w\W]+?)</container>""", content)
container = search and search.group(1)

expected_xhtml = None
expected_image = None
if id:
ref_image = Path(file).parent / f'{id}.bmp'
if ref_image.exists():
with ref_image.open('rb') as f:
expected_image = f.read()
with (test_tmp_folder / f"{temp_file_name}.expected.bmp").open("wb") as f:
f.write(expected_image)

num = 0
for tag, info, rendering in re.findall(r"""<(rendering|error)([^>]*)>([\w\W]+?)</(?:rendering|error)>""", test):
num += 1
if "skip" in info:
print(f"{vt100.YELLOW}Skip test{vt100.RESET}")
continue

update_temp_file(container, rendering)

# generate temporary bmp
img_path = test_tmp_folder / f"{temp_file_name}-{num}.bmp"
paperMuncher.popen("render", "-sdlpo", img_path, temp_file)
with img_path.open('rb') as f:
output_image = f.read()

# the first template is the expected value
if not expected_xhtml:
expected_xhtml = rendering
expected_pdf = paperMuncher.popen("print", "-sdlpo", test_tmp_folder / f"{temp_file_name}.expected.pdf", temp_file)
if not expected_image:
expected_image = output_image
with (test_tmp_folder / f"{temp_file_name}.expected.bmp").open("wb") as f:
f.write(expected_image)
continue

# check if the rendering is different
if (expected_image == output_image) == (tag == "rendering"):
img_path.unlink()
print(f"{vt100.GREEN}Passed{vt100.RESET}")
else:
# generate temporary file for debugging
output_pdf = paperMuncher.popen("print", "-sdlpo", test_tmp_folder / f"{temp_file_name}-{num}.pdf", temp_file)

if tag == "error":
print(f"{vt100.RED}Failed {name!r} (The result should be different){vt100.RESET}")
print(f"{vt100.WHITE}{expected_xhtml[1:].rstrip()}{vt100.RESET}")
print(f"{vt100.BLUE}{rendering[1:].rstrip()}{vt100.RESET}")
print(f"{vt100.BLUE}{test_tmp_folder / f'{temp_file_name}-{num}.pdf'}{vt100.RESET}")
print(f"{vt100.BLUE}{test_tmp_folder / f'{temp_file_name}-{num}.bmp'}{vt100.RESET}")
else:
print(f"{vt100.RED}Failed {name!r}{vt100.RESET}")
print(f"{vt100.WHITE}{expected_xhtml[1:].rstrip()}{vt100.RESET}")
print(f"{vt100.WHITE}{test_tmp_folder / f'{temp_file_name}.expected.pdf'}{vt100.RESET}")
print(f"{vt100.WHITE}{test_tmp_folder / f'{temp_file_name}.expected.bmp'}{vt100.RESET}")
print(f"{vt100.BLUE}{rendering[1:].rstrip()}{vt100.RESET}")
print(f"{vt100.BLUE}{test_tmp_folder / f'{temp_file_name}-{num}.pdf'}{vt100.RESET}")
print(f"{vt100.BLUE}{test_tmp_folder / f'{temp_file_name}-{num}.bmp'}{vt100.RESET}")

# print rendering diff
output = output_pdf.split("---")[-3]
expected = expected_pdf.split('---')[-3]
if expected == output:
continue
diff_html = []
theDiffs = difflib.ndiff(expected.splitlines(), output.splitlines())
for eachDiff in theDiffs:
if eachDiff[0] == "-":
diff_html.append(f"{vt100.RED}{eachDiff}{vt100.RESET}")
elif eachDiff[0] == "+":
diff_html.append(f"{vt100.GREEN}{eachDiff}{vt100.RESET}")
elif eachDiff[0] != "?":
diff_html.append(eachDiff)
print('\n'.join(diff_html))

temp_file.unlink()
132 changes: 0 additions & 132 deletions tests/css/.ref/cascade.xhtml.ref

This file was deleted.

24 changes: 0 additions & 24 deletions tests/css/cascade.xhtml

This file was deleted.

Binary file added tests/css/display-block-basic.bmp
Binary file not shown.
Loading

0 comments on commit 65fd403

Please sign in to comment.