File: file_transition_finish_on_compositor.html

package info (click to toggle)
firefox 143.0.3-1
  • links: PTS, VCS
  • area: main
  • in suites: sid
  • size: 4,617,328 kB
  • sloc: cpp: 7,478,492; javascript: 6,417,157; ansic: 3,720,058; python: 1,396,372; xml: 627,523; asm: 438,677; java: 186,156; sh: 63,477; makefile: 19,171; objc: 13,059; perl: 12,983; yacc: 4,583; cs: 3,846; pascal: 3,405; lex: 1,720; ruby: 1,003; exp: 762; php: 436; lisp: 258; awk: 247; sql: 66; sed: 53; csh: 10
file content (67 lines) | stat: -rw-r--r-- 2,030 bytes parent folder | download | duplicates (17)
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
<!doctype html>
<meta charset=utf-8>
<script src="../testcommon.js"></script>
<script src="/tests/SimpleTest/paint_listener.js"></script>
<style>
div {
  /* Element needs geometry to be eligible for layerization */
  width: 100px;
  height: 100px;
  background-color: white;
}
</style>
<body>
<script>
'use strict';

function waitForPaints() {
  return new Promise(function(resolve, reject) {
    waitForAllPaintsFlushed(resolve);
  });
}

promise_test(async t => {
  // This test only applies to compositor animations
  if (!isOMTAEnabled()) {
    return;
  }

  var div = addDiv(t, { style: 'transition: transform 50ms; ' +
                               'transform: translateX(0px)' });
  getComputedStyle(div).transform;

  div.style.transform = 'translateX(100px)';

  var timeBeforeStart = window.performance.now();
  await waitForPaints();

  // If it took over 50ms to paint the transition, we have no luck
  // to test it.  This situation will happen if GC runs while waiting for the
  // paint.
  if (window.performance.now() - timeBeforeStart >= 50) {
    return;
  }

  var transform  =
    SpecialPowers.DOMWindowUtils.getOMTAStyle(div, 'transform');
  assert_not_equals(transform, '',
                    'The transition style is applied on the compositor');

  // Generate artificial busyness on the main thread for 100ms.
  var timeAtStart = window.performance.now();
  while (window.performance.now() - timeAtStart < 100) {}

  // Now the transition on the compositor should finish but stay at the final
  // position because there was no chance to pull the transition back from
  // the compositor.
  transform  =
    SpecialPowers.DOMWindowUtils.getOMTAStyle(div, 'transform');
  assert_equals(transform, 'matrix(1, 0, 0, 1, 100, 0)',
                'The final transition style is still applied on the ' +
                'compositor');
}, 'Transition on the compositor keeps the final style while the main thread ' +
   'is busy even if the transition finished on the compositor');

done();
</script>
</body>