File: one-custom-property-animation.https.html

package info (click to toggle)
thunderbird 1%3A143.0.1-1
  • links: PTS, VCS
  • area: main
  • in suites: experimental
  • size: 4,703,968 kB
  • sloc: cpp: 7,770,492; javascript: 5,943,842; ansic: 3,918,754; python: 1,418,263; xml: 653,354; asm: 474,045; java: 183,079; sh: 111,238; makefile: 20,410; perl: 14,359; objc: 13,059; yacc: 4,583; pascal: 3,405; lex: 1,720; ruby: 999; exp: 762; sql: 715; awk: 580; php: 436; lisp: 430; sed: 69; csh: 10
file content (98 lines) | stat: -rw-r--r-- 2,830 bytes parent folder | download | duplicates (8)
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
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
<!DOCTYPE html>
<html class="reftest-wait">
<link rel="help" href="https://drafts.css-houdini.org/css-paint-api/">
<link rel="match" href="one-custom-property-animation-ref.html">
<style>
.container {
  width: 100px;
  height: 100px;
}
@keyframes expand {
  0% { --foo: 0; }
  100% { --foo: 100; }
}
.animate {
  background-image: paint(geometry);
  /* Use a long animation that start at 50% progress where the slope of the
     selected timing function is zero. By setting up the animation in this way,
     we accommodate lengthy delays in running the test without a potential drift
     in the animated property value. This is important for avoiding flakes,
     especially on debug builds. The screenshots are taken as soon as the
     animation is ready, thus the long animation duration has no bearing on
     the actual duration of the test. */
  animation: expand 1000000s cubic-bezier(0,1,1,0) -500000s;
}

#canvas-geometry {
  background-color: blue;
}
</style>

<script src="/common/reftest-wait.js"></script>
<script src="/web-animations/testcommon.js"></script>

<body>
<div id="canvas-geometry" class="container"></div>
<div id="log"></div>

<script id="code" type="text/worklet">
registerPaint('geometry', class {
  static get inputProperties() { return ['--foo']; }
  paint(ctx, geom, properties) {
    let fooValue = parseFloat(properties.get('--foo').toString());
    ctx.fillStyle = 'green';
    ctx.fillRect(0, 0, fooValue, fooValue);
  }
});
</script>

<script>
CSS.registerProperty({
  name: '--foo',
  syntax: '<number>',
  initialValue: '0',
  inherits: false
});

function logAssert(condition, message) {
  if(!condition) {
    document.getElementById("log").innerHTML = "<p>" + message + "</p>";
  }
}

window.onload = async() => {
  await waitForCompositorReady();

  const blob = new Blob([document.getElementById('code').textContent],
                         {type: 'text/javascript'});
  // Load the module and verify it was loaded.
  try {
    await CSS.paintWorklet.addModule(URL.createObjectURL(blob));
  } catch (error) {
    logAssert(false, 'The module was not loaded: ' + error.message)
  }

  // Check that custom property is registered.
  const style = getComputedStyle(document.documentElement);
  logAssert(style.getPropertyValue('--foo'),
            'Custom property is not registered');

  // Trigger CSS-animation.
  document.getElementById('canvas-geometry').classList.add('animate');
  const animations = document.getAnimations();
  // Verify we have an animation.
  logAssert(animations.length == 1, 'Animation was not added');

  // Force failure as a result of image mismatch instead of Timeout if
  // animation is not created
  if(animations.length == 1){
    await animations[0].ready;
  }
  await waitForAnimationFrames(3);
  takeScreenshot();
};


</script>
</body>
</html>