gecko-dev/layout/style/test/test_non_content_accessible...

59 строки
1.5 KiB
HTML

<!doctype html>
<script src="/resources/testharness.js"></script>
<script src="/resources/testharnessreport.js"></script>
<style id="sheet"></style>
<div></div>
<script>
const NON_CONTENT_ACCESSIBLE_PROPERTIES = [
"-x-span",
"-x-lang",
"-x-text-zoom",
"-moz-window-shadow",
// FIXME(bug 1419695): These should be hidden, but Gecko would refuse to
// transition them. We need to fix that.
// "-moz-window-opacity",
// "-moz-window-transform",
// "-moz-window-transform-origin",
"-moz-top-layer",
"-moz-script-size-multiplier",
"-moz-script-level",
"-moz-math-display",
"-moz-math-variant",
"-moz-script-min-size",
"-moz-font-smoothing-background-color",
"-moz-min-font-size-ratio",
"-moz-script-size-multiplier",
];
const sheet = document.getElementById("sheet");
const div = document.querySelector("div");
test(function() {
sheet.textContent = `div { color: initial }`;
assert_equals(sheet.sheet.cssRules[0].style.length, 1);
}, "sanity");
for (const prop of NON_CONTENT_ACCESSIBLE_PROPERTIES) {
test(function() {
sheet.textContent = `div { ${prop}: initial }`;
let block = sheet.sheet.cssRules[0].style;
assert_equals(
block.length,
0,
prop + " shouldn't be parsed in content"
);
block.setProperty(prop, "initial");
assert_equals(
block.length,
0,
prop + " shouldn't be settable via CSSOM in content"
);
assert_equals(
getComputedStyle(div).getPropertyValue(prop),
"",
prop + " shouldn't be accessible via CSSOM in content"
);
}, prop);
}
</script>