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
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
|
<!DOCTYPE html>
<link rel="help" href="https://drafts.csswg.org/css-values-4/#comp-func">
<link rel="help" href="https://drafts.csswg.org/css-values-4/#numbers">
<link rel="help" href="https://drafts.csswg.org/css-values-4/#calc-serialize">
<link rel="author" title="Apple Inc">
<script src="/resources/testharness.js"></script>
<script src="/resources/testharnessreport.js"></script>
<script src="../support/serialize-testcommon.js"></script>
<div id=target></div>
<script>
function test_serialization(t,s,c) {
test_specified_serialization('opacity', t, s);
test_specified_serialization('transform', `scale(${t})`, `scale(calc(${c}))`);
test_computed_serialization('opacity', t, c);
test_computed_serialization('transform', `scale(${t})`, `matrix(${c}, 0, 0, ${c}, 0, 0)`);
}
test_serialization(
'abs(1)',
'calc(1)',
'1');
test_serialization(
'sign(.1)',
'calc(1)',
'1');
test_serialization(
'abs(1 + 2 + 3)',
'calc(6)',
'6');
test_serialization(
'sign(1 + 2 + 3)',
'calc(1)',
'1');
test_serialization(
'calc(abs(1) + abs(2))',
'calc(3)',
'3');
test_serialization(
'calc(sign(.1) + sign(.2))',
'calc(2)',
'2');
test_serialization(
'calc(1 + abs(1))',
'calc(2)',
'2');
test_serialization(
'calc(sign(.1) + 1)',
'calc(2)',
'2');
test_serialization(
'calc(abs(inFinity))',
'calc(inFinity)',
'infinity');
test_serialization(
'calc(abs(infinity))',
'calc(infinity)',
'infinity');
test_serialization(
'calc(sign(infinity))',
'calc(1)',
'1');
test_serialization(
'abs(infinity)',
'calc(infinity)',
'infinity');
test_serialization(
'calc(abs(-infinity))',
'calc(infinity)',
'infinity');
test_serialization(
'calc(sign(-1 * infinity))',
'calc(-1)',
'-1');
</script>
|