LibWeb: Add overflow-clip-margin-* properties

The corner radius isn't quite right yet, but this gives us
another couple WPT passes for these.
This commit is contained in:
Psychpsyo
2026-02-12 18:00:38 +01:00
committed by Alexander Kalenik
parent 3253ddfcb2
commit a7267f711b
Notes: github-actions[bot] 2026-02-14 21:59:33 +00:00
28 changed files with 674 additions and 4 deletions

View File

@@ -0,0 +1,42 @@
<!doctype html>
<meta charset="utf-8">
<title>Verifies overflow-clip-margin extends outside bounds</title>
<link rel="help" href="https://www.w3.org/TR/css-overflow-3/#propdef-overflow-clip-margin">
<link rel="author" title="Scott Violet" href="mailto:sky@chromium.org">
<link rel="match" href="../../../../expected/wpt-import/css/css-overflow/overflow-clip-margin-001-ref.html">
<style>
.container {
display: flex;
}
.parent {
width: 100px;
height: 100px;
flex: none;
overflow: clip;
overflow-clip-margin: 10px;
}
.child {
width: 200px;
height: 200px;
position: relative;
top: -50px;
left: -50px;
background-color: green;
}
.spacer {
flex: none;
height: 100px;
width: 100px;
}
</style>
<p>You should see two green squares touching each other. The one on the
right should be slightly larger.</p>
<div class="spacer"></div>
<div class="container">
<div class="spacer" style="width: 90px; background-color: green"></div>
<div class="spacer" style="width: 10px"></div>
<div class="parent">
<div class="child"></div>
</div>
</div>

View File

@@ -0,0 +1,18 @@
<!doctype html>
<meta charset="utf-8">
<title>Verifies overflow-clip-margin doesn't impact paint effects</title>
<link rel="help" href="https://www.w3.org/TR/css-overflow-3/#propdef-overflow-clip-margin">
<link rel="author" title="Scott Violet" href="mailto:sky@chromium.org">
<link rel="match" href="../../../../expected/wpt-import/css/css-overflow/overflow-clip-margin-003-ref.html">
<style>
.parent {
width: 100px;
height: 100px;
background-color: green;
overflow: clip;
overflow-clip-margin: 1px;
box-shadow: 20px 20px 5px red;
}
</style>
<p>You should see a green box with a red box shadow.
<div class="parent"></div>

View File

@@ -0,0 +1,42 @@
<!doctype html>
<meta charset="utf-8">
<title>Verifies overflow-clip-margin extends outside bounds with contain: paint</title>
<link rel="help" href="https://www.w3.org/TR/css-overflow-3/#propdef-overflow-clip-margin">
<link rel="author" title="Scott Violet" href="mailto:sky@chromium.org">
<link rel="match" href="../../../../expected/wpt-import/css/css-overflow/overflow-clip-margin-004-ref.html">
<style>
.container {
display: flex;
}
.parent {
width: 100px;
height: 100px;
flex: none;
contain: paint;
overflow-clip-margin: 10px;
}
.child {
width: 200px;
height: 200px;
position: relative;
top: -50px;
left: -50px;
background-color: green;
}
.spacer {
flex: none;
height: 100px;
width: 100px;
}
</style>
<p>You should see two green squares touching each other. The one on the
right should be slightly larger.</p>
<div class="spacer"></div>
<div class="container">
<div class="spacer" style="width: 90px; background-color: green"></div>
<div class="spacer" style="width: 10px"></div>
<div class="parent">
<div class="child"></div>
</div>
</div>

View File

@@ -0,0 +1,18 @@
<!doctype html>
<meta charset="utf-8">
<title>Verifies overflow-clip-margin doesn't impact paint effects</title>
<link rel="help" href="https://www.w3.org/TR/css-overflow-3/#propdef-overflow-clip-margin">
<link rel="author" title="Scott Violet" href="mailto:sky@chromium.org">
<link rel="match" href="../../../../expected/wpt-import/css/css-overflow/overflow-clip-margin-006-ref.html">
<style>
.parent {
width: 100px;
height: 100px;
background-color: green;
contain: paint;
overflow-clip-margin: 1px;
box-shadow: 20px 20px 5px red;
}
</style>
<p>You should see a green box with a red box shadow.
<div class="parent"></div>

