diff options
Diffstat (limited to 'testing/web-platform/tests/svg/animations/first-interval-in-the-past-contribute.html')
-rw-r--r-- | testing/web-platform/tests/svg/animations/first-interval-in-the-past-contribute.html | 30 |
1 files changed, 30 insertions, 0 deletions
diff --git a/testing/web-platform/tests/svg/animations/first-interval-in-the-past-contribute.html b/testing/web-platform/tests/svg/animations/first-interval-in-the-past-contribute.html new file mode 100644 index 0000000000..a4c7383b8e --- /dev/null +++ b/testing/web-platform/tests/svg/animations/first-interval-in-the-past-contribute.html @@ -0,0 +1,30 @@ +<!DOCTYPE html> +<title>Inserting animation elements that end before current presentation time</title> +<link rel="help" href="https://www.w3.org/TR/2001/REC-smil-animation-20010904/#Timing-BeginEnd-LC-Start"> +<script src="/resources/testharness.js"></script> +<script src="/resources/testharnessreport.js"></script> +<script src="/common/rendering-utils.js"></script> +<svg> + <rect width="100" height="100" fill="orange"> + <animate attributeName="fill" values="blue;red" dur="10ms" fill="freeze"/> + </rect> +</svg> +<script> + promise_test(t => { + const rect = document.querySelector('rect'); + const endWatcher = new Promise(resolve => { + document.querySelector('animate').onend = resolve; + }); + return endWatcher + .then(() => { + const oldAnimation = rect.firstElementChild; + const newAnimation = oldAnimation.cloneNode(false); + newAnimation.setAttribute('values', 'red;green'); + rect.replaceChild(newAnimation, oldAnimation); + return waitForAtLeastOneFrame(); + }) + .then(() => { + assert_equals(getComputedStyle(rect).fill, 'rgb(0, 128, 0)', 'new animation applies'); + }); + }); +</script> |