Source code
Revision control
Copy as Markdown
Other Tools
Test Info:
- This WPT test may be referenced by the following Test IDs:
- /css/css-animations/display-none-to-display-block-dont-cancel.tentative.html - WPT Dashboard Interop Dashboard
<!DOCTYPE html>
<script src="/resources/testharness.js"></script>
<script src="/resources/testharnessreport.js"></script>
<script src="/css/css-animations/support/testcommon.js"></script>
<div id="target">hello</div>
<style>
@keyframes display-animation {
0% { display: none; }
100% { display: block; }
}
#target {
display: none;
}
#target.animate {
animation: display-animation 1s;
display: block;
}
</style>
<script>
promise_test(async (t) => {
t.add_cleanup(() => target.classList.remove('animate'));
let numAnimationstartFired = 0;
target.addEventListener('animationstart', () => numAnimationstartFired++);
assert_equals(getComputedStyle(target).display, 'none',
'The display should be none before the animation.');
await waitForAnimationFrames(1);
target.classList.add('animate');
await waitForAnimationFrames(2);
assert_equals(getComputedStyle(target).display, 'block',
'The display should be block during the animation.');
assert_equals(numAnimationstartFired, 1,
'Only one animation should start.');
}, 'display:none animating to display:block should be block for the whole animation.');
</script>