File: block-height-004.html

package info (click to toggle)
thunderbird 1%3A143.0.1-1
  • links: PTS, VCS
  • area: main
  • in suites: experimental
  • size: 4,703,968 kB
  • sloc: cpp: 7,770,492; javascript: 5,943,842; ansic: 3,918,754; python: 1,418,263; xml: 653,354; asm: 474,045; java: 183,079; sh: 111,238; makefile: 20,410; perl: 14,359; objc: 13,059; yacc: 4,583; pascal: 3,405; lex: 1,720; ruby: 999; exp: 762; sql: 715; awk: 580; php: 436; lisp: 430; sed: 69; csh: 10
file content (94 lines) | stat: -rw-r--r-- 2,734 bytes parent folder | download | duplicates (10)
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
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
<!DOCTYPE html>
<link rel="help"
  href="https://drafts.csswg.org/css-sizing-4/#stretch-fit-sizing">
<link rel="help" href="https://github.com/w3c/csswg-drafts/issues/11044">
<script src='/resources/testharness.js'></script>
<script src='/resources/testharnessreport.js'></script>
<script src="/resources/check-layout-th.js"></script>
<meta name="assert"
  content="margins of the stretched element are accounted for correctly in a variety of scenarios, mostly around siblings">

<style>
  .outer {
    width: 100px;
    height: 100px;
    outline: solid;
    position: relative;
  }

  .inner {
    height: stretch;
    margin: 10px;
  }
</style>

<h2>These tests assert the behavior described at
  https://github.com/w3c/csswg-drafts/issues/11044#issuecomment-2599101601
</h2>

<p>Basic case: treat margins as 0.</p>
<div class="outer">
  <div class="inner" style="border: solid magenta;" data-expected-height="100"
    data-offset-y="0">
  </div>
</div>

<p>
  When resolving stretch treat both block margins as 0 because the parent is
  not a BFC and has no top or bottom content edge (i.e. border + padding = 0).
  <br>But cyan's margins will not actually collapse through its IFC-siblings so
  there is overflow:
</p>
<div class="outer">
  <div style="overflow: hidden"></div>
  <div class="inner" style="border: solid cyan;" data-expected-height="100"
    data-offset-y="10">
  </div>
  <div style="overflow: hidden"></div>
</div>

<div class="outer">
  <div></div>
  <div class="inner" style="border: solid blue;" data-expected-height="100"
    data-offset-y="0">
  </div>
  <div></div>
</div>

<div class="outer">
  <div></div>
  <div class="inner" style="border: solid purple;" data-expected-height="100"
    data-offset-y="0">
  </div>
</div>

<div class="outer">
  <div class="inner" style="border: solid lime;" data-expected-height="100"
    data-offset-y="0">
  </div>
  <div></div>
</div>

<p>Parent has non-zero bottom border, so only top margin is treated as 0:</p>
<div class="outer" style="border-bottom: 5px dashed blue;">
  <div class="inner" style="border: solid brown;" data-expected-height="90"
    data-offset-y="0">
  </div>
</div>

<p>Parent has non-zero top padding so only bottom margin is treated as 0:</p>
<div class="outer" style="padding-top: 5px;">
  <div class="inner" style="border: solid darkgreen;" data-expected-height="90"
    data-offset-y="15"> <!-- 15 = 10px top margin + parent's padding-->
  </div>
</div>

<p>Account for the margins when parent establishes a BFC.</p>
<div class="outer" style="display: flow-root;">
  <div class="inner" style="border: solid orange;" data-expected-height="80"
    data-offset-y="10">
  </div>
  <div></div>
</div>

<script>checkLayout(".inner");</script>