diff options
Diffstat (limited to 'testing/web-platform/tests/svg/scripted')
10 files changed, 228 insertions, 0 deletions
diff --git a/testing/web-platform/tests/svg/scripted/script-invalid-script-type.html b/testing/web-platform/tests/svg/scripted/script-invalid-script-type.html new file mode 100644 index 0000000000..9602dd525b --- /dev/null +++ b/testing/web-platform/tests/svg/scripted/script-invalid-script-type.html @@ -0,0 +1,16 @@ +<!doctype html> +<link rel="author" href="mailto:avandolder@mozilla.com" title="Adam Vandolder"> +<link rel="author" href="https://mozilla.org" title="Mozilla"> +<link rel="help" href="https://bugzilla.mozilla.org/show_bug.cgi?id=1827512"> +<script src="/resources/testharness.js"></script> +<script src="/resources/testharnessreport.js"></script> +<div id="host"></div> +<svg><script type="text/plain">window.scriptRan = true;</script></svg> +<script> + let svgScript = document.querySelector("svg > script"); + svgScript.type = "text/javascript"; + svgScript.appendChild(document.createTextNode("")); + test(function() { + assert_true(window.scriptRan); + }, "svg:script runs after valid script type is set"); +</script> diff --git a/testing/web-platform/tests/svg/scripted/script-runs-in-shadow-tree.html b/testing/web-platform/tests/svg/scripted/script-runs-in-shadow-tree.html new file mode 100644 index 0000000000..9693db333f --- /dev/null +++ b/testing/web-platform/tests/svg/scripted/script-runs-in-shadow-tree.html @@ -0,0 +1,15 @@ +<!doctype html> +<link rel="author" href="mailto:emilio@crisal.io" title="Emilio Cobos Álvarez"> +<link rel="author" href="https://mozilla.org" title="Mozilla"> +<link rel="help" href="https://bugzilla.mozilla.org/show_bug.cgi?id=1555949"> +<script src="/resources/testharness.js"></script> +<script src="/resources/testharnessreport.js"></script> +<div id="host"></div> +<script> + let svgScript = document.createElementNS("http://www.w3.org/2000/svg", "script"); + svgScript.innerHTML = "window.scriptRan = true"; + document.getElementById("host").attachShadow({ mode: "open" }).appendChild(svgScript); + test(function() { + assert_true(window.scriptRan); + }, "svg:script runs correctly in a shadow tree"); +</script> diff --git a/testing/web-platform/tests/svg/scripted/script-style-attribute-csp-ref.html b/testing/web-platform/tests/svg/scripted/script-style-attribute-csp-ref.html new file mode 100644 index 0000000000..a7316213f1 --- /dev/null +++ b/testing/web-platform/tests/svg/scripted/script-style-attribute-csp-ref.html @@ -0,0 +1,3 @@ +<!doctype html> +<meta charset="UTF-8"> +<svg style="width: 100px; height: 100px; background-color: green"></svg> diff --git a/testing/web-platform/tests/svg/scripted/script-style-attribute-csp.html b/testing/web-platform/tests/svg/scripted/script-style-attribute-csp.html new file mode 100644 index 0000000000..a70138d98a --- /dev/null +++ b/testing/web-platform/tests/svg/scripted/script-style-attribute-csp.html @@ -0,0 +1,22 @@ +<!doctype html> +<meta charset="UTF-8"> +<!-- + Allow scripts, but don't allow inline styles. + This does allow scripts to *set* inline styles via the .style attribute. +--> +<title>Setting style setters via script for an SVG element outside of the document should work</title> +<meta http-equiv="Content-Security-Policy" content=" + script-src 'unsafe-inline'; + style-src 'none'; +"> +<link rel="match" href="script-style-attribute-csp-ref.html"> +<link rel="author" title="Emilio Cobos Álvarez" href="mailto:emilio@crisal.io"> +<link rel="help" href="https://bugzilla.mozilla.org/show_bug.cgi?id=1494356"> +<body> +<script> + const element = document.createElementNS('http://www.w3.org/2000/svg', 'svg'); + element.style.width = '100px'; + element.style.height = '100px'; + element.style.backgroundColor = 'green'; + document.body.appendChild(element); +</script> diff --git a/testing/web-platform/tests/svg/scripted/text-attrs-dxdy-have-length.svg b/testing/web-platform/tests/svg/scripted/text-attrs-dxdy-have-length.svg new file mode 100644 index 0000000000..a5f07e29a1 --- /dev/null +++ b/testing/web-platform/tests/svg/scripted/text-attrs-dxdy-have-length.svg @@ -0,0 +1,23 @@ +<?xml version="1.0" standalone="no"?> +<svg xmlns="http://www.w3.org/2000/svg" + xmlns:h="http://www.w3.org/1999/xhtml"> + <metadata> + <h:link rel="help" href="https://svgwg.org/svg2-draft/single-page.html#text-TSpanNotes"/> + <h:meta name="assert" content="dx and dy attributes on text elements are lists that support length()"/> +</metadata> + <text id="text" font-family="Verdana" font-size="55" fill="blue" + y="150" + x="120" + dx="60 90 -30 120 60 -257" + dy="0 12 24 12 0 -12 -24 -12 0" + >His socks are black.</text> + <h:script src="/resources/testharness.js"/> + <h:script src="/resources/testharnessreport.js"/> + <script><![CDATA[ + test(function() { + var text = document.getElementById('text'); + assert_equals(text.dx.baseVal.length, 6); + assert_equals(text.dy.baseVal.length, 9); + }); + ]]></script> +</svg> diff --git a/testing/web-platform/tests/svg/scripted/text-attrs-xyrotate-have-length.svg b/testing/web-platform/tests/svg/scripted/text-attrs-xyrotate-have-length.svg new file mode 100644 index 0000000000..79d365ddec --- /dev/null +++ b/testing/web-platform/tests/svg/scripted/text-attrs-xyrotate-have-length.svg @@ -0,0 +1,24 @@ +<?xml version="1.0" standalone="no"?> +<svg xmlns="http://www.w3.org/2000/svg" + xmlns:h="http://www.w3.org/1999/xhtml"> + <metadata> + <h:link rel="help" href="https://svgwg.org/svg2-draft/single-page.html#text-TSpanNotes"/> + <h:meta name="assert" content="x y and rotate attributes on text elements are lists that support length()"/> +</metadata> + <text id="text" font-family="Verdana" font-size="55" fill="blue" + y="150 130 160" + x="120 160 200 240" + rotate="0 0 10, -10, 0" + >My socks are blue.</text> + <h:script src="/resources/testharness.js"/> + <h:script src="/resources/testharnessreport.js"/> + <script><![CDATA[ + /* The SVG spec requires (at least) readonly support for length */ + test(function() { + var text = document.getElementById('text'); + assert_equals(text.y.baseVal.length, 3); + assert_equals(text.x.baseVal.length, 4); + assert_equals(text.rotate.baseVal.length, 5); + }); + ]]></script> +</svg> diff --git a/testing/web-platform/tests/svg/scripted/text-tspan-attrs-have-length.svg b/testing/web-platform/tests/svg/scripted/text-tspan-attrs-have-length.svg new file mode 100644 index 0000000000..d189b531d7 --- /dev/null +++ b/testing/web-platform/tests/svg/scripted/text-tspan-attrs-have-length.svg @@ -0,0 +1,44 @@ +<?xml version="1.0" standalone="no"?> +<svg xmlns="http://www.w3.org/2000/svg" + xmlns:h="http://www.w3.org/1999/xhtml"> + <metadata> + <h:link rel="help" href="https://svgwg.org/svg2-draft/single-page.html#text-TSpanNotes"/> + <h:meta name="assert" content="x y dx dy and rotate attributes on text and tspan elements are lists that support length()"/> +</metadata> + <text id="text" font-family="Verdana" font-size="55" fill="blue" + y="150 130 160" x="120 160 200 240" rotate="0 0 10, -10, 0"> + My <tspan id="tspan" x="280 325" y="150 155 160 165 170" rotate="-30,0,30">socks</tspan> + are blue. + </text> + <h:script src="/resources/testharness.js"/> + <h:script src="/resources/testharnessreport.js"/> + <script><![CDATA[ + test(function() { + /* Make sure that text.y is a list, (presumably + * SVGAnimatedLengthList) and that the list has a + * length() method and that it returns the right thing. + * + * This test is for a change in SVG for 2.0, since 1.x, to add + * a length property. + */ + var text = document.getElementById('text'); + assert_equals(text.y.baseVal.length, 3); + assert_equals(text.x.baseVal.length, 4); + assert_equals(text.rotate.baseVal.length, 5); + + /* same for tspan */ + var tspan = document.getElementById('tspan'); + assert_equals(tspan.x.baseVal.length, 2); + assert_equals(tspan.y.baseVal.length, 5); + assert_equals(tspan.rotate.baseVal.length, 3); + + /* Note, we only have to test that the length property + * is there (and interoperable) when there is a list given; + * in practice it's there with value 0 when the attributes are + * absent, but that's not required, the attribute could be implemented + * as a plain string in that case, or absent entirely, I think + * - Liam Quin 2018 + */ + }); + ]]></script> +</svg> diff --git a/testing/web-platform/tests/svg/scripted/text-tspan-attrs-indexed-access.svg b/testing/web-platform/tests/svg/scripted/text-tspan-attrs-indexed-access.svg new file mode 100644 index 0000000000..b14b6bfc28 --- /dev/null +++ b/testing/web-platform/tests/svg/scripted/text-tspan-attrs-indexed-access.svg @@ -0,0 +1,33 @@ +<?xml version="1.0" standalone="no"?> +<svg xmlns="http://www.w3.org/2000/svg" + xmlns:h="http://www.w3.org/1999/xhtml"> + <metadata> + <h:link rel="help" href="https://svgwg.org/svg2-draft/single-page.html#text-TSpanNotes"/> + <h:meta name="assert" content="x y dx dy and rotate attributes on text and tspan elements are lists that support length()"/> +</metadata> + <text id="text" font-family="Verdana" font-size="55" fill="blue" + y="150 130 160" x="120 160 200 240" rotate="0 0 10, -10, 0"> + My <tspan id="tspan" x="280 325" y="150 155 160 165 170" rotate="-30,0,30">socks</tspan> + are blue. + </text> + <h:script src="/resources/testharness.js"/> + <h:script src="/resources/testharnessreport.js"/> + <script><![CDATA[ + test(function() { + /* Make sure that we can get at list items with indexed access. + */ + var text = document.getElementById('text'); + assert_equals(text.x.baseVal[0].value, 120); + assert_equals(text.y.baseVal[2].value, 160); + assert_equals(text.rotate.baseVal[3].value, -10); + assert_equals(text.rotate.baseVal[0].value, 0); + + /* same for tspan */ + var tspan = document.getElementById('tspan'); + assert_equals(tspan.x.baseVal[1].value, 325); + assert_equals(tspan.y.baseVal[4].value, 170); + assert_equals(tspan.rotate.baseVal[0].value, -30); + }); + + ]]></script> +</svg> diff --git a/testing/web-platform/tests/svg/scripted/tspan-attrs-dxdy-have-length.svg b/testing/web-platform/tests/svg/scripted/tspan-attrs-dxdy-have-length.svg new file mode 100644 index 0000000000..c8d002f1ce --- /dev/null +++ b/testing/web-platform/tests/svg/scripted/tspan-attrs-dxdy-have-length.svg @@ -0,0 +1,24 @@ +<?xml version="1.0" standalone="no"?> +<svg xmlns="http://www.w3.org/2000/svg" + xmlns:h="http://www.w3.org/1999/xhtml"> + <metadata> + <h:link rel="help" href="https://svgwg.org/svg2-draft/single-page.html#text-TSpanNotes"/> + <h:meta name="assert" content="dx, dy attrs on tspan support length()"/> +</metadata> + <text id="text" font-family="Verdana" font-size="55" fill="blue" + y="150" + x="120" + >His socks are <tspan id="tsp" + dx="60 90 -30 120 60 -257" + dy="0 12 24 12 0 -12 -24 -12 0" + >very</tspan> clean.</text> + <h:script src="/resources/testharness.js"/> + <h:script src="/resources/testharnessreport.js"/> + <script><![CDATA[ + test(function() { + var tspan = document.getElementById('tsp'); + assert_equals(tspan.dx.baseVal.length, 6); + assert_equals(tspan.dy.baseVal.length, 9); + }); + ]]></script> +</svg> diff --git a/testing/web-platform/tests/svg/scripted/tspan-attrs-xyrotate-have-length.svg b/testing/web-platform/tests/svg/scripted/tspan-attrs-xyrotate-have-length.svg new file mode 100644 index 0000000000..11086aa198 --- /dev/null +++ b/testing/web-platform/tests/svg/scripted/tspan-attrs-xyrotate-have-length.svg @@ -0,0 +1,24 @@ +<?xml version="1.0" standalone="no"?> +<svg xmlns="http://www.w3.org/2000/svg" + xmlns:h="http://www.w3.org/1999/xhtml"> + <metadata> + <h:link rel="help" href="https://svgwg.org/svg2-draft/single-page.html#text-TSpanNotes"/> + <h:meta name="assert" content="dx and dy attributes on text elements are lists that support length()"/> +</metadata> + <text id="text" font-family="Verdana" font-size="55" fill="blue" + y="150" + x="120" + >Her socks were <tspan id="tsp" + x="280 325" y="150 155 160 165 170" rotate="-30,0,30" + >stained</tspan> with blood.</text> + <h:script src="/resources/testharness.js"/> + <h:script src="/resources/testharnessreport.js"/> + <script><![CDATA[ + test(function() { + var tspan = document.getElementById('tsp'); + assert_equals(tspan.x.baseVal.length, 2); + assert_equals(tspan.y.baseVal.length, 5); + assert_equals(tspan.rotate.baseVal.length, 3); + }); + ]]></script> +</svg> |