summaryrefslogtreecommitdiffstats
path: root/testing/web-platform/tests/svg/animations/cyclic-syncbase-events.html
diff options
context:
space:
mode:
Diffstat (limited to 'testing/web-platform/tests/svg/animations/cyclic-syncbase-events.html')
-rw-r--r--testing/web-platform/tests/svg/animations/cyclic-syncbase-events.html30
1 files changed, 30 insertions, 0 deletions
diff --git a/testing/web-platform/tests/svg/animations/cyclic-syncbase-events.html b/testing/web-platform/tests/svg/animations/cyclic-syncbase-events.html
new file mode 100644
index 0000000000..09d5c2e7b8
--- /dev/null
+++ b/testing/web-platform/tests/svg/animations/cyclic-syncbase-events.html
@@ -0,0 +1,30 @@
+<!DOCTYPE html>
+<title>Cyclic syncbase dependency with syncbase trigger - event dispatching</title>
+<script src="/resources/testharness.js"></script>
+<script src="/resources/testharnessreport.js"></script>
+<svg>
+ <rect width="100" height="100" fill="blue">
+ <animate attributeName="fill" from="yellow" to="blue" id="a"
+ begin="c.end; b.begin" dur="10ms"/>
+ </rect>
+ <rect width="100" height="100" x="100" fill="blue">
+ <animate attributeName="fill" from="yellow" to="blue" id="b"
+ begin="c.end; a.begin" dur="10ms"/>
+ </rect>
+ <rect width="100" height="100" x="200" fill="blue">
+ <animate attributeName="fill" from="yellow" to="blue" id="c"
+ begin="0; 15ms" dur="10ms"/>
+ </rect>
+</svg>
+<script>
+ promise_test(function(t) {
+ // Wait for two beginEvent/endEvent pairs on all the timed elements.
+ let promises = ['a', 'b', 'c'].map(function(id) {
+ return new EventWatcher(t, document.getElementById(id),
+ ['beginEvent', 'endEvent'])
+ .wait_for(['beginEvent', 'endEvent',
+ 'beginEvent', 'endEvent']);
+ });
+ return Promise.all(promises);
+ });
+</script>