| OLD | NEW |
| 1 <!DOCTYPE html> | 1 <!DOCTYPE html> |
| 2 <div class="target">-webkit-transform 10ms</div><br> | 2 <meta charset="utf-8"> |
| 3 <div class="target">transform 10ms</div><br> | 3 <script src="../resources/testharness.js"></script> |
| 4 <div class="target">transform 10ms, -webkit-transform 10ms</div><br> | 4 <script src="../resources/testharnessreport.js"></script> |
| 5 <div class="target">-webkit-transform 10ms, transform 10ms</div><br> | 5 <div id="container"></div> |
| 6 <div class="target">all 10ms</div><br> | |
| 7 <div class="target">all 10ms, -webkit-transform 10ms</div><br> | |
| 8 <div class="target">-webkit-transform 10ms, all 10ms</div> | |
| 9 <script> | 6 <script> |
| 10 if (window.testRunner) { | 7 'use strict'; |
| 11 testRunner.dumpAsText(); | |
| 12 testRunner.waitUntilDone(); | |
| 13 } | |
| 14 | 8 |
| 15 document.addEventListener('transitionend', function(e) { | 9 var transitionValues = [ |
| 16 var result = document.createElement('div'); | 10 '-webkit-transform 10ms', |
| 17 result.textContent = 'fired transitionend with propertyName: ' + e.propertyNam
e; | 11 'transform 10ms', |
| 18 e.target.appendChild(result); | 12 'transform 10ms, -webkit-transform 10ms', |
| 19 if (window.testRunner) { | 13 '-webkit-transform 10ms, transform 10ms', |
| 20 // All events should be fired by next frame. | 14 'all 10ms', |
| 21 requestAnimationFrame(function() { | 15 'all 10ms, -webkit-transform 10ms', |
| 22 testRunner.notifyDone(); | 16 '-webkit-transform 10ms, all 10ms' |
| 17 ]; |
| 18 |
| 19 async_test(t => { |
| 20 var remaining = transitionValues.length; |
| 21 for (let i = 0; i < transitionValues.length; i++) { |
| 22 const element = document.createElement('div'); |
| 23 container.appendChild(element); |
| 24 |
| 25 element.addEventListener('transitionend', e => { |
| 26 t.step(() => { |
| 27 assert_equals(e.target, element); |
| 28 assert_equals(e.type, 'transitionend'); |
| 29 assert_equals(e.propertyName, 'transform'); |
| 30 assert_greater_than(remaining, 0); |
| 31 |
| 32 remaining -= 1; |
| 33 if (!remaining) { |
| 34 // Delay provides opportunity to detect excess events. |
| 35 setTimeout(() => { |
| 36 t.done(); |
| 37 }, 50); |
| 38 } |
| 39 }); |
| 40 }); |
| 41 |
| 42 requestAnimationFrame(() => { |
| 43 element.offsetTop; |
| 44 element.style.transition = transitionValues[i]; |
| 45 element.style.webkitTransform = 'rotate(360deg)'; |
| 46 element.style.transform = 'rotate(360deg)'; |
| 23 }); | 47 }); |
| 24 } | 48 } |
| 25 }); | 49 }, 'Transition on the prefixed and/or unprefixed transform property causes a sin
gle transitionend event for the unprefixed transform property.'); |
| 26 | |
| 27 onload = function() { | |
| 28 var targets = document.querySelectorAll('.target'); | |
| 29 for (var i = 0; i < targets.length; i++) { | |
| 30 targets[i].offsetTop; | |
| 31 targets[i].style.transition = targets[i].textContent; | |
| 32 targets[i].style.webkitTransform = 'rotate(360deg)'; | |
| 33 targets[i].style.transform = 'rotate(360deg)'; | |
| 34 } | |
| 35 }; | |
| 36 </script> | 50 </script> |
| OLD | NEW |