summaryrefslogtreecommitdiffstats
path: root/testing/web-platform/tests/css/css-flexbox/flex-minimum-height-flex-items-031.html
blob: 57f3f180de7f6d9faf9f90a6287f2c42c9eac05d (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
<!DOCTYPE html>
<link rel="author" title="Oriol Brufau" href="mailto:obrufau@igalia.com">
<link rel="help" href="https://drafts.csswg.org/css-flexbox/#min-size-auto">
<link rel="help" href="https://bugs.webkit.org/show_bug.cgi?id=240068">
<meta name="assert" content="An intrinsic min-height can make a column flex container grow enough for its contents, even if it's also a flex item with 'flex-basis: 0px'.">

<div id="log"></div>

<script src="/resources/testharness.js"></script>
<script src="/resources/testharnessreport.js"></script>
<script src="/resources/check-layout-th.js"></script>
<script>
for (let outerFlexDirection of ["column", "column-reverse"]) {
  for (let innerFlexDirection of ["column", "column-reverse"]) {
    for (let placeContent of ["start", "center", "end"]) {
      for (let minHeight of ["auto", "min-content", "max-content"]) {
        for (let flex of ["0 0 44px", "1 1 44px"]) {
          const outer = document.createElement("div");
          outer.className = "flex";
          outer.style.display = "inline-flex";
          outer.style.flexDirection = outerFlexDirection;
          outer.style.border = "1px solid #000";
          outer.dataset.expectedClientHeight = "104";

          const inner = document.createElement("div");
          inner.style.flexBasis = "0px";
          inner.style.display = "flex";
          inner.style.flexDirection = innerFlexDirection;
          inner.style.placeContent = placeContent;
          inner.style.minHeight = minHeight;
          inner.style.border = "2px solid #0ff";
          inner.dataset.expectedClientHeight = "100";

          const content1 = document.createElement("div");
          content1.style.flex = flex;
          content1.style.border = "3px solid #f0f";
          content1.dataset.expectedHeight = "50";

          const content2 = content1.cloneNode();

          content1.textContent = "1";
          content2.textContent = "2";
          inner.appendChild(content1);
          inner.appendChild(content2);
          outer.appendChild(inner);
          document.body.appendChild(outer);
        }
      }
    }
  }
  document.body.appendChild(document.createElement("br"));
}
checkLayout(".flex");
</script>