undefined reference to 'JSC::B3::BasicBlock::fallThrough() const
[WebKit-https.git] / LayoutTests / http / wpt / web-animations / interfaces / AnimationEffectTiming / delay.html
1 <!DOCTYPE html>
2 <meta charset=utf-8>
3 <title>delay tests</title>
4 <link rel="help" href="https://w3c.github.io/web-animations/#dom-animationeffecttiming-delay">
5 <link rel="author" title="Daisuke Akatsuka" href="mailto:daisuke@mozilla-japan.org">
6 <script src="/resources/testharness.js"></script>
7 <script src="/resources/testharnessreport.js"></script>
8 <script src="../../testcommon.js"></script>
9 <body>
10 <div id="log"></div>
11 <script>
12 'use strict';
13
14 test(function(t) {
15   var anim = createDiv(t).animate(null);
16   assert_equals(anim.effect.timing.delay, 0);
17 }, 'Test default value');
18
19 test(function(t) {
20   var div = createDiv(t);
21   var anim = div.animate({ opacity: [ 0, 1 ] }, 100);
22   anim.effect.timing.delay = 100;
23   assert_equals(anim.effect.timing.delay, 100, 'set delay 100');
24   assert_equals(anim.effect.getComputedTiming().delay, 100,
25                   'getComputedTiming() after set delay 100');
26 }, 'set delay 100');
27
28 test(function(t) {
29   var div = createDiv(t);
30   var anim = div.animate({ opacity: [ 0, 1 ] }, 100);
31   anim.effect.timing.delay = -100;
32   assert_equals(anim.effect.timing.delay, -100, 'set delay -100');
33   assert_equals(anim.effect.getComputedTiming().delay, -100,
34                 'getComputedTiming() after set delay -100');
35 }, 'set delay -100');
36
37 test(function(t) {
38   var div = createDiv(t);
39   var anim = div.animate({ opacity: [ 0, 1 ] }, 100);
40   anim.effect.timing.delay = 100;
41   assert_equals(anim.effect.getComputedTiming().progress, null);
42   assert_equals(anim.effect.getComputedTiming().currentIteration, null);
43 }, 'Test adding a positive delay to an animation without a backwards fill ' +
44    'makes it no longer active');
45
46 test(function(t) {
47   var div = createDiv(t);
48   var anim = div.animate({ opacity: [ 0, 1 ] },
49                          { fill: 'both',
50                            duration: 100 });
51   anim.effect.timing.delay = -50;
52   assert_equals(anim.effect.getComputedTiming().progress, 0.5);
53 }, 'Test seeking an animation by setting a negative delay');
54
55 test(function(t) {
56   var div = createDiv(t);
57   var anim = div.animate({ opacity: [ 0, 1 ] },
58                          { fill: 'both',
59                            duration: 100 });
60   anim.effect.timing.delay = -100;
61   assert_equals(anim.effect.getComputedTiming().progress, 1);
62   assert_equals(anim.effect.getComputedTiming().currentIteration, 0);
63 }, 'Test finishing an animation using a large negative delay');
64
65 test(function(t) {
66   var div = createDiv(t);
67   var anim = div.animate(null);
68   for (let invalid of [NaN, Infinity]) {
69     assert_throws({ name: 'TypeError' }, function() {
70       anim.effect.timing.delay = invalid;
71     }, 'setting ' + invalid);
72     assert_throws({ name: 'TypeError' }, function() {
73       div.animate({}, { delay: invalid });
74     }, 'animate() with ' + invalid);
75   }
76 }, 'Setting invalid values should throw TypeError');
77
78 </script>
79 </body>