166 lines
5.9 KiB
HTML
166 lines
5.9 KiB
HTML
<!DOCTYPE html>
|
|
|
|
<script src="../../resources/testharness.js"></script>
|
|
<script src="../../resources/testharnessreport.js"></script>
|
|
|
|
<style>
|
|
#test1 {
|
|
color: text;
|
|
}
|
|
</style>
|
|
|
|
<div id="test1"></div>
|
|
|
|
<script>
|
|
function test_prop(element, prop, expected) {
|
|
assert_equals(window.getComputedStyle(element).getPropertyValue(prop), expected);
|
|
}
|
|
|
|
function test_color_is_white(id) {
|
|
test_prop(document.getElementById("test1"), "color", "rgb(255, 255, 255)");
|
|
}
|
|
|
|
function test_color_is_black(id) {
|
|
test_prop(document.getElementById("test1"), "color", "rgb(0, 0, 0)");
|
|
}
|
|
|
|
test(function() {
|
|
// The semantic text color should be black.
|
|
test_color_is_black("test1");
|
|
}, "Element colors are correct in light color scheme with only light supported color scheme");
|
|
|
|
test(function() {
|
|
if (window.internals)
|
|
internals.settings.setUseDarkAppearance(true);
|
|
}, "Dark color scheme enabled");
|
|
|
|
test(function() {
|
|
// The semantic text color should be black, and not change.
|
|
test_color_is_black("test1");
|
|
}, "Element colors are correct in dark color scheme with only light supported color scheme");
|
|
|
|
test(function() {
|
|
if (window.internals)
|
|
internals.settings.setUseDarkAppearance(false);
|
|
}, "Light color scheme enabled");
|
|
|
|
test(function() {
|
|
document.body.style.setProperty("supported-color-schemes", "light dark");
|
|
test_prop(document.body, "supported-color-schemes", "light dark");
|
|
test_prop(document.body, "color-scheme", "light dark");
|
|
}, "Supported color schemes changed to light and dark");
|
|
|
|
test(function() {
|
|
// The semantic text color should be black.
|
|
test_color_is_black("test1");
|
|
}, "Element colors are correct in light color scheme with light and dark supported color scheme");
|
|
|
|
test(function() {
|
|
if (window.internals)
|
|
internals.settings.setUseDarkAppearance(true);
|
|
}, "Dark color scheme enabled 2");
|
|
|
|
test(function() {
|
|
// The semantic text color should be white.
|
|
test_color_is_white("test1");
|
|
}, "Element colors are correct in dark color scheme with light and dark supported color scheme");
|
|
|
|
test(function() {
|
|
if (window.internals)
|
|
internals.settings.setUseDarkAppearance(false);
|
|
}, "Light color scheme enabled 2");
|
|
|
|
test(function() {
|
|
document.body.style.setProperty("supported-color-schemes", "dark");
|
|
test_prop(document.body, "supported-color-schemes", "dark");
|
|
test_prop(document.body, "color-scheme", "dark");
|
|
}, "Supported color schemes changed to dark");
|
|
|
|
test(function() {
|
|
// The semantic text color should be white.
|
|
test_color_is_white("test1");
|
|
}, "Element colors are correct in light color scheme with only dark supported color scheme");
|
|
|
|
test(function() {
|
|
if (window.internals)
|
|
internals.settings.setUseDarkAppearance(true);
|
|
}, "Dark color scheme enabled 3");
|
|
|
|
test(function() {
|
|
// The semantic text color should be white still.
|
|
test_color_is_white("test1");
|
|
}, "Element colors are correct in dark color scheme with only dark supported color scheme");
|
|
|
|
test(function() {
|
|
document.body.style.setProperty("supported-color-schemes", "light foo");
|
|
test_prop(document.body, "supported-color-schemes", "light");
|
|
test_prop(document.body, "color-scheme", "light");
|
|
}, "Supported color schemes changed to light and a bogus value");
|
|
|
|
test(function() {
|
|
// The semantic text color should be black again.
|
|
test_color_is_black("test1");
|
|
}, "Element colors are correct in dark color scheme with only light supported color scheme 2");
|
|
|
|
test(function() {
|
|
document.body.style.setProperty("supported-color-schemes", "auto");
|
|
test_prop(document.body, "supported-color-schemes", "auto");
|
|
test_prop(document.body, "color-scheme", "auto");
|
|
}, "Supported color schemes changed to auto value");
|
|
|
|
test(function() {
|
|
// The semantic text color should be black still.
|
|
test_color_is_black("test1");
|
|
}, "Element colors are correct in dark color scheme with implicit light supported color scheme");
|
|
|
|
test(function() {
|
|
let meta = document.createElement("meta");
|
|
meta.id = "test-meta";
|
|
meta.name = "supported-color-schemes";
|
|
meta.content = "light dark";
|
|
document.head.appendChild(meta);
|
|
}, "Supported color schemes changed to light and dark via <meta> element");
|
|
|
|
test(function() {
|
|
// The semantic text color should be white now.
|
|
test_color_is_white("test1");
|
|
}, "Element colors are correct in dark color scheme with light and dark supported color scheme via <meta> element");
|
|
|
|
test(function() {
|
|
document.body.style.setProperty("supported-color-schemes", "light");
|
|
test_prop(document.body, "supported-color-schemes", "light");
|
|
test_prop(document.body, "color-scheme", "light");
|
|
}, "Supported color schemes changed to light value");
|
|
|
|
test(function() {
|
|
// The semantic text color should be black again.
|
|
test_color_is_black("test1");
|
|
}, "Element colors are correct in dark color scheme with explicit light, overriding <meta> element");
|
|
|
|
test(function() {
|
|
document.getElementById("test-meta").remove();
|
|
}, "Remove test meta element");
|
|
|
|
test(function() {
|
|
document.body.style.setProperty("supported-color-schemes", "light dark");
|
|
test_prop(document.body, "supported-color-schemes", "light dark");
|
|
test_prop(document.body, "color-scheme", "light dark");
|
|
}, "Supported color schemes changed to light and dark 2");
|
|
|
|
test(function() {
|
|
// The semantic text color should be white now.
|
|
test_color_is_white("test1");
|
|
}, "Element colors are correct in dark color scheme with light and dark supported color scheme 2");
|
|
|
|
test(function() {
|
|
document.body.style.setProperty("supported-color-schemes", "foo dark");
|
|
test_prop(document.body, "supported-color-schemes", "dark");
|
|
test_prop(document.body, "color-scheme", "dark");
|
|
}, "Supported color schemes changed to a bogus value and dark");
|
|
|
|
test(function() {
|
|
// The semantic text color should be white still.
|
|
test_color_is_white("test1");
|
|
}, "Element colors are correct in dark color scheme with dark supported color scheme");
|
|
</script>
|