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
|
<!DOCTYPE HTML>
<html>
<!--
https://bugzilla.mozilla.org/show_bug.cgi?id=613888
-->
<head>
<title>Test for Bug 613888</title>
<script type="text/javascript" src="/MochiKit/MochiKit.js"></script>
<script src="/tests/SimpleTest/SimpleTest.js"></script>
<link rel="stylesheet" type="text/css" href="/tests/SimpleTest/test.css" />
<style type="text/css">
#animated-elements-container > span {
color: black;
background: white;
transition:
color 10s ease-out,
background 1s ease-out;
}
#animated-elements-container > span.another {
color: white;
background: black;
}
</style>
</head>
<body>
<a target="_blank" href="https://bugzilla.mozilla.org/show_bug.cgi?id=613888">Mozilla Bug 613888</a>
<pre id="animated-elements-container">
<span should-restyle="true">canceled on a half of the animation</span>
<span should-restyle="true">canceled too fast, and restyled on transitionend</span>
<span>canceled too fast, but not restyled on transitionend</span>
</pre>
<pre id="test">
<script class="testbody" type="text/javascript">
/** Test for Bug 613888: that we don't cancel transitions when they're
about to end (current interpolated value rounds to ending value) and
they get an unrelated style change. **/
var count_remaining = 6;
window.addEventListener('load', function() {
var cases = Array.from(document.querySelectorAll('#animated-elements-container > span'));
cases.forEach(function(aTarget) {
aTarget.addEventListener('transitionend', function(aEvent) {
if (aTarget.hasAttribute('should-restyle'))
aTarget.style.outline = '1px solid';
var attr = 'transitionend-' + aEvent.propertyName;
if (aTarget.hasAttribute(attr)) {
// It's possible, given bad timers, that we might get a
// transition that completed before we reversed it, which could
// lead to two transitionend events for the same thing. We
// don't want to decrement count_remaining in this case.
return;
}
aTarget.setAttribute(attr, "true");
if (--count_remaining == 0) {
cases.forEach(function(aCase, aIndex) {
ok(aCase.hasAttribute('transitionend-color'),
"transitionend for color was fired for case "+aIndex);
ok(aCase.hasAttribute('transitionend-background-color'),
"transitionend for background-color was fired for case "+aIndex);
});
SimpleTest.finish();
}
});
});
cases.forEach(aCase => aCase.className = 'another' );
window.setTimeout(() => cases[0].className = '', 500);
window.setTimeout(() => cases[1].className = cases[2].className = '', 250);
});
SimpleTest.waitForExplicitFinish();
SimpleTest.requestFlakyTimeout("untriaged");
</script>
</pre>
</body>
</html>
|