parse-input-arguments-007.https.html (1140B)
1 <!DOCTYPE html> 2 <html class="reftest-wait"> 3 <link rel="help" href="https://drafts.css-houdini.org/css-paint-api/"> 4 <link rel="match" href="parse-input-arguments-ref.html"> 5 <style> 6 .container { 7 width: 100px; 8 height: 100px; 9 } 10 11 #canvas-geometry { 12 background-image: paint(geometry); 13 } 14 </style> 15 <script src="/common/reftest-wait.js"></script> 16 <script src="/common/worklet-reftest.js"></script> 17 <body> 18 <div id="canvas-geometry" class="container"></div> 19 20 <script id="code" type="text/worklet"> 21 var testsPassed = false; 22 try { 23 registerPaint('foo3', class { 24 static get inputProperties() { 25 throw Error('failed!'); 26 } 27 }); 28 } catch(ex) { 29 if (ex.name == 'Error' && ex.message == 'failed!') 30 testsPassed = true; 31 } 32 33 registerPaint('geometry', class { 34 paint(ctx, geom) { 35 if (testsPassed) 36 ctx.fillStyle = 'green'; 37 else 38 ctx.fillStyle = 'red'; 39 ctx.fillRect(0, 0, geom.width, geom.height); 40 } 41 }); 42 </script> 43 44 <script> 45 importWorkletAndTerminateTestAfterAsyncPaint(CSS.paintWorklet, document.getElementById('code').textContent); 46 </script> 47 </body> 48 </html>