Implement keyword sizes for replaced elements (#34091)

Signed-off-by: Oriol Brufau <obrufau@igalia.com>
This commit is contained in:
Oriol Brufau 2024-11-05 14:46:58 +01:00 committed by GitHub
parent 3289e7d84d
commit ee7b207f96
No known key found for this signature in database
GPG key ID: B5690EEEBB952194
18 changed files with 342 additions and 106 deletions

View file

@ -570980,6 +570980,13 @@
{}
]
],
"keyword-sizes-on-replaced-element.html": [
"e26c1b7d6ac38858fd7a941a690ea01e6005c38c",
[
null,
{}
]
],
"min-max-content-orthogonal-flow-crash-001.html": [
"d2617f8aa2d1c966e394abb1d1617c012ea4648e",
[

View file

@ -1,2 +0,0 @@
[image-min-max-content-intrinsic-size-change-001.html]
expected: FAIL

View file

@ -1,2 +0,0 @@
[image-min-max-content-intrinsic-size-change-002.html]
expected: FAIL

View file

@ -1,2 +0,0 @@
[image-min-max-content-intrinsic-size-change-003.html]
expected: FAIL

View file

@ -1,2 +0,0 @@
[image-min-max-content-intrinsic-size-change-004.html]
expected: FAIL

View file

@ -1,2 +0,0 @@
[image-min-max-content-intrinsic-size-change-005.html]
expected: FAIL

View file

@ -1,2 +0,0 @@
[image-min-max-content-intrinsic-size-change-006.html]
expected: FAIL

View file

@ -1,2 +0,0 @@
[image-min-max-content-intrinsic-size-change-007.html]
expected: FAIL

View file

@ -1,2 +0,0 @@
[image-min-max-content-intrinsic-size-change-008.html]
expected: FAIL

View file

@ -1,2 +0,0 @@
[replaced-max-height-min-content.html]
expected: FAIL

View file

@ -1,2 +0,0 @@
[replaced-max-width-min-content.html]
expected: FAIL

View file

@ -1,2 +0,0 @@
[replaced-min-height-min-content.html]
expected: FAIL

View file

@ -1,2 +0,0 @@
[replaced-min-width-min-content.html]
expected: FAIL

View file

@ -0,0 +1,184 @@
<!DOCTYPE html>
<title>Keyword sizes on replaced element</title>
<link rel="author" title="Oriol Brufau" href="obrufau@igalia.com">
<link rel="help" href="https://drafts.csswg.org/css-sizing-3/#sizing-values">
<link rel="help" href="https://drafts.csswg.org/css-sizing-4/#sizing-values">
<link rel="help" href="https://drafts.csswg.org/css2/#replaced-element">
<link rel="help" href="https://github.com/w3c/csswg-drafts/issues/11006">
<meta assert="The various keyword sizes work as expected on replaced elements.">
<style>
.test {
margin: 5px;
border: 3px solid;
padding: 2px;
width: auto;
height: auto;
}
/* Set the preferred size to small amount, to test that the min size works */
.test.min-width { width: 0px }
.test.min-height { height: 0px }
/* Set the preferred size to big amount, to test that the max size works */
.test.max-width { width: 500px }
.test.max-height { height: 500px }
/* stretch isn't widely supported, fall back to vendor-prefixed alternatives */
.width.stretch { width: -moz-available; width: -webkit-fill-available; width: stretch }
.min-width.stretch { min-width: -moz-available; min-width: -webkit-fill-available; min-width: stretch }
.max-width.stretch { max-width: -moz-available; max-width: -webkit-fill-available; max-width: stretch }
.height.stretch { height: -moz-available; height: -webkit-fill-available; height: stretch }
.min-height.stretch { min-height: -moz-available; min-height: -webkit-fill-available; min-height: stretch }
.max-height.stretch { max-height: -moz-available; max-height: -webkit-fill-available; max-height: stretch }
</style>
<div id="log"></div>
<!-- Intrinsic keywords -->
<div style="width: 200px; height: 100px">
<canvas width="100" height="100" class="test width height" style="width: 50px; height: 50px"
data-expected-width="60" data-expected-height="60"></canvas>
<canvas width="100" height="100" class="test width height" style="width: 50px; height: min-content"
data-expected-width="60" data-expected-height="60"></canvas>
<canvas width="100" height="100" class="test width height" style="width: 50px; height: fit-content"
data-expected-width="60" data-expected-height="60"></canvas>
<canvas width="100" height="100" class="test width height" style="width: 50px; height: max-content"
data-expected-width="60" data-expected-height="60"></canvas>
<canvas width="100" height="100" class="test width height" style="width: min-content; height: 50px"
data-expected-width="60" data-expected-height="60"></canvas>
<canvas width="100" height="100" class="test width height" style="width: min-content; height: min-content"
data-expected-width="110" data-expected-height="110"></canvas>
<canvas width="100" height="100" class="test width height" style="width: min-content; height: fit-content"
data-expected-width="110" data-expected-height="110"></canvas>
<canvas width="100" height="100" class="test width height" style="width: min-content; height: max-content"
data-expected-width="110" data-expected-height="110"></canvas>
<canvas width="100" height="100" class="test width height" style="width: fit-content; height: 50px"
data-expected-width="60" data-expected-height="60"></canvas>
<canvas width="100" height="100" class="test width height" style="width: fit-content; height: min-content"
data-expected-width="110" data-expected-height="110"></canvas>
<canvas width="100" height="100" class="test width height" style="width: fit-content; height: fit-content"
data-expected-width="110" data-expected-height="110"></canvas>
<canvas width="100" height="100" class="test width height" style="width: fit-content; height: max-content"
data-expected-width="110" data-expected-height="110"></canvas>
<canvas width="100" height="100" class="test width height" style="width: max-content; height: 50px"
data-expected-width="60" data-expected-height="60"></canvas>
<canvas width="100" height="100" class="test width height" style="width: max-content; height: min-content"
data-expected-width="110" data-expected-height="110"></canvas>
<canvas width="100" height="100" class="test width height" style="width: max-content; height: fit-content"
data-expected-width="110" data-expected-height="110"></canvas>
<canvas width="100" height="100" class="test width height" style="width: max-content; height: max-content"
data-expected-width="110" data-expected-height="110"></canvas>
<br>
<canvas width="100" height="100" class="test min-width height" style="min-width: 50px; height: 50px"
data-expected-width="60" data-expected-height="60"></canvas>
<canvas width="100" height="100" class="test min-width height" style="min-width: 50px; height: min-content"
data-expected-width="60" data-expected-height="60"></canvas>
<canvas width="100" height="100" class="test min-width height" style="min-width: 50px; height: fit-content"
data-expected-width="60" data-expected-height="60"></canvas>
<canvas width="100" height="100" class="test min-width height" style="min-width: 50px; height: max-content"
data-expected-width="60" data-expected-height="60"></canvas>
<canvas width="100" height="100" class="test min-width height" style="min-width: min-content; height: 50px"
data-expected-width="60" data-expected-height="60"></canvas>
<canvas width="100" height="100" class="test min-width height" style="min-width: min-content; height: min-content"
data-expected-width="110" data-expected-height="110"></canvas>
<canvas width="100" height="100" class="test min-width height" style="min-width: min-content; height: fit-content"
data-expected-width="110" data-expected-height="110"></canvas>
<canvas width="100" height="100" class="test min-width height" style="min-width: min-content; height: max-content"
data-expected-width="110" data-expected-height="110"></canvas>
<canvas width="100" height="100" class="test min-width height" style="min-width: fit-content; height: 50px"
data-expected-width="60" data-expected-height="60"></canvas>
<canvas width="100" height="100" class="test min-width height" style="min-width: fit-content; height: min-content"
data-expected-width="110" data-expected-height="110"></canvas>
<canvas width="100" height="100" class="test min-width height" style="min-width: fit-content; height: fit-content"
data-expected-width="110" data-expected-height="110"></canvas>
<canvas width="100" height="100" class="test min-width height" style="min-width: fit-content; height: max-content"
data-expected-width="110" data-expected-height="110"></canvas>
<canvas width="100" height="100" class="test min-width height" style="min-width: max-content; height: 50px"
data-expected-width="60" data-expected-height="60"></canvas>
<canvas width="100" height="100" class="test min-width height" style="min-width: max-content; height: min-content"
data-expected-width="110" data-expected-height="110"></canvas>
<canvas width="100" height="100" class="test min-width height" style="min-width: max-content; height: fit-content"
data-expected-width="110" data-expected-height="110"></canvas>
<canvas width="100" height="100" class="test min-width height" style="min-width: max-content; height: max-content"
data-expected-width="110" data-expected-height="110"></canvas>
<br>
<canvas width="100" height="100" class="test max-width height" style="max-width: 50px; height: 50px"
data-expected-width="60" data-expected-height="60"></canvas>
<canvas width="100" height="100" class="test max-width height" style="max-width: 50px; height: min-content"
data-expected-width="60" data-expected-height="60"></canvas>
<canvas width="100" height="100" class="test max-width height" style="max-width: 50px; height: fit-content"
data-expected-width="60" data-expected-height="60"></canvas>
<canvas width="100" height="100" class="test max-width height" style="max-width: 50px; height: max-content"
data-expected-width="60" data-expected-height="60"></canvas>
<canvas width="100" height="100" class="test max-width height" style="max-width: min-content; height: 50px"
data-expected-width="60" data-expected-height="60"></canvas>
<canvas width="100" height="100" class="test max-width height" style="max-width: min-content; height: min-content"
data-expected-width="110" data-expected-height="110"></canvas>
<canvas width="100" height="100" class="test max-width height" style="max-width: min-content; height: fit-content"
data-expected-width="110" data-expected-height="110"></canvas>
<canvas width="100" height="100" class="test max-width height" style="max-width: min-content; height: max-content"
data-expected-width="110" data-expected-height="110"></canvas>
<canvas width="100" height="100" class="test max-width height" style="max-width: fit-content; height: 50px"
data-expected-width="60" data-expected-height="60"></canvas>
<canvas width="100" height="100" class="test max-width height" style="max-width: fit-content; height: min-content"
data-expected-width="110" data-expected-height="110"></canvas>
<canvas width="100" height="100" class="test max-width height" style="max-width: fit-content; height: fit-content"
data-expected-width="110" data-expected-height="110"></canvas>
<canvas width="100" height="100" class="test max-width height" style="max-width: fit-content; height: max-content"
data-expected-width="110" data-expected-height="110"></canvas>
<canvas width="100" height="100" class="test max-width height" style="max-width: max-content; height: 50px"
data-expected-width="60" data-expected-height="60"></canvas>
<canvas width="100" height="100" class="test max-width height" style="max-width: max-content; height: min-content"
data-expected-width="110" data-expected-height="110"></canvas>
<canvas width="100" height="100" class="test max-width height" style="max-width: max-content; height: fit-content"
data-expected-width="110" data-expected-height="110"></canvas>
<canvas width="100" height="100" class="test max-width height" style="max-width: max-content; height: max-content"
data-expected-width="110" data-expected-height="110"></canvas>
</div>
<!-- Definite stretch -->
<div style="width: 200px; height: 100px">
<canvas width="100" height="100" class="test width stretch"
data-expected-width="190" data-expected-height="190">X X</canvas>
<canvas width="100" height="100" class="test min-width stretch"
data-expected-width="190" data-expected-height="190">X X</canvas>
<canvas width="100" height="100" class="test max-width stretch"
data-expected-width="190" data-expected-height="190">X X</canvas>
<canvas width="100" height="100" class="test height stretch"
data-expected-width="90" data-expected-height="90">X X</canvas>
<canvas width="100" height="100" class="test min-height stretch"
data-expected-width="90" data-expected-height="90">X X</canvas>
<canvas width="100" height="100" class="test max-height stretch"
data-expected-width="90" data-expected-height="90">X X</canvas>
</div>
<!-- Stretch sizes can't result in a negative content size -->
<div class="wrapper" style="width: 0px; height: 0px">
<canvas width="100" height="100" class="test width min-width max-width stretch"
data-expected-width="10" data-expected-height="10"></canvas>
<canvas width="100" height="100" class="test height min-height max-height stretch"
data-expected-width="10" data-expected-height="10"></canvas>
<canvas width="100" height="100" class="test width min-width max-width height min-height max-height stretch"
data-expected-width="10" data-expected-height="10"></canvas>
</div>
<!-- Indefinite stretch -->
<div style="width: 200px; max-height: 100px">
<canvas width="100" height="100" class="test height stretch indefinite"
data-expected-width="110" data-expected-height="110"></canvas>
<canvas width="100" height="100" class="test min-height stretch indefinite"
data-expected-width="110" data-expected-height="110"></canvas>
<canvas width="100" height="100" class="test max-height stretch indefinite"
data-expected-width="110" data-expected-height="110"></canvas>
</div>
<script src="/resources/testharness.js"></script>
<script src="/resources/testharnessreport.js"></script>
<script src="/resources/check-layout-th.js"></script>
<script>
checkLayout(".test");
</script>