1902da1b882ab705f942cbab4b75ecd410f7dbfb
[WebKit-https.git] / LayoutTests / imported / mozilla / css-transitions / test_document-get-animations.html
1 <!doctype html>
2 <meta charset=utf-8>
3 <script src="../../../resources/testharness.js"></script>
4 <script src="../../../resources/testharnessreport.js"></script>
5 <script src="../resources/testcommon.js"></script>
6 <body>
7 <div id="log"></div>
8 <script>
9 'use strict';
10
11 test(function(t) {
12   assert_equals(document.getAnimations().length, 0,
13     'getAnimations returns an empty sequence for a document'
14     + ' with no animations');
15 }, 'getAnimations for non-animated content');
16
17 test(function(t) {
18   var div = addDiv(t);
19
20   // Add a couple of transitions
21   div.style.left = '0px';
22   div.style.top = '0px';
23   getComputedStyle(div).transitionProperty;
24
25   div.style.transition = 'all 100s';
26   div.style.left = '100px';
27   div.style.top = '100px';
28   assert_equals(document.getAnimations().length, 2,
29                 'getAnimations returns two running CSS Transitions');
30
31   // Remove both
32   div.style.transitionProperty = 'none';
33   assert_equals(document.getAnimations().length, 0,
34                 'getAnimations returns no running CSS Transitions');
35 }, 'getAnimations for CSS Transitions');
36
37 test(function(t) {
38   addStyle(t, { '.init::after': 'content: ""; width: 0px; ' +
39                                 'transition: all 100s;',
40                 '.init::before': 'content: ""; width: 0px; ' +
41                                  'transition: all 10s;',
42                 '.change::after': 'width: 100px;',
43                 '.change::before': 'width: 100px;' });
44   // create two divs with these arrangement:
45   //       parent
46   //     ::before,
47   //     ::after
48   //        |
49   //       child
50   var parent = addDiv(t);
51   var child = addDiv(t);
52   parent.appendChild(child);
53
54   parent.style.left = '0px';
55   parent.style.transition = 'left 10s';
56   parent.classList.add('init');
57   child.style.left = '0px';
58   child.style.transition = 'left 10s';
59   flushComputedStyle(parent);
60
61   parent.style.left = '100px';
62   parent.classList.add('change');
63   child.style.left = '100px';
64
65   var anims = document.getAnimations();
66   assert_equals(anims.length, 4,
67                 'CSS transition on both pseudo-elements and elements ' +
68                 'are returned');
69   assert_equals(anims[0].effect.target, parent,
70                 'The animation targeting the parent element comes first');
71   assert_equals(anims[1].effect.target.type, '::before',
72                 'The animation targeting the ::before element comes second');
73   assert_equals(anims[2].effect.target.type, '::after',
74                 'The animation targeting the ::after element comes third');
75   assert_equals(anims[3].effect.target, child,
76                 'The animation targeting the child element comes last');
77 }, 'CSS Transitions targetting (pseudo-)elements should have correct order ' +
78    'after sorting');
79
80 async_test(function(t) {
81   var div = addDiv(t, { style: 'left: 0px; transition: all 50ms' });
82   flushComputedStyle(div);
83
84   div.style.left = '100px';
85   var animations = div.getAnimations();
86   assert_equals(animations.length, 1, 'Got transition');
87   animations[0].finished.then(t.step_func(function() {
88     assert_equals(document.getAnimations().length, 0,
89                   'No animations returned');
90     t.done();
91   }));
92 }, 'Transitions are not returned after they have finished');
93
94 </script>
95 </body>