diff options
Diffstat (limited to 'testing/web-platform/tests/html/canvas/tools/templates')
7 files changed, 262 insertions, 0 deletions
diff --git a/testing/web-platform/tests/html/canvas/tools/templates/reftest.html b/testing/web-platform/tests/html/canvas/tools/templates/reftest.html new file mode 100644 index 0000000000..4c9affbbbb --- /dev/null +++ b/testing/web-platform/tests/html/canvas/tools/templates/reftest.html @@ -0,0 +1,14 @@ +<!DOCTYPE html> +<!-- DO NOT EDIT! This test has been generated by /html/canvas/tools/gentest.py. --> +<title>Canvas test: {{ name }}</title> +<h1>{{ name }}</h1> +<p class="desc">{{ desc }}</p> +{% if notes %}<p class="notes">{{ notes }}{% endif %} + +{{ code | trim }} +{% for image in images %} +<img src="/images/{{ image }}" id="{{ image }}" class="resource"> +{% endfor -%} +{% for svgimage in svgimages %} +<svg><image xlink:href="/images/{{ svgimage }}" id="{{ svgimage }}" class="resource"></svg> +{% endfor -%} diff --git a/testing/web-platform/tests/html/canvas/tools/templates/reftest_element.html b/testing/web-platform/tests/html/canvas/tools/templates/reftest_element.html new file mode 100644 index 0000000000..6684e9c615 --- /dev/null +++ b/testing/web-platform/tests/html/canvas/tools/templates/reftest_element.html @@ -0,0 +1,34 @@ +<!DOCTYPE html> +<!-- DO NOT EDIT! This test has been generated by /html/canvas/tools/gentest.py. --> +{% if test_type == 'promise' %}<html class="reftest-wait"> +{% endif %} +{% if not is_test_reference %} +<link rel="match" href="{{ name }}-expected.html"> +{% if fuzzy %}<meta name=fuzzy content="{{ fuzzy }}"> +{% endif %} +{% endif %} +{% if timeout %}<meta name="timeout" content="{{ timeout }}"> +{% endif %} +<title>Canvas test: {{ name }}</title> +<h1>{{ name }}</h1> +<p class="desc">{{ desc }}</p> +{% if notes %}<p class="notes">{{ notes }}{% endif %} +<canvas id="canvas" width="{{ size[0] }}" height="{{ size[1] }}"{{ canvas }}> + <p class="fallback">FAIL (fallback content)</p> +</canvas> +<script{% if test_type == 'promise' %} type="module"{% endif %}> + const canvas = document.getElementById("canvas"); + const ctx = canvas.getContext('2d'{% if attributes %}, {{ attributes }}{% endif %}); + + {{ code | trim | indent(2) }} + {% if test_type == 'promise' %} + document.documentElement.classList.remove("reftest-wait"); + {% endif %} +</script> +{% for image in images %} +<img src="/images/{{ image }}" id="{{ image }}" class="resource"> +{% endfor -%} +{% for svgimage in svgimages %} +<svg><image xlink:href="/images/{{ svgimage }}" id="{{ svgimage }}" class="resource"></svg> +{% endfor -%} +{% if test_type == 'promise' %}</html>{% endif %} diff --git a/testing/web-platform/tests/html/canvas/tools/templates/reftest_offscreen.html b/testing/web-platform/tests/html/canvas/tools/templates/reftest_offscreen.html new file mode 100644 index 0000000000..1d0d93dfa1 --- /dev/null +++ b/testing/web-platform/tests/html/canvas/tools/templates/reftest_offscreen.html @@ -0,0 +1,29 @@ +<!DOCTYPE html> +<!-- DO NOT EDIT! This test has been generated by /html/canvas/tools/gentest.py. --> +{% if test_type == 'promise' %}<html class="reftest-wait"> +{% endif %} +<link rel="match" href="{{ name }}-expected.html"> +{% if fuzzy %}<meta name=fuzzy content="{{ fuzzy }}"> +{% endif %} +{% if timeout %}<meta name="timeout" content="{{ timeout }}"> +{% endif %} +<title>Canvas test: {{ name }}</title> +<h1>{{ name }}</h1> +<p class="desc">{{ desc }}</p> +{% if notes %}<p class="notes">{{ notes }}{% endif %} +<canvas id="canvas" width="{{ size[0] }}" height="{{ size[1] }}"{{ canvas }}> + <p class="fallback">FAIL (fallback content)</p> +</canvas> +<script{% if test_type == 'promise' %} type="module"{% endif %}> + const canvas = new OffscreenCanvas({{ size[0] }}, {{ size[1] }}); + const ctx = canvas.getContext('2d'{% if attributes %}, {{ attributes }}{% endif %}); + + {{ code | trim | indent(2) }} + + const outputCanvas = document.getElementById("canvas"); + outputCanvas.getContext('2d'{% if attributes %}, {{ attributes }}{% endif %}).drawImage(canvas, 0, 0); + {% if test_type == 'promise' %} + document.documentElement.classList.remove("reftest-wait"); + {% endif %} +</script> +{% if test_type == 'promise' %}</html>{% endif %} diff --git a/testing/web-platform/tests/html/canvas/tools/templates/reftest_worker.html b/testing/web-platform/tests/html/canvas/tools/templates/reftest_worker.html new file mode 100644 index 0000000000..e636d3634b --- /dev/null +++ b/testing/web-platform/tests/html/canvas/tools/templates/reftest_worker.html @@ -0,0 +1,37 @@ +<!DOCTYPE html> +<!-- DO NOT EDIT! This test has been generated by /html/canvas/tools/gentest.py. --> +<html class="reftest-wait"> +<link rel="match" href="{{ name }}-expected.html"> +{% if fuzzy %}<meta name=fuzzy content="{{ fuzzy }}"> +{% endif %} +{% if timeout %}<meta name="timeout" content="{{ timeout }}"> +{% endif %} +<title>Canvas test: {{ name }}</title> +<h1>{{ name }}</h1> +<p class="desc">{{ desc }}</p> +{% if notes %}<p class="notes">{{ notes }}{% endif %} +<canvas id="canvas" width="{{ size[0] }}" height="{{ size[1] }}"{{ canvas }}> + <p class="fallback">FAIL (fallback content)</p> +</canvas> +<script id='myWorker' type='text/worker'> + self.onmessage = {% if test_type == 'promise' %}async {% endif %}function(e) { + const canvas = new OffscreenCanvas({{ size[0] }}, {{ size[1] }}); + const ctx = canvas.getContext('2d'{% if attributes %}, {{ attributes }}{% endif %}); + + {{ code | trim | indent(4) }} + + const bitmap = canvas.transferToImageBitmap(); + self.postMessage(bitmap, bitmap); + }; +</script> +<script> + const blob = new Blob([document.getElementById('myWorker').textContent]); + const worker = new Worker(URL.createObjectURL(blob)); + worker.addEventListener('message', msg => { + const outputCtx = document.getElementById("canvas").getContext('2d'{% if attributes %}, {{ attributes }}{% endif %}); + outputCtx.drawImage(msg.data, 0, 0); + document.documentElement.classList.remove("reftest-wait"); + }); + worker.postMessage(null); +</script> +</html> diff --git a/testing/web-platform/tests/html/canvas/tools/templates/testharness_element.html b/testing/web-platform/tests/html/canvas/tools/templates/testharness_element.html new file mode 100644 index 0000000000..56cde7936a --- /dev/null +++ b/testing/web-platform/tests/html/canvas/tools/templates/testharness_element.html @@ -0,0 +1,68 @@ +<!DOCTYPE html> +<!-- DO NOT EDIT! This test has been generated by /html/canvas/tools/gentest.py. --> +<title>Canvas test: {{ name }}</title> +<script src="/resources/testharness.js"></script> +<script src="/resources/testharnessreport.js"></script> +<script src="/html/canvas/resources/canvas-tests.js"></script> +<link rel="stylesheet" href="/html/canvas/resources/canvas-tests.css"> +{% if fonts %} +<style> +{% for font in fonts %} +@font-face { + font-family: {{ font }}; + src: url("/fonts/{{ font }}.ttf"); +} +{% endfor %} +</style> +{% endif %} +<body class="show_output"> + +<h1>{{ name }}</h1> +<p class="desc">{{ desc }}</p> + +{% if notes %}<p class="notes">{{ notes }} +{% else %} + +{% endif %} +{% if fonts and not font_unused_in_dom %} +{% for font in fonts %} +<span style="font-family: {{ font }}; position: absolute; visibility: hidden">A</span> +{% endfor %} +{% endif %} +<p class="output">Actual output:</p> +<canvas id="c" class="output" width="{{ size[0] }}" height="{{ size[1] }}" + {{- canvas}}><p class="fallback">FAIL (fallback content)</p></canvas> +{% if expected_img %} +<p class="output expectedtext">Expected output:<p><img src="{{ expected_img }}" class="output expected" id="expected" alt=""> +{%- endif +%} +<ul id="d"></ul> +<script> + +{#- Promise vs. async test header: +#} +{% if test_type == 'promise' %} +promise_test(async t => { + + var canvas = document.getElementById('c'); + var ctx = canvas.getContext('2d'{% if attributes %}, {{ attributes }}{% endif %}); +{% else %} +var t = async_test("{{ desc | double_quote_escape }}"); +_addTest(function(canvas, ctx) { +{% endif %} + + {# Test body: #} + {{ code | trim | indent(2) }} + +{# Promise vs. async test footer: #} +{% if test_type == 'promise' %} +}, "{{ desc }}"); +{% else %} +}{% if attributes %}, {{ attributes }}{% endif %}); +{% endif -%} + +</script> +{% for image in images %} +<img src="/images/{{ image }}" id="{{ image }}" class="resource"> +{% endfor -%} +{% for svgimage in svgimages %} +<svg><image xlink:href="/images/{{ svgimage }}" id="{{ svgimage }}" class="resource"></svg> +{% endfor +%} diff --git a/testing/web-platform/tests/html/canvas/tools/templates/testharness_offscreen.html b/testing/web-platform/tests/html/canvas/tools/templates/testharness_offscreen.html new file mode 100644 index 0000000000..8ebbff77a6 --- /dev/null +++ b/testing/web-platform/tests/html/canvas/tools/templates/testharness_offscreen.html @@ -0,0 +1,45 @@ +<!DOCTYPE html> +<!-- DO NOT EDIT! This test has been generated by /html/canvas/tools/gentest.py. --> +<title>OffscreenCanvas test: {{ name }}</title> +{% if timeout %}<meta name="timeout" content="{{ timeout }}">{% endif %} +<script src="/resources/testharness.js"></script> +<script src="/resources/testharnessreport.js"></script> +<script src="/html/canvas/resources/canvas-tests.js"></script> + +<h1>{{ name }}</h1> +<p class="desc">{{ desc }}</p> + +{% if notes %}<p class="notes">{{ notes }}{% endif +%} +<script> + +{#- Promise vs. async test header: +#} +{% if test_type == 'promise' %} +promise_test(async t => { +{% else %} +var t = async_test("{{ desc | double_quote_escape }}"); +var t_pass = t.done.bind(t); +var t_fail = t.step_func(function(reason) { + throw reason; +}); +t.step(function() { +{% endif %} + +{# Test body: #} + var canvas = new OffscreenCanvas({{ size[0] }}, {{ size[1] }}); + var ctx = canvas.getContext('2d'{% if attributes %}, {{ attributes }}{% endif %}); + + {{ code | trim | indent(2)}} + +{#- Promise vs. async test footer: +#} +{% if test_type == 'promise' %} + +}, "{{ desc }}"); +{% else %} + t.done(); + +}); +{% endif %} +</script> +{% for svgimage in svgimages %} +<svg><image xlink:href="/images/{{ svgimage }}" id="{{ svgimage }}" class="resource"></svg> +{% endfor %} diff --git a/testing/web-platform/tests/html/canvas/tools/templates/testharness_worker.js b/testing/web-platform/tests/html/canvas/tools/templates/testharness_worker.js new file mode 100644 index 0000000000..f1f04e7bb6 --- /dev/null +++ b/testing/web-platform/tests/html/canvas/tools/templates/testharness_worker.js @@ -0,0 +1,35 @@ +{% if timeout %}// META: timeout={{ timeout }}{% endif %} +// DO NOT EDIT! This test has been generated by /html/canvas/tools/gentest.py. +// OffscreenCanvas test in a worker:{{ name }} +// Description:{{ desc }} +// Note:{% if notes %}<p class="notes">{{ notes }}{% endif +%} + +importScripts("/resources/testharness.js"); +importScripts("/html/canvas/resources/canvas-tests.js"); + +{# Promise vs. async test header: #} +{% if test_type == 'promise' %} +promise_test(async t => { +{% else %} +var t = async_test("{{ desc | double_quote_escape }}"); +var t_pass = t.done.bind(t); +var t_fail = t.step_func(function(reason) { + throw reason; +}); +t.step(function() { +{% endif %} + +{# Test body: #} + var canvas = new OffscreenCanvas({{ size[0] }}, {{ size[1] }}); + var ctx = canvas.getContext('2d'{% if attributes %}, {{ attributes }}{% endif %}); + + {{ code | trim | indent(2)}} + t.done(); + +{#- Promise vs. async test footer: +#} +{% if test_type == 'promise' %} +}, "{{ desc }}"); +{% else %} +}); +{% endif %} +done(); |