summaryrefslogtreecommitdiffstats
path: root/testing/web-platform/tests/svg/animations/seeking-events-2.html
diff options
context:
space:
mode:
Diffstat (limited to 'testing/web-platform/tests/svg/animations/seeking-events-2.html')
-rw-r--r--testing/web-platform/tests/svg/animations/seeking-events-2.html28
1 files changed, 28 insertions, 0 deletions
diff --git a/testing/web-platform/tests/svg/animations/seeking-events-2.html b/testing/web-platform/tests/svg/animations/seeking-events-2.html
new file mode 100644
index 0000000000..4bfe05b84d
--- /dev/null
+++ b/testing/web-platform/tests/svg/animations/seeking-events-2.html
@@ -0,0 +1,28 @@
+<!DOCTYPE html>
+<title>Seeking backwards dispatches 'endEvent' if the element is not active at the seeked-to time</title>
+<script src="/resources/testharness.js"></script>
+<script src="/resources/testharnessreport.js"></script>
+<svg>
+ <rect width="50" height="100" fill="red">
+ <set id="anim1" attributeName="fill" to="green" begin="5s" dur="1s" repeatCount="2" fill="freeze"/>
+ </rect>
+ <rect width="50" height="100" x="50" fill="green">
+ <set id="anim2" attributeName="fill" to="red" begin="9s" dur="11s"/>
+ </rect>
+</svg>
+<script>
+ const SMIL_EVENTS = ['beginEvent', 'repeatEvent', 'endEvent'];
+
+ promise_test(function(t) {
+ let svg = document.querySelector('svg');
+ svg.pauseAnimations();
+ svg.setCurrentTime(10);
+ let anim1_watcher = new EventWatcher(t, document.getElementById('anim1'), SMIL_EVENTS);
+ let anim2_watcher = new EventWatcher(t, document.getElementById('anim2'), SMIL_EVENTS);
+ return anim2_watcher.wait_for('beginEvent').then(() => {
+ svg.setCurrentTime(5.5);
+ return Promise.all([anim1_watcher.wait_for('beginEvent'),
+ anim2_watcher.wait_for('endEvent')]);
+ });
+ });
+</script>