summaryrefslogtreecommitdiffstats
path: root/layout/base/tests/test_bug435293-skew.html
blob: ce099a0c5174ccefcc48ce94e4934427ac719ed2 (plain)
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
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
<!DOCTYPE HTML>
<html>
<!--
https://bugzilla.mozilla.org/show_bug.cgi?id=435293
-->
<head>
  <title>Test for Bug 435293</title>
  <script src="/tests/SimpleTest/SimpleTest.js"></script>
  <link rel="stylesheet" type="text/css" href="/tests/SimpleTest/test.css" />

  <style>
    /* Skewed boxes can get very big.  The .pane wrapper prevents them
       from obscuring the test results.  */
    .pane {
      height: 300px;
      width: 300px;
      float: left;
      overflow: auto;
      border: 1px solid black;
    }
    .test {
      background: green;
      height: 100px;
      width: 100px;
      margin: 100px;
    }

    /* Radian units are not used in this test because our CSS
       implementation stores all dimensional values in single-
       precision floating point, which makes it impossible to
       hit mathematically interesting angles with radians.
       Degrees and grads do not suffer this problem.  */
    #test1 {
      transform: skewx(30deg);
    }
    #test2 {
      transform: skewy(60deg);
    }
    #test3 {
      transform: skew(45deg, 45deg);
    }
    #test4 {
      transform: skew(360deg, 45deg);
    }
    #test5 {
      transform: skew(45deg, 150grad);
    }
    #test6 {
      transform: skew(80%, 78px);
    }
    #test7 {
      transform: skew(2em, 40ex);
    }
    #test8 {
      transform: skew(-45deg, -465deg);
    }
    #test9 {
      transform: skew(30deg, 30deg, 30deg);
    }

    /* approach the singularity from the negative side */
    #test10 {
      transform: skew(50grad, 90.001deg);
    }
    #test11 {
      transform: skew(300grad, 90.001deg);
    }
  </style>
</head>
<body>
<a target="_blank" href="https://bugzilla.mozilla.org/show_bug.cgi?id=435293">Mozilla Bug 435293</a>
<p id="display"></p>
<div id="content">
  <div class="pane"><div id="test1" class="test">test</div></div>
  <div class="pane"><p id="test2" class="test">test</p></div>
  <div class="pane"><div id="test3" class="test">test</div></div>
  <div class="pane"><div id="test4" class="test">test</div></div>
  <div class="pane"><div id="test5" class="test">test</div></div>
  <div class="pane"><div id="test6" class="test">test</div></div>
  <div class="pane"><div id="test7" class="test">test</div></div>
  <div class="pane"><div id="test8" class="test">test</div></div>
  <div class="pane"><div id="test9" class="test">test</div></div>
  <div class="pane"><div id="test10" class="test">test</div></div>
  <div class="pane"><div id="test11" class="test">test</div></div>
</div>

<pre id="test">
<script type="application/javascript">
runtests();

function runtests() {
  // For test 1 we need to handle the contingency that different systems may
  // round differently.  We will parse out the values and compare them
  // individually.  The matrix should be: matrix(1, 0, 0.57735, 1, 0, 0)
  var style = window.getComputedStyle(document.getElementById("test1"));
  var tformStyle = style.getPropertyValue("transform");
  var tformValues = tformStyle.substring(tformStyle.indexOf('(') + 1,
                                         tformStyle.indexOf(')')).split(',');
  is((+tformValues[0]), 1, "Test1: skewx: param 0 is 1");
  is((+tformValues[1]), 0, "Test1: skewx: param 1 is 0");
  ok(verifyRounded(tformValues[2], 0.57735), "Test1: skewx: Rounded param 2 is in bounds");
  is((+tformValues[3]), 1, "Test1: skewx: param 3 is 1");
  is((+tformValues[4]), 0, "Test1: skewx: param 4 is 0");
  is((+tformValues[5]), 0, "Test1: skewx: param 5 is 0");

  // Again, handle rounding for test 2, proper matrix should be:
  // matrix(1, 1.73205, 0, 1, 0, 0)
  style = window.getComputedStyle(document.getElementById("test2"));
  tformStyle = style.getPropertyValue("transform");
  tformValues = tformStyle.substring(tformStyle.indexOf('(') + 1,
                                     tformStyle.indexOf(')')).split(',');
  is((+tformValues[0]), 1, "Test2: skewy: param 0 is 1");
  ok(verifyRounded(tformValues[1], 1.73205), "Test2: skewy: Rounded param 1 is in bounds");
  is((+tformValues[2]), 0, "Test2: skewy: param 2 is 0");
  is((+tformValues[3]), 1, "Test2: skewy: param 3 is 1");
  is((+tformValues[4]), 0, "Test2: skewy: param 4 is 0");
  is((+tformValues[5]), 0, "Test2: skewy: param 5 is 0");

  style = window.getComputedStyle(document.getElementById("test3"));
  is(style.getPropertyValue("transform"), "matrix(1, 1, 1, 1, 0, 0)",
     "Test3: Skew proper matrix is applied");

  style = window.getComputedStyle(document.getElementById("test4"));
  is(style.getPropertyValue("transform"), "matrix(1, 1, 0, 1, 0, 0)",
     "Test4: Skew angle wrap: proper matrix is applied");

  style = window.getComputedStyle(document.getElementById("test5"));
  is(style.getPropertyValue("transform"), "matrix(1, -1, 1, 1, 0, 0)",
     "Test5: Skew mixing deg and grad");

  style = window.getComputedStyle(document.getElementById("test6"));
  is(style.getPropertyValue("transform"), "none",
     "Test6: Skew with invalid units");

  style = window.getComputedStyle(document.getElementById("test7"));
  is(style.getPropertyValue("transform"), "none",
     "Test7: Skew with more invalid units");

  // Test 8: skew with negative degrees, here again we must handle rounding.
  // The matrix should be: matrix(1, 3.73206, -1, 1, 0, 0)
  style = window.getComputedStyle(document.getElementById("test8"));
  tformStyle = style.getPropertyValue("transform");
  tformValues = tformStyle.substring(tformStyle.indexOf('(') + 1,
                                     tformStyle.indexOf(')')).split(',');
  is((+tformValues[0]), 1, "Test8: Test skew with negative degrees-param 0 is 1");
  ok(verifyRounded(tformValues[1], 3.73206), "Test8: Rounded param 1 is in bounds");
  is((+tformValues[2]), -1, "Test8: param 2 is -1");
  is((+tformValues[3]), 1, "Test8: param 3 is 1");
  is((+tformValues[4]), 0, "Test8: param 4 is 0");
  is((+tformValues[5]), 0, "Test8: param 5 is 0");

  style = window.getComputedStyle(document.getElementById("test9"));
  is(style.getPropertyValue("transform"), "none",
     "Test9: Skew in 3d should be ignored");

  style = window.getComputedStyle(document.getElementById("test10"));
  is(style.getPropertyValue("transform"), "matrix(1, -10000, 1, 1, 0, 0)",
     "Test10: Skew with nearly infinite numbers");

  style = window.getComputedStyle(document.getElementById("test11"));
  is(style.getPropertyValue("transform"), "matrix(1, -10000, 10000, 1, 0, 0)",
     "Test11: Skew with more infinite numbers");
}

// Verifies that aVal is +/- 0.00001 of aTrueVal
// Returns true if so, false if not
function verifyRounded(aVal, aTrueVal) {
  return (Math.abs(aVal - aTrueVal).toFixed(5) <= 0.00001);
}
</script>
</pre>
</body>
</html>