View File

@@ -0,0 +1,28 @@
<!doctype html>
<html class="reftest">
<meta charset="utf-8">
<title>Overflow-clip-margin can be inherited even if it has no effect on specified element</title>
<link rel="help" href="https://www.w3.org/TR/css-overflow-3/#propdef-overflow-clip-margin">
<link rel="author" title="Vladimir Levin" href="mailto:vmpstr@chromium.org">
<link rel="match" href="../../../../expected/wpt-import/css/css-overflow/overflow-clip-margin-009-ref.html">
<style>
.prop {
overflow-clip-margin: 20px;
}
.container {
width: 100px;
height: 100px;
overflow-clip-margin: inherit;
overflow: clip;
}
.child {
width: 200px;
height: 200px;
background: lightblue;
}
</style>
<div class=prop>
<div class=container>
<div class=child></div>
</div>
</div>

View File

@@ -0,0 +1,35 @@
<!doctype html>
<meta charset="utf-8">
<title>Overflow-clip-margin: child of a small-border-box out-of-view large-clip-margin parent is shown</title>
<link rel="help" href="https://www.w3.org/TR/css-overflow-3/#propdef-overflow-clip-margin">
<link rel="author" title="Xianzhu Wang" href="mailto:wangxianzhu@chromium.org">
<link rel="match" href="../../../../expected/wpt-import/css/css-overflow/overflow-clip-margin-011-ref.html">
<style>
.overflow-hidden {
width: 200px;
height: 200px;
overflow: hidden;
}
.parent {
width: 100px;
height: 100px;
position: relative;
top: 500px;
overflow: clip;
overflow-clip-margin: 500px;
z-index: 1;
background: red;
}
.child {
width: 100px;
height: 100px;
position: relative;
top: -500px;
background: green;
}
</style>
<div class="overflow-hidden">
<div class="parent">
<div class="child">
</div>
</div>

View File

@@ -0,0 +1,64 @@
<!DOCTYPE html>
<html class="reftest-wait">
<head>
<title>CSS Overflow: overflow-clip-margin: invalidation on change</title>
<link rel="help" href="https://www.w3.org/TR/css-overflow-3/#propdef-overflow-clip-margin">
<meta name="assert" content="overflow-clip-margin: toggling should invalidate.">
<link rel="author" title="Scott Violet" href="mailto:sky@chromium.org">
<link rel="match" href="../../../../expected/wpt-import/css/css-overflow/overflow-clip-margin-invalidation-ref.html">
<style>
.container {
display: flex;
}
.parent {
flex: none;
width: 100px;
height: 100px;
flex: none;
overflow: clip;
}
.child {
width: 200px;
height: 200px;
position: relative;
top: -50px;
left: -50px;
background-color: green;
}
.spacer {
flex: none;
height: 100px;
width: 100px;
}
.margin {
overflow-clip-margin: 10px;
}
</style>
<script src="../../common/reftest-wait.js"></script>
<script src="../../common/rendering-utils.js"></script>
</head>
<body>
<div class="spacer"></div>
<div class="container">
<div class="spacer"></div>
<div id="div_with_margin" class="parent margin">
<div class="child"></div>
</div>
<div class="spacer"></div>
<div class="container">
<div class="spacer"></div>
<div id="div_without_margin" class="parent">
<div class="child"></div>
</div>
</body>
<script>
async function runTest() {
document.getElementById('div_with_margin').classList.remove("margin");
document.getElementById('div_without_margin').classList.add("margin");
takeScreenshot();
}
onload = () => {
waitForAtLeastOneFrame().then(() => { runTest() });
}
</script>
</html>