summaryrefslogtreecommitdiffstats
path: root/layout/inspector/tests/test_bug877690.html
diff options
context:
space:
mode:
Diffstat (limited to '')
-rw-r--r--layout/inspector/tests/test_bug877690.html269
1 files changed, 269 insertions, 0 deletions
diff --git a/layout/inspector/tests/test_bug877690.html b/layout/inspector/tests/test_bug877690.html
new file mode 100644
index 0000000000..a8b30402a4
--- /dev/null
+++ b/layout/inspector/tests/test_bug877690.html
@@ -0,0 +1,269 @@
+<!DOCTYPE HTML>
+<html>
+<!--
+https://bugzilla.mozilla.org/show_bug.cgi?id=877690
+-->
+<head>
+<meta charset="utf-8">
+<title>Test for InspectorUtils.getCSSValuesForProperty</title>
+<script src="/tests/SimpleTest/SimpleTest.js"></script>
+<link rel="stylesheet" type="text/css" href="/tests/SimpleTest/test.css"/>
+<script>
+
+/** Test for InspectorUtils.getCSSValuesForProperty **/
+
+const InspectorUtils = SpecialPowers.InspectorUtils;
+
+// Returns true if values contains all and only the expected values. False otherwise.
+function testValues(values, expected) {
+ values.sort();
+ expected.sort();
+
+ info(JSON.stringify([...values]));
+ info(JSON.stringify(expected));
+
+ if (values.length !== expected.length) {
+ return false;
+ }
+
+ for (var i = 0; i < values.length; ++i) {
+ if (values[i] !== expected[i]) {
+ return false;
+ }
+ }
+ return true;
+}
+
+function do_test() {
+ var allColors = [ "COLOR", "currentColor", "transparent", "rgb", "rgba", "hsl", "hsla", "hwb" ];
+ if (SpecialPowers.getBoolPref("layout.css.color-mix.enabled")) {
+ allColors.push("color-mix");
+ }
+ if (SpecialPowers.getBoolPref("layout.css.more_color_4.enabled", true)) {
+ allColors.push("color", "lab", "lch", "oklab", "oklch");
+ }
+ var allGradients = [
+ "linear-gradient",
+ "-webkit-linear-gradient",
+ "-moz-linear-gradient",
+ "repeating-linear-gradient",
+ "-webkit-repeating-linear-gradient",
+ "-moz-repeating-linear-gradient",
+ "radial-gradient",
+ "-webkit-radial-gradient",
+ "-moz-radial-gradient",
+ "repeating-radial-gradient",
+ "-webkit-repeating-radial-gradient",
+ "-moz-repeating-radial-gradient",
+ "-webkit-gradient",
+ "conic-gradient",
+ "repeating-conic-gradient",
+ ];
+
+ // test a property with keywords and colors
+ var prop = "color";
+ var values = InspectorUtils.getCSSValuesForProperty(prop);
+ var expected = [ "initial", "inherit", "unset", "revert", "revert-layer", ...allColors ];
+ ok(testValues(values, expected), "property color's values.");
+
+ // test a shorthand property
+ var prop = "background";
+ var values = InspectorUtils.getCSSValuesForProperty(prop);
+ var expected = [ "auto", "initial", "inherit", "unset", "revert", "revert-layer", ...allColors, "no-repeat", "repeat",
+ "repeat-x", "repeat-y", "space", "round", "fixed", "scroll", "local", "center", "top", "bottom", "left", "right",
+ "border-box", "padding-box", "content-box", "text", "contain",
+ "cover", "none", "-moz-element", "-moz-image-rect", "url", ...allGradients, "image-set" ];
+
+ if(SpecialPowers.getBoolPref("layout.css.cross-fade.enabled")) {
+ expected.push("cross-fade");
+ }
+
+ ok(testValues(values, expected), "property background values.");
+
+ var prop = "border";
+ var values = InspectorUtils.getCSSValuesForProperty(prop);
+ var expected = [ "initial", "unset", "revert", "revert-layer", "dashed", "dotted", "double",
+ "groove", "hidden", "inherit", "inset", "medium", "none", "outset", "ridge",
+ "solid", "thick", "thin", ...allColors ]
+ ok(testValues(values, expected), "property border values.");
+
+ // test keywords only
+ var prop = "border-top";
+ var values = InspectorUtils.getCSSValuesForProperty(prop);
+ var expected = [ "initial", "inherit", "revert", "revert-layer", "unset", "thin", "medium", "thick", "none", "hidden", "dotted",
+ "dashed", "solid", "double", "groove", "ridge", "inset", "outset", ...allColors ];
+ ok(testValues(values, expected), "property border-top's values.");
+
+ // tests no keywords or colors
+ var prop = "padding-bottom";
+ var values = InspectorUtils.getCSSValuesForProperty(prop);
+ var expected = [ "initial", "inherit", "unset", "revert", "revert-layer" ];
+ ok(testValues(values, expected), "property padding-bottom's values.");
+
+ // test proprety
+ var prop = "display";
+ var values = InspectorUtils.getCSSValuesForProperty(prop);
+ var expected = [ "initial", "inherit", "unset", "revert", "revert-layer", "none", "inline", "block", "inline-block", "list-item",
+ "table", "inline-table", "table-row-group", "table-header-group", "table-footer-group", "table-row",
+ "table-column-group", "table-column", "table-cell", "table-caption",
+ "flex", "inline-flex", "-webkit-box", "-webkit-inline-box",
+ "grid", "inline-grid", "inline list-item", "inline flow-root list-item", "flow-root list-item",
+ "ruby", "ruby-base", "ruby-base-container", "ruby-text", "ruby-text-container", "block ruby",
+ "contents", "flow-root" ];
+ ok(testValues(values, expected), "property display's values.");
+
+ // test property
+ var prop = "float";
+ var values = InspectorUtils.getCSSValuesForProperty(prop);
+ var expected = [ "initial", "inherit", "unset", "revert", "revert-layer", "none", "left", "right", "inline-start", "inline-end" ];
+ ok(testValues(values, expected), "property float's values.");
+
+ // Test property with "auto"
+ var prop = "margin";
+ var values = InspectorUtils.getCSSValuesForProperty(prop);
+ var expected = [ "initial", "unset", "auto", "inherit", "revert", "revert-layer" ];
+ ok(testValues(values, expected), "property margin's values.");
+
+ // Test property with "normal"
+ var prop = "font-style";
+ var values = InspectorUtils.getCSSValuesForProperty(prop);
+ var expected = [ "initial", "inherit", "unset", "revert", "revert-layer", "italic", "normal", "oblique" ];
+ ok(testValues(values, expected), "property font-style's values.");
+
+ // Test property with "cubic-bezier" and "step".
+ var prop = "-moz-transition";
+ var values = InspectorUtils.getCSSValuesForProperty(prop);
+ var expected = [ "initial", "all", "unset", "cubic-bezier", "ease", "ease-in", "ease-in-out",
+ "ease-out", "inherit", "revert", "revert-layer", "linear", "none", "step-end", "step-start",
+ "steps" ];
+ ok(testValues(values, expected), "property -moz-transition's values.");
+
+ // test invalid property
+ var prop = "invalidProperty";
+ try {
+ InspectorUtils.getCSSValuesForProperty(prop);
+ ok(false, "invalid property should throw an exception");
+ }
+ catch(e) {
+ // test passed
+ }
+
+ // test border-image property, for bug 973345
+ var prop = "border-image";
+ var values = InspectorUtils.getCSSValuesForProperty(prop);
+ var expected = [ "auto", "inherit", "revert", "revert-layer", "initial", "unset", "repeat", "stretch",
+ "-moz-element", "-moz-image-rect", "url", ...allGradients,
+ "fill", "none", "round", "space", "image-set" ];
+
+ if(SpecialPowers.getBoolPref("layout.css.cross-fade.enabled")) {
+ expected.push("cross-fade");
+ }
+
+ ok(testValues(values, expected), "property border-image's values.");
+
+ var prop = "background-size"
+ var values = InspectorUtils.getCSSValuesForProperty(prop);
+ var expected = [ "auto", "inherit", "revert", "revert-layer", "initial", "unset", "contain", "cover" ];
+ ok(testValues(values, expected), "property background-size's values.");
+
+ // Regression test for bug 1255401.
+ var prop = "all"
+ var values = InspectorUtils.getCSSValuesForProperty(prop);
+ var expected = [ "inherit", "initial", "unset", "revert", "revert-layer" ];
+ ok(testValues(values, expected), "property all's values.");
+
+ var prop = "quotes"
+ var values = InspectorUtils.getCSSValuesForProperty(prop);
+ var expected = [ "inherit", "initial", "unset", "revert", "revert-layer", "auto", "none" ];
+ ok(testValues(values, expected), "property quotes's values.");
+
+ // Regression test for bug 1255384.
+ for (prop of ["counter-increment", "counter-reset"]) {
+ var values = InspectorUtils.getCSSValuesForProperty(prop);
+ var expected = [ "inherit", "initial", "unset", "none", "revert", "revert-layer" ];
+ ok(testValues(values, expected), "property " + prop + "'s values.");
+ }
+
+ // Regression test for bug 1430616
+ var prop = "text-align";
+ var values = InspectorUtils.getCSSValuesForProperty(prop);
+ ok(values.includes("match-parent"), "property text-align includes match-parent");
+
+ // Regression test for bug 1255402.
+ var expected = [ "inherit", "initial", "unset", "revert", "revert-layer", "left", "right",
+ "top", "center", "bottom" ];
+ for (prop of ["object-position", "perspective-origin"]) {
+ var values = InspectorUtils.getCSSValuesForProperty(prop);
+ ok(testValues(values, expected), "property " + prop + "'s values");
+ }
+
+ // Regression test for bug 1255378.
+ var expected = [ "inherit", "initial", "unset", "revert", "revert-layer", "none", ...allColors ];
+ var values = InspectorUtils.getCSSValuesForProperty("text-shadow");
+ ok(testValues(values, expected), "property text-shadow's values");
+
+ var expected = [ "inherit", "initial", "unset", "revert", "revert-layer", "inset", "none", ...allColors ];
+ var values = InspectorUtils.getCSSValuesForProperty("box-shadow");
+ ok(testValues(values, expected), "property box-shadow's values");
+
+ // Regression test for bug 1255379.
+ var expected = [ "inherit", "initial", "unset", "revert", "revert-layer", "none", "url",
+ "polygon", "circle", "ellipse", "inset", "path",
+ "fill-box", "stroke-box", "view-box", "margin-box",
+ "border-box", "padding-box", "content-box" ];
+ var values = InspectorUtils.getCSSValuesForProperty("clip-path");
+ ok(testValues(values, expected), "property clip-path's values");
+
+ var expected = [ "inherit", "initial", "unset", "revert", "revert-layer", "auto", "rect" ];
+ var values = InspectorUtils.getCSSValuesForProperty("clip");
+ ok(testValues(values, expected), "property clip's values");
+
+ // Regression test for bug 1255380.
+ var expected = [ "normal", "none", "counter", "counters",
+ "attr", "open-quote", "close-quote", "no-open-quote",
+ "no-close-quote", "inherit", "initial", "unset", "revert",
+ "revert-layer", "-moz-alt-content", "-moz-label-content", "image-set", "url", "-moz-element", "-moz-image-rect" ]
+ .concat(allGradients);
+ var values = InspectorUtils.getCSSValuesForProperty("content");
+ ok(testValues(values, expected), "property content's values");
+
+ // Regression test for bug 1255369.
+ var expected = ["none", "decimal", "decimal-leading-zero", "arabic-indic", "armenian",
+ "upper-armenian", "lower-armenian", "bengali", "cambodian", "khmer",
+ "cjk-decimal", "devanagari", "georgian", "gujarati", "gurmukhi", "hebrew",
+ "kannada", "lao", "malayalam", "mongolian", "myanmar", "oriya", "persian",
+ "lower-roman", "upper-roman", "tamil", "telugu", "thai", "tibetan",
+ "lower-alpha", "lower-latin", "upper-alpha", "upper-latin",
+ "cjk-earthly-branch", "cjk-heavenly-stem", "lower-greek",
+ "hiragana", "hiragana-iroha", "katakana", "katakana-iroha",
+ "disc", "circle", "square", "disclosure-open", "disclosure-closed",
+ "japanese-informal", "japanese-formal",
+ "korean-hangul-formal", "korean-hanja-informal", "korean-hanja-formal",
+ "simp-chinese-informal", "simp-chinese-formal",
+ "trad-chinese-informal", "trad-chinese-formal", "cjk-ideographic",
+ "ethiopic-numeric", "symbols", "inherit", "initial", "unset", "revert", "revert-layer" ];
+ var values = InspectorUtils.getCSSValuesForProperty("list-style-type");
+ ok(testValues(values, expected), "property list-style-type's values");
+
+ // Regression test for bug 1696677.
+ var values = InspectorUtils.getCSSValuesForProperty("cursor");
+ ok(values.includes("url"), "property cursor values include url");
+ ok(values.includes("image-set"), "property cursor values include image-set");
+
+ SimpleTest.finish();
+}
+
+SimpleTest.waitForExplicitFinish();
+addLoadEvent(do_test);
+
+</script>
+</head>
+<body>
+<a target="_blank" href="https://bugzilla.mozilla.org/show_bug.cgi?id=877690">Mozilla Bug 877690</a>
+<p id="display"></p>
+<div id="content" style="display: none">
+</div>
+<pre id="test">
+</pre>
+</body>
+</html>