summaryrefslogtreecommitdiffstats
path: root/testing/web-platform/tests/css/cssom-view/checkVisibility.html
diff options
context:
space:
mode:
authorDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-19 01:47:29 +0000
committerDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-19 01:47:29 +0000
commit0ebf5bdf043a27fd3dfb7f92e0cb63d88954c44d (patch)
treea31f07c9bcca9d56ce61e9a1ffd30ef350d513aa /testing/web-platform/tests/css/cssom-view/checkVisibility.html
parentInitial commit. (diff)
downloadfirefox-esr-0ebf5bdf043a27fd3dfb7f92e0cb63d88954c44d.tar.xz
firefox-esr-0ebf5bdf043a27fd3dfb7f92e0cb63d88954c44d.zip
Adding upstream version 115.8.0esr.upstream/115.8.0esr
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'testing/web-platform/tests/css/cssom-view/checkVisibility.html')
-rw-r--r--testing/web-platform/tests/css/cssom-view/checkVisibility.html99
1 files changed, 99 insertions, 0 deletions
diff --git a/testing/web-platform/tests/css/cssom-view/checkVisibility.html b/testing/web-platform/tests/css/cssom-view/checkVisibility.html
new file mode 100644
index 0000000000..3ab1cc7dc2
--- /dev/null
+++ b/testing/web-platform/tests/css/cssom-view/checkVisibility.html
@@ -0,0 +1,99 @@
+<!DOCTYPE html>
+<link rel=author href="mailto:jarhar@chromium.org">
+<link rel=help href="https://github.com/w3c/csswg-drafts/issues/6850">
+<script src="/resources/testharness.js"></script>
+<script src="/resources/testharnessreport.js"></script>
+
+<div id=visibilityhidden style="visibility:hidden">hello</div>
+
+<div style="content-visibility:hidden">
+ <div id=cvhidden>hello</div>
+</div>
+
+<div style="content-visibility:auto">
+ <div id=cvauto>hello</div>
+</div>
+
+<div id=displaynone style="display:none">hello</div>
+
+<div id=opacityzero style="opacity:0">hello</div>
+
+<div style="content-visibility:hidden">
+ <div id=cvhiddenchildwithupdate></div>
+</div>
+
+<div style="content-visibility:hidden" id=cvhiddenwithupdate></div>
+
+<div style="height:10000px">spacer</div>
+
+<div style="content-visibility:auto">
+ <div id=cvautooffscreen>hello</div>
+</div>
+
+<div id=cvautocontainer>
+ <div id=cvautochild></div>
+</div>
+
+<div style="content-visibility:auto">
+ <div style="content-visibility:auto">
+ <div id=nestedcvautochild></div>
+ </div>
+</div>
+
+<script>
+test(() => {
+ assert_false(visibilityhidden.checkVisibility({
+ checkVisibilityCSS: true
+ }), 'checkVisibilityCSS:true');
+ assert_true(visibilityhidden.checkVisibility({
+ checkVisibilityCSS: false
+ }), 'checkVisibilityCSS:false');
+}, 'checkVisibility on visibility:hidden element.');
+
+test(() => {
+ assert_false(cvhidden.checkVisibility());
+}, 'checkVisibility on content-visibility:hidden element.');
+
+test(() => {
+ assert_true(cvauto.checkVisibility());
+}, 'checkVisibility on content-visibility:auto element.');
+
+test(() => {
+ assert_true(cvautooffscreen.checkVisibility());
+}, 'checkVisibility on content-visibility:auto element which is outside the viewport.');
+
+test(() => {
+ assert_false(displaynone.checkVisibility());
+}, 'checkVisibility on display:none element.');
+
+test(() => {
+ assert_false(opacityzero.checkVisibility({
+ checkOpacity: true
+ }), 'checkOpacity:true');
+ assert_true(opacityzero.checkVisibility({
+ checkOpacity: false
+ }), 'checkOpacity:false');
+}, 'checkVisibility on opacity:0 element.');
+
+test(() => {
+ cvautocontainer.style.contentVisibility = 'auto';
+ cvautochild.style.visibility = 'hidden';
+ assert_false(cvautochild.checkVisibility({checkVisibilityCSS: true}));
+ cvautochild.style.visibility = 'visible';
+ assert_true(cvautochild.checkVisibility({checkVisibilityCSS: true}));
+}, 'checkVisibility on content-visibility:auto with visibility:hidden inside.');
+
+test(() => {
+ assert_true(nestedcvautochild.checkVisibility());
+}, 'checkVisibility on nested content-visibility:auto containers reports that the content is visible.');
+
+test(() => {
+ cvhiddenchildwithupdate.getBoundingClientRect();
+ assert_false(cvhiddenchildwithupdate.checkVisibility());
+}, 'checkVisibility on content-visibility:hidden child after forced layout update.');
+
+test(() => {
+ cvhiddenwithupdate.getBoundingClientRect();
+ assert_true(cvhiddenwithupdate.checkVisibility());
+}, 'checkVisibility on content-visibility:hidden element after forced layout update.');
+</script>