File: window-resize-aborts-transition.html

package info (click to toggle)
firefox-esr 115.15.0esr-1~deb12u1
  • links: PTS, VCS
  • area: main
  • in suites: bookworm
  • size: 3,659,216 kB
  • sloc: cpp: 6,676,686; javascript: 5,690,965; ansic: 3,328,546; python: 1,120,594; asm: 397,163; xml: 180,531; java: 178,838; sh: 68,930; makefile: 20,999; perl: 12,595; objc: 12,561; yacc: 4,583; cs: 3,846; pascal: 2,840; lex: 1,720; ruby: 1,079; exp: 762; php: 436; lisp: 258; awk: 247; sql: 66; sed: 54; csh: 10
file content (76 lines) | stat: -rw-r--r-- 2,453 bytes parent folder | download | duplicates (4)
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
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
<!DOCTYPE html>
<html>
<head>
<title>View transitions: Resizing viewport skips the transition</title>
<link rel="help" href="https://github.com/WICG/view-transitions">
<link rel="author" href="mailto:bokan@chromium.org">

<script src="/common/rendering-utils.js"></script>
<script src="/resources/testharness.js"></script>
<script src="/resources/testharnessreport.js"></script>
<script src="/resources/testdriver.js"></script>
<script src="/resources/testdriver-vendor.js"></script>

<script>
function waitForAtLeastOneFrame(win) {
  return new Promise(resolve => {
    win.requestAnimationFrame(() => {
      win.requestAnimationFrame(() => {
        resolve();
      });
    });
  });
}

let popupWin;
promise_test(async t => {
  assert_implements(document.startViewTransition, "Missing document.startViewTransition");

  return new Promise(async (resolve, reject) => {
    await waitForAtLeastOneFrame(window);

    // Open a popup window that we'll use to start a transition
    await test_driver.bless('Open a popup in a new window', () => {
        popupWin = window.open('about:blank', 'popup', 'width=300,height=300');
    });
    let popupDoc = popupWin.document;
    popupDoc.documentElement.innerHTML = `
      <style>
        html {background-color: red;}
        html.new {background-color: limegreen;}

        /* Set a no-op animation to show the old snapshot indefinitely. */
        html::view-transition-group(*) {animation-duration: 10s;}
        html::view-transition-new(*) {animation: unset;opacity: 0;}
        html::view-transition-old(*) {animation-duration: 10s;opacity: 1;}
      </style>`;

    // Start a transition inside the popup.
    let transition = popupDoc.startViewTransition(() => {
      popupDoc.documentElement.classList.add('new');
    });

    let finishResolved = false;
    transition.finished.then(() => {
      finishResolved = true;
    });

    // Wait for the transition to start animating.
    await transition.ready;
    await waitForAtLeastOneFrame(popupWin);
    await waitForAtLeastOneFrame(popupWin);

    // Resize the popup window.
    popupWin.resizeTo(popupWin.innerWidth/2, popupWin.innerHeight/2);

    await waitForAtLeastOneFrame(popupWin);

    // `finish` should have resolved as resizing the transition after capture
    // should cause it to skip.
    assert_true(finishResolved, "Transition must be finished by the window resize");
    resolve();
  });
});
</script>
</head>
</html>