tor-browser

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

presentational-hints-rollback.html (5228B)


      1 <!DOCTYPE html>
      2 <meta charset="utf-8">
      3 <title>CSS Cascade: rolling back the cascade with presentation hints</title>
      4 <link rel="author" title="Oriol Brufau" href="mailto:obrufau@igalia.com">
      5 <link rel="help" href="https://www.w3.org/TR/css-cascade-5/#preshint">
      6 <link rel="help" href="https://www.w3.org/TR/css-cascade-5/#default">
      7 <link rel="help" href="https://www.w3.org/TR/css-cascade-5/#revert-layer">
      8 <link rel="help" href="https://html.spec.whatwg.org/multipage/embedded-content-other.html#dimension-attributes">
      9 <meta name="assert" content="Checks that 'revert' considers presentational hints as part of the author origin,
     10    and 'revert-layer' considers them an independent origin between the user origin and the author origin.">
     11 
     12 <style>
     13 @layer {
     14  .revert-1 {
     15    width: revert;
     16    height: revert;
     17  }
     18  .revert-layer-1 {
     19    width: revert-layer;
     20    height: revert-layer;
     21  }
     22 }
     23 
     24 .revert-2 {
     25  width: revert;
     26  height: revert;
     27 }
     28 .revert-layer-2 {
     29  width: revert-layer;
     30  height: revert-layer;
     31 }
     32 
     33 .revert-3 {
     34  animation: revert-3 paused 2s -1s;
     35 }
     36 .revert-layer-3 {
     37  animation: revert-layer-3 paused 2s -1s;
     38 }
     39 @keyframes revert-3 {
     40  from, to {
     41    width: revert;
     42    height: revert;
     43  }
     44 }
     45 @keyframes revert-layer-3 {
     46  from, to {
     47    width: revert-layer;
     48    height: revert-layer;
     49  }
     50 }
     51 </style>
     52 
     53 <div id="log"></div>
     54 
     55 <div id="tests">
     56  <!-- 'revert' considers presentational hints as part of the author origin, so it rolls back to user origin.
     57        The images should then get an 'auto' size, which will use the natural size of the resource. -->
     58  <img class="revert-1" src="/css/support/60x60-green.png"
     59      width="44" data-expected-client-width="60"
     60      height="33" data-expected-client-height="60">
     61  <img class="revert-2" src="/css/support/60x60-green.png"
     62      width="44" data-expected-client-width="60"
     63      height="33" data-expected-client-height="60">
     64  <img class="revert-3" src="/css/support/60x60-green.png"
     65       width="44" data-expected-client-width="60"
     66       height="33" data-expected-client-height="60">
     67  <img style="width: revert; height: revert" src="/css/support/60x60-green.png"
     68       width="44" data-expected-client-width="60"
     69       height="33" data-expected-client-height="60">
     70 
     71  <!-- 'revert-layer' considers presentational hints as an independent origin, so it rolls back to them.
     72        The images should then get size specified in the attributes. -->
     73  <img class="revert-layer-1" src="/css/support/60x60-green.png"
     74      width="44" data-expected-client-width="44"
     75      height="33" data-expected-client-height="33">
     76  <img class="revert-layer-2" src="/css/support/60x60-green.png"
     77      width="44" data-expected-client-width="44"
     78      height="33" data-expected-client-height="33">
     79  <img class="revert-layer-3" src="/css/support/60x60-green.png"
     80      width="44" data-expected-client-width="44"
     81      height="33" data-expected-client-height="33">
     82  <img style="width: revert-layer; height: revert-layer" src="/css/support/60x60-green.png"
     83       width="44" data-expected-client-width="44"
     84       height="33" data-expected-client-height="33">
     85 
     86  <!-- 'revert' considers presentational hints as part of the author origin, so it rolls back to user origin.
     87        The iframes should then get an 'auto' size, which will default to 300x150. -->
     88  <iframe class="revert-1" src="/css/support/60x60-green.png"
     89      width="44" data-expected-client-width="300"
     90      height="33" data-expected-client-height="150"></iframe>
     91  <iframe class="revert-2" src="/css/support/60x60-green.png"
     92      width="44" data-expected-client-width="300"
     93      height="33" data-expected-client-height="150"></iframe>
     94  <iframe class="revert-3" src="/css/support/60x60-green.png"
     95      width="44" data-expected-client-width="300"
     96      height="33" data-expected-client-height="150"></iframe>
     97  <iframe style="width: revert; height: revert" src="/css/support/60x60-green.png"
     98       width="44" data-expected-client-width="300"
     99       height="33" data-expected-client-height="150"></iframe>
    100 
    101  <!-- 'revert-layer' considers presentational hints as an independent origin, so it rolls back to them.
    102        The iframes should then get size specified in the attributes. -->
    103  <iframe class="revert-layer-1" src="/css/support/60x60-green.png"
    104      width="44" data-expected-client-width="44"
    105      height="33" data-expected-client-height="33"></iframe>
    106  <iframe class="revert-layer-2" src="/css/support/60x60-green.png"
    107      width="44" data-expected-client-width="44"
    108      height="33" data-expected-client-height="33"></iframe>
    109  <iframe class="revert-layer-3" src="/css/support/60x60-green.png"
    110      width="44" data-expected-client-width="44"
    111      height="33" data-expected-client-height="33"></iframe>
    112  <iframe style="width: revert-layer; height: revert-layer" src="/css/support/60x60-green.png"
    113       width="44" data-expected-client-width="44"
    114       height="33" data-expected-client-height="33"></iframe>
    115 </div>
    116 
    117 <script src="/resources/testharness.js"></script>
    118 <script src="/resources/testharnessreport.js"></script>
    119 <script src="/resources/check-layout-th.js"></script>
    120 <script>
    121 addEventListener("load", function() {
    122  checkLayout("#tests > *", false);
    123  done();
    124 }, {once: true});
    125 </script>