offset-path-parsing-valid.html (5853B)
1 <!DOCTYPE html> 2 <html> 3 <head> 4 <meta charset="utf-8"> 5 <title>Motion Path Module Level 1: parsing offset-path with valid values</title> 6 <link rel="author" title="Eric Willigers" href="mailto:ericwilligers@chromium.org"> 7 <link rel="help" href="https://drafts.fxtf.org/motion-1/#offset-path-property"> 8 <meta name="assert" content="offset-path supports the full grammar from the spec."> 9 <script src="/resources/testharness.js"></script> 10 <script src="/resources/testharnessreport.js"></script> 11 <script src="/css/support/parsing-testcommon.js"></script> 12 </head> 13 <body> 14 <script> 15 test_valid_value("offset-path", "none"); 16 17 test_valid_value("offset-path", "ray(0deg)"); 18 test_valid_value("offset-path", "ray(0rad closest-side)", "ray(0rad)"); 19 test_valid_value("offset-path", "ray(0.25turn closest-corner contain)"); 20 test_valid_value("offset-path", "ray(200grad farthest-side)"); 21 test_valid_value("offset-path", "ray(270deg farthest-corner contain)"); 22 test_valid_value("offset-path", "ray(-720deg sides)"); 23 test_valid_value("offset-path", "ray(calc(180deg - 45deg) farthest-side)", "ray(calc(135deg) farthest-side)"); 24 test_valid_value("offset-path", "ray(0deg at 100px 100px)"); 25 test_valid_value("offset-path", "ray(0deg sides at center center)"); 26 test_valid_value("offset-path", "ray(0deg at center center sides)", "ray(0deg sides at center center)"); 27 test_valid_value("offset-path", "ray(0deg at center center contain)", "ray(0deg contain at center center)"); 28 test_valid_value("offset-path", "ray(at 10px 10px 0deg contain)", "ray(0deg contain at 10px 10px)"); 29 30 test_valid_value("offset-path", 'path("m 20 0 h -100")'); 31 test_valid_value("offset-path", 'path("M 0 0 L 100 100 M 100 200 L 200 200 Z L 300 300 Z")'); 32 test_valid_value("offset-path", 'path("m 10 20 q 30 60 40 50 q 100 70 90 80")'); 33 test_valid_value("offset-path", 'path("M 0 0 L 100 100 m 0 100 l 100 0 Z l 160 20 Z")'); 34 test_valid_value("offset-path", 'path("m 10 20 l 20 30 Z l 50 60 Z m 70 80 l 90 60 Z t 70 120")'); 35 test_valid_value("offset-path", 'path("m 10 170 h 90 v 30 m 0 0 s 1 2 3 4 z c 9 8 7 6 5 4")', 'path("m 10 170 h 90 v 30 m 0 0 s 1 2 3 4 Z c 9 8 7 6 5 4")'); 36 test_valid_value("offset-path", 'path("m 10 20 a 10 20 30 1 0 40 50 a 110 120 30 1 1 140 50")'); 37 test_valid_value("offset-path", 38 'path("m 10 20 l 20 30 Z l 50 60 Z m 70 80 l 90 60 Z t 70 120")', 39 'path("m 10 20 l 20 30 Z l 50 60 Z m 70 80 l 90 60 Z t 70 120")' 40 ); 41 test_valid_value("offset-path", 42 'path("m 10.0 170.0 h 90.00 v 30.00 m 0 0 s 1 2 3 4 z c 9 8 7 6 5 4")', 43 'path("m 10 170 h 90 v 30 m 0 0 s 1 2 3 4 Z c 9 8 7 6 5 4")' 44 ); 45 test_valid_value("offset-path", 46 ' path( "m 10 20 a 10 20 30 1 0 40 50 a 110 120 30 1 1 140 50" ) ', 47 'path("m 10 20 a 10 20 30 1 0 40 50 a 110 120 30 1 1 140 50")' 48 ); 49 50 test_valid_value("offset-path", 'url("http://www.example.com/index.html#polyline1")'); 51 52 // https://drafts.csswg.org/css-shapes-1/#basic-shape-serialization 53 test_valid_value("offset-path", "inset(100%)"); 54 test_valid_value("offset-path", "inset(0 1px)", "inset(0px 1px)"); 55 test_valid_value("offset-path", "inset(0px 1px 2%)"); 56 test_valid_value("offset-path", "inset(0px 1px 2% 3em)"); 57 test_valid_value("offset-path", "inset(0px round 100%)"); 58 test_valid_value("offset-path", "inset(0px round 0 1px)", "inset(0px round 0px 1px)"); 59 test_valid_value("offset-path", "inset(0px round 0px 1px 2%)"); 60 test_valid_value("offset-path", "inset(0px round 0px 1px 2% 3em)"); 61 test_valid_value("offset-path", "inset(10px round 20% / 0px 1px 2% 3em)"); 62 63 test_valid_value("offset-path", "circle()"); 64 test_valid_value("offset-path", "circle(100px)"); 65 test_valid_value("offset-path", "circle(closest-side)", "circle()"); 66 test_valid_value("offset-path", "circle(at 50% 50%)"); 67 test_valid_value("offset-path", "circle(100px at 50% 50%)"); 68 test_valid_value("offset-path", "circle(farthest-side at 0% 0%)"); 69 70 test_valid_value("offset-path", "ellipse()"); 71 test_valid_value("offset-path", "ellipse(1px closest-side)"); 72 test_valid_value("offset-path", "ellipse(at 50% 50%)"); 73 test_valid_value("offset-path", "ellipse(closest-side closest-side at 10% 20%)", "ellipse(at 10% 20%)"); 74 test_valid_value("offset-path", "ellipse(farthest-side 4% at 0% 100%)"); 75 76 test_valid_value("offset-path", "polygon(1% 2%)"); 77 test_valid_value("offset-path", "polygon(1px 2px, 3em 4em)"); 78 79 test_valid_value("offset-path", "xywh(0 1% 2px 3em)", "xywh(0px 1% 2px 3em)"); 80 test_valid_value("offset-path", "xywh(0px 1% 2px 3em round 0)", "xywh(0px 1% 2px 3em)"); 81 test_valid_value("offset-path", "xywh(0px 1% 2px 3em round 0 1px)", "xywh(0px 1% 2px 3em round 0px 1px)"); 82 test_valid_value("offset-path", "xywh(0px 1% 2px 3em round 0px 1px 2%)"); 83 test_valid_value("offset-path", "xywh(0px 1% 2px 3em round 0px 1px 2% 3em)"); 84 85 test_valid_value("offset-path", "rect(0 100% 200px 4em)", "rect(0px 100% 200px 4em)"); 86 test_valid_value("offset-path", "rect(auto auto auto auto)"); 87 test_valid_value("offset-path", "rect(0px 100% auto 4em round 0)", "rect(0px 100% auto 4em)"); 88 test_valid_value("offset-path", "rect(0px 100% auto 4em round 0 1px)", "rect(0px 100% auto 4em round 0px 1px)"); 89 test_valid_value("offset-path", "rect(0px 100% auto 4em round 0px 1px 2%)"); 90 test_valid_value("offset-path", "rect(0px 100% auto 4em round 0px 1px 2% 3em)"); 91 92 test_valid_value("offset-path", "content-box"); 93 test_valid_value("offset-path", "border-box"); 94 test_valid_value("offset-path", "view-box"); 95 96 test_valid_value("offset-path", "inset(10% 20% 30% 40%) border-box", "inset(10% 20% 30% 40%)"); 97 test_valid_value("offset-path", "fill-box ellipse(50% 60%)", "ellipse(50% 60%) fill-box"); 98 test_valid_value("offset-path", "content-box ellipse(50% 60% at 50% 50%)", "ellipse(50% 60% at 50% 50%) content-box"); 99 test_valid_value("offset-path", "ray(0deg) stroke-box"); 100 test_valid_value("offset-path", 'path("m 20 0 h -100") view-box'); 101 </script> 102 </body> 103 </html>