tor-browser

The Tor Browser
git clone https://git.dasho.dev/tor-browser.git
Log | Files | Refs | README | LICENSE

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>