1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
|
<svg xmlns="http://www.w3.org/2000/svg" xmlns:h="http://www.w3.org/1999/xhtml">
<title>'paint-order' computed style serialization</title>
<h:script src="/resources/testharness.js"/>
<h:script src="/resources/testharnessreport.js"/>
<text id="text" x="100" y="100"/>
<script><![CDATA[
'use strict';
function make_tests(check, type) {
let tests = [
// Single keyword
["normal", "normal"],
["fill", "fill"],
["stroke", "stroke"],
["markers", "markers"],
// Two keywords
["fill stroke", "fill"],
["fill markers", "fill markers"],
["stroke fill", "stroke"],
["stroke markers", "stroke markers"],
["markers fill", "markers"],
["markers stroke", "markers stroke"],
// Three keywords
["fill stroke markers", "fill"],
["fill markers stroke", "fill markers"],
["stroke fill markers", "stroke"],
["stroke markers fill", "stroke markers"],
["markers fill stroke", "markers"],
["markers stroke fill", "markers stroke"],
// Invalid
["foo", "normal"],
["fill foo", "normal"],
["stroke foo", "normal"],
["markers foo", "normal"],
["normal foo", "normal"],
["fill markers stroke foo", "normal"],
];
for (let [value, expected] of tests) {
test(() => {
check(value, expected);
}, `${document.title}, "${value}" => "${expected}" (${type})`);
}
}
const text = document.getElementById("text");
make_tests((value, expected) => {
text.setAttribute("style", "paint-order: " + value);
let actual = getComputedStyle(text).paintOrder;
text.removeAttribute("style");
assert_equals(actual, expected, value);
}, "property");
make_tests((value, expected) => {
text.setAttribute("paint-order", value);
let actual = getComputedStyle(text).paintOrder;
text.removeAttribute("paint-order");
assert_equals(actual, expected, value);
}, "presentation attribute");
]]>
</script>
</svg>
|