File: toggle-animated-iframe-visibility.html

package info (click to toggle)
thunderbird 1%3A140.3.1esr-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 4,608,628 kB
  • sloc: cpp: 7,671,698; javascript: 5,901,131; ansic: 3,898,955; python: 1,413,270; xml: 653,997; asm: 462,284; java: 180,948; sh: 113,489; makefile: 20,460; perl: 14,288; objc: 13,059; yacc: 4,583; pascal: 3,352; lex: 1,720; ruby: 1,222; exp: 762; sql: 715; awk: 580; php: 436; lisp: 430; sed: 70; csh: 10
file content (56 lines) | stat: -rw-r--r-- 1,656 bytes parent folder | download | duplicates (7)
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
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
<!DOCTYPE html>
<html class="reftest-wait">
<meta name="assert" content="This should resume the animation after unhiding the iframe.">
<meta name="fuzzy" content="0-25;0-50">
<title>CSS Test (Animations): Unhiding iframe visibility should restart animation. </title>
<link rel="help" href="https://bugs.chromium.org/p/chromium/issues/detail?id=616270">
<link rel="match" href="toggle-animated-iframe-visibility-ref.html">
<script src="/common/reftest-wait.js"></script>

<div id="container"></div>

<div id="log"></div>

<script>
  var container;
  var block;
  var logDiv;

  function verifyVisibility(expected_visibility, message) {
    if (getComputedStyle(block).visibility !== expected_visibility)
      logDiv.innerHTML = `FAIL: ${message}`;
  }

  async function runTest() {
    var animation = block.animate(
    { transform: [ 'rotate(0deg)', 'rotate(180deg)' ] },
    {
      duration: 10000000,
      delay: -5000000,
      easing: 'cubic-bezier(0, 1, 1, 0)'
    });

    await animation.ready;

    container.style.visibility = 'hidden';
    requestAnimationFrame(() => {
      verifyVisibility('hidden', 'style.visibility should be hidden');
      container.style.visibility = 'visible';

      requestAnimationFrame(() => {
        verifyVisibility('visible', 'style.visiblity should be visible');
        takeScreenshot();
      });
    });
  }

  window.onload = function () {
    logDiv = document.getElementById('log');
    container = document.getElementById('container');
    block = document.createElement('iframe');

    container.appendChild(block);
    block.onload = runTest;
    block.src = 'resources/block.html';
  };
</script>