2d.path.roundrect.nonfinite.html (4977B)
1 <!DOCTYPE html> 2 <!-- DO NOT EDIT! This test has been generated by /html/canvas/tools/gentest.py. --> 3 <meta charset="UTF-8"> 4 <title>OffscreenCanvas test: 2d.path.roundrect.nonfinite</title> 5 <script src="/resources/testharness.js"></script> 6 <script src="/resources/testharnessreport.js"></script> 7 <script src="/html/canvas/resources/canvas-tests.js"></script> 8 9 <h1>2d.path.roundrect.nonfinite</h1> 10 <p class="desc">roundRect() with Infinity/NaN is ignored</p> 11 12 13 <script> 14 var t = async_test("roundRect() with Infinity/NaN is ignored"); 15 var t_pass = t.done.bind(t); 16 var t_fail = t.step_func(function(reason) { 17 throw reason; 18 }); 19 t.step(function() { 20 21 var canvas = new OffscreenCanvas(100, 50); 22 var ctx = canvas.getContext('2d'); 23 24 ctx.fillStyle = '#f00'; 25 ctx.fillRect(0, 0, 100, 50) 26 ctx.moveTo(0, 0); 27 ctx.lineTo(100, 0); 28 ctx.roundRect(Infinity, 50, 1, 1, [0]); 29 ctx.roundRect(-Infinity, 50, 1, 1, [0]); 30 ctx.roundRect(NaN, 50, 1, 1, [0]); 31 ctx.roundRect(0, Infinity, 1, 1, [0]); 32 ctx.roundRect(0, -Infinity, 1, 1, [0]); 33 ctx.roundRect(0, NaN, 1, 1, [0]); 34 ctx.roundRect(0, 50, Infinity, 1, [0]); 35 ctx.roundRect(0, 50, -Infinity, 1, [0]); 36 ctx.roundRect(0, 50, NaN, 1, [0]); 37 ctx.roundRect(0, 50, 1, Infinity, [0]); 38 ctx.roundRect(0, 50, 1, -Infinity, [0]); 39 ctx.roundRect(0, 50, 1, NaN, [0]); 40 ctx.roundRect(0, 50, 1, 1, [Infinity]); 41 ctx.roundRect(0, 50, 1, 1, [-Infinity]); 42 ctx.roundRect(0, 50, 1, 1, [NaN]); 43 ctx.roundRect(0, 50, 1, 1, [Infinity,0]); 44 ctx.roundRect(0, 50, 1, 1, [-Infinity,0]); 45 ctx.roundRect(0, 50, 1, 1, [NaN,0]); 46 ctx.roundRect(0, 50, 1, 1, [0,Infinity]); 47 ctx.roundRect(0, 50, 1, 1, [0,-Infinity]); 48 ctx.roundRect(0, 50, 1, 1, [0,NaN]); 49 ctx.roundRect(0, 50, 1, 1, [Infinity,0,0]); 50 ctx.roundRect(0, 50, 1, 1, [-Infinity,0,0]); 51 ctx.roundRect(0, 50, 1, 1, [NaN,0,0]); 52 ctx.roundRect(0, 50, 1, 1, [0,Infinity,0]); 53 ctx.roundRect(0, 50, 1, 1, [0,-Infinity,0]); 54 ctx.roundRect(0, 50, 1, 1, [0,NaN,0]); 55 ctx.roundRect(0, 50, 1, 1, [0,0,Infinity]); 56 ctx.roundRect(0, 50, 1, 1, [0,0,-Infinity]); 57 ctx.roundRect(0, 50, 1, 1, [0,0,NaN]); 58 ctx.roundRect(0, 50, 1, 1, [Infinity,0,0,0]); 59 ctx.roundRect(0, 50, 1, 1, [-Infinity,0,0,0]); 60 ctx.roundRect(0, 50, 1, 1, [NaN,0,0,0]); 61 ctx.roundRect(0, 50, 1, 1, [0,Infinity,0,0]); 62 ctx.roundRect(0, 50, 1, 1, [0,-Infinity,0,0]); 63 ctx.roundRect(0, 50, 1, 1, [0,NaN,0,0]); 64 ctx.roundRect(0, 50, 1, 1, [0,0,Infinity,0]); 65 ctx.roundRect(0, 50, 1, 1, [0,0,-Infinity,0]); 66 ctx.roundRect(0, 50, 1, 1, [0,0,NaN,0]); 67 ctx.roundRect(0, 50, 1, 1, [0,0,0,Infinity]); 68 ctx.roundRect(0, 50, 1, 1, [0,0,0,-Infinity]); 69 ctx.roundRect(0, 50, 1, 1, [0,0,0,NaN]); 70 ctx.roundRect(Infinity, Infinity, 1, 1, [0]); 71 ctx.roundRect(Infinity, Infinity, Infinity, 1, [0]); 72 ctx.roundRect(Infinity, Infinity, Infinity, Infinity, [0]); 73 ctx.roundRect(Infinity, Infinity, Infinity, Infinity, [Infinity]); 74 ctx.roundRect(Infinity, Infinity, Infinity, 1, [Infinity]); 75 ctx.roundRect(Infinity, Infinity, 1, Infinity, [0]); 76 ctx.roundRect(Infinity, Infinity, 1, Infinity, [Infinity]); 77 ctx.roundRect(Infinity, Infinity, 1, 1, [Infinity]); 78 ctx.roundRect(Infinity, 50, Infinity, 1, [0]); 79 ctx.roundRect(Infinity, 50, Infinity, Infinity, [0]); 80 ctx.roundRect(Infinity, 50, Infinity, Infinity, [Infinity]); 81 ctx.roundRect(Infinity, 50, Infinity, 1, [Infinity]); 82 ctx.roundRect(Infinity, 50, 1, Infinity, [0]); 83 ctx.roundRect(Infinity, 50, 1, Infinity, [Infinity]); 84 ctx.roundRect(Infinity, 50, 1, 1, [Infinity]); 85 ctx.roundRect(0, Infinity, Infinity, 1, [0]); 86 ctx.roundRect(0, Infinity, Infinity, Infinity, [0]); 87 ctx.roundRect(0, Infinity, Infinity, Infinity, [Infinity]); 88 ctx.roundRect(0, Infinity, Infinity, 1, [Infinity]); 89 ctx.roundRect(0, Infinity, 1, Infinity, [0]); 90 ctx.roundRect(0, Infinity, 1, Infinity, [Infinity]); 91 ctx.roundRect(0, Infinity, 1, 1, [Infinity]); 92 ctx.roundRect(0, 50, Infinity, Infinity, [0]); 93 ctx.roundRect(0, 50, Infinity, Infinity, [Infinity]); 94 ctx.roundRect(0, 50, Infinity, 1, [Infinity]); 95 ctx.roundRect(0, 50, 1, Infinity, [Infinity]); 96 ctx.roundRect(0, 0, 100, 100, [new DOMPoint(10, Infinity)]); 97 ctx.roundRect(0, 0, 100, 100, [new DOMPoint(10, -Infinity)]); 98 ctx.roundRect(0, 0, 100, 100, [new DOMPoint(10, NaN)]); 99 ctx.roundRect(0, 0, 100, 100, [new DOMPoint(Infinity, 10)]); 100 ctx.roundRect(0, 0, 100, 100, [new DOMPoint(-Infinity, 10)]); 101 ctx.roundRect(0, 0, 100, 100, [new DOMPoint(NaN, 10)]); 102 ctx.roundRect(0, 0, 100, 100, [{x: 10, y: Infinity}]); 103 ctx.roundRect(0, 0, 100, 100, [{x: 10, y: -Infinity}]); 104 ctx.roundRect(0, 0, 100, 100, [{x: 10, y: NaN}]); 105 ctx.roundRect(0, 0, 100, 100, [{x: Infinity, y: 10}]); 106 ctx.roundRect(0, 0, 100, 100, [{x: -Infinity, y: 10}]); 107 ctx.roundRect(0, 0, 100, 100, [{x: NaN, y: 10}]); 108 ctx.lineTo(100, 50); 109 ctx.lineTo(0, 50); 110 ctx.fillStyle = '#0f0'; 111 ctx.fill(); 112 _assertPixel(canvas, 50,25, 0,255,0,255); 113 _assertPixel(canvas, 90,45, 0,255,0,255); 114 t.done(); 115 116 }); 117 </script>