diff options
author | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-19 01:47:29 +0000 |
---|---|---|
committer | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-19 01:47:29 +0000 |
commit | 0ebf5bdf043a27fd3dfb7f92e0cb63d88954c44d (patch) | |
tree | a31f07c9bcca9d56ce61e9a1ffd30ef350d513aa /testing/web-platform/tests/css/css-view-transitions/only-child-group.html | |
parent | Initial commit. (diff) | |
download | firefox-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/css-view-transitions/only-child-group.html')
-rw-r--r-- | testing/web-platform/tests/css/css-view-transitions/only-child-group.html | 113 |
1 files changed, 113 insertions, 0 deletions
diff --git a/testing/web-platform/tests/css/css-view-transitions/only-child-group.html b/testing/web-platform/tests/css/css-view-transitions/only-child-group.html new file mode 100644 index 0000000000..665befee12 --- /dev/null +++ b/testing/web-platform/tests/css/css-view-transitions/only-child-group.html @@ -0,0 +1,113 @@ +<!DOCTYPE html> +<html class="reftest-wait foo"> +<title>View transitions: ensure :only-child is supported on view-transition-group</title> +<link rel="help" href="https://github.com/WICG/view-transitions"> +<link rel="author" href="mailto:khushalsagar@chromium.org"> + +<script src="/resources/testharness.js"></script> +<script src="/resources/testharnessreport.js"></script> + +<style> +::view-transition { + background-color: black; +} +html:only-child { + background-color: black; +} +:root:only-child { + background-color: black; +} +:only-child { + background-color: black; +} +.foo:only-child { + background-color: black; +} + +::view-transition-group(root) { + background-color: blue; +} +::view-transition-group(target) { + background-color: blue; +} +::view-transition-group(*) { + color: blue; +} + +::view-transition-group(root):only-child { + background-color: red; +} +::view-transition-group(target):only-child { + background-color: red; +} +::view-transition-group(*):only-child { + color: red; +} + +</style> +<div id="target"></div> +<div id="target2"></div> + +<script> +promise_test(() => { + return new Promise(async (resolve, reject) => { + let transition = document.startViewTransition(); + transition.ready.then(() => { + let style = getComputedStyle( + document.documentElement, ":view-transition-group(root)"); + if (style.backgroundColor == "rgb(255, 0, 0)" && style.color == "rgb(255, 0, 0)") + resolve(); + else + reject(style.backgroundColor + " and " + style.color); + }); + }); +}, ":only-child should match because ::view-transition-group is generated for root element only"); + +promise_test(() => { + return new Promise(async (resolve, reject) => { + target.style.viewTransitionName = "target"; + let transition = document.startViewTransition(); + transition.ready.then(() => { + let style = getComputedStyle( + document.documentElement, ":view-transition-group(root)"); + if (style.backgroundColor == "rgb(0, 0, 255)" && style.color == "rgb(0, 0, 255)") + resolve(); + else + reject(style.backgroundColor + " and " + style.color); + }); + }); +}, ":only-child should not match because ::view-transition-group is generated for multiple elements"); + +promise_test(() => { + return new Promise(async (resolve, reject) => { + document.documentElement.style.viewTransitionName = "none"; + target.style.viewTransitionName = "target"; + let transition = document.startViewTransition(); + transition.ready.then(() => { + let style = getComputedStyle( + document.documentElement, ":view-transition-group(target)"); + if (style.backgroundColor == "rgb(255, 0, 0)" && style.color == "rgb(255, 0, 0)") + resolve(); + else + reject(style.backgroundColor + " and " + style.color); + }); + }); +}, ":only-child should match because ::view-transition-group is generated for sub element only"); + +promise_test(() => { + return new Promise(async (resolve, reject) => { + document.documentElement.style.viewTransitionName = "none"; + target.style.viewTransitionName = "target"; + target2.style.viewTransitionName = "target2"; + let transition = document.startViewTransition(); + transition.ready.then(() => { + let style = getComputedStyle( + document.documentElement, ":view-transition-group(target)"); + if (style.backgroundColor == "rgb(0, 0, 255)" && style.color == "rgb(0, 0, 255)") + resolve(); + else + reject(style.backgroundColor + " and " + style.color); + }); + }); +}, ":only-child should not match because ::view-transition-group is generated for multiple sub elements"); +</script> |