summaryrefslogtreecommitdiffstats
path: root/testing/web-platform/tests/svg/animations/repeat-iteration-event-005.svg
blob: 63ba7fbcd9f9d3760d7c4380e3863de516b09d2f (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
<svg xmlns="http://www.w3.org/2000/svg">
  <title>No repeat iteration at interval end</title>
  <script xmlns="http://www.w3.org/1999/xhtml" src="/resources/testharness.js"/>
  <script xmlns="http://www.w3.org/1999/xhtml" src="/resources/testharnessreport.js"/>
  <rect width="100" height="100" fill="green">
    <animate id="anim" attributeName="visibility" to="visible" begin="0s" dur="2s" repeatCount="4"/>
    <set attributeName="width" to="0" begin="anim.repeat(4)"/>
  </rect>
  <script>
  function waitForFrame() {
    return new Promise(resolve => {
      window.requestAnimationFrame(resolve);
    });
  }

  promise_test(t => {
    document.documentElement.setCurrentTime(7.995);
    let set = document.querySelector("set");
    new EventWatcher(t, set, 'beginEvent');
    let anim = document.getElementById("anim");
    let animWatcher = new EventWatcher(t, anim, 'endEvent');
    return animWatcher.wait_for('endEvent').then(() => {
      return waitForFrame();
    }).then(() => {
      assert_equals(set.parentNode.getBBox().width, 100);
    });
  });
  </script>
</svg>