blob: a3cfa47213fd3ce46a7c7302b5763f49142a3767 [file] [log] [blame]
<!DOCTYPE html>
<meta charset="UTF-8">
<title>CSS Values and Units Test: calc() function in 'min-height' and 'box-sizing: border-box' (complex)</title>
<!--
Original test is:
https://chromium.googlesource.com/chromium/src/+/c825d655f6aaf73484f9d56e9012793f5b9668cc/third_party/WebKit/LayoutTests/css3/calc/calc-min-height.html
The original test is related to:
Issue 580508: Height of content changes after multiple reloads
https://bugs.chromium.org/p/chromium/issues/detail?id=580508
-->
<link rel="author" title="GĂ©rard Talbot" href="http://www.gtalbot.org/BrowserBugsSection/css21testsuite/">
<link rel="help" href="https://www.w3.org/TR/css-values-3/#calc-notation">
<link rel="match" href="../reference/ref-filled-green-100px-square.xht">
<meta name="flags" content="">
<meta name="assert" content="This test checks how 'min-height' with calc(percentage) and 'box-sizing' are handled. The percentage in the calc() is calculated on the content box height of div#container.">
<style>
div#container
{
border-bottom: transparent solid 100px;
border-right: transparent solid 100px;
height: 400px;
width: 100px;
}
div#item
{
background-color: red;
box-sizing: border-box;
height: 50px;
min-height: calc(50% - 100px);
}
div#item > div
{
background-color: green;
border-bottom: green solid 34px; /* arbitrary border-bottom-width value */
border-top: green solid 12px; /* arbitrary border-top-width value */
box-sizing: border-box;
height: 17px;
min-height: 100%; /* content height should be 100px - 34px - 12px == 54px */
overflow-y: visible;
/*
If the content height of innermost div is taller
than 54px, then a green rectangle (not a square)
will be created.
If the content height of innermost div is less
than 54px, then an horizontal stripe of red
will become visible.
*/
}
</style>
<p>Test passes if there is a filled green square and <strong>no red</strong>.
<div id="container">
<div id="item">
<div></div>
</div>
</div>