diff options
author | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-07 19:33:14 +0000 |
---|---|---|
committer | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-07 19:33:14 +0000 |
commit | 36d22d82aa202bb199967e9512281e9a53db42c9 (patch) | |
tree | 105e8c98ddea1c1e4784a60a5a6410fa416be2de /testing/web-platform/tests/css/cssom/variable-names.html | |
parent | Initial commit. (diff) | |
download | firefox-esr-36d22d82aa202bb199967e9512281e9a53db42c9.tar.xz firefox-esr-36d22d82aa202bb199967e9512281e9a53db42c9.zip |
Adding upstream version 115.7.0esr.upstream/115.7.0esr
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'testing/web-platform/tests/css/cssom/variable-names.html')
-rw-r--r-- | testing/web-platform/tests/css/cssom/variable-names.html | 48 |
1 files changed, 48 insertions, 0 deletions
diff --git a/testing/web-platform/tests/css/cssom/variable-names.html b/testing/web-platform/tests/css/cssom/variable-names.html new file mode 100644 index 0000000000..5591411e6e --- /dev/null +++ b/testing/web-platform/tests/css/cssom/variable-names.html @@ -0,0 +1,48 @@ +<!DOCTYPE html> +<meta charset="utf-8"> +<title>Tests for handling of CSS Custom Property names</title> +<link rel="help" href="https://drafts.csswg.org/css-variables/#serializing-custom-props"> +<meta name="author" title="Cameron McCormack" href="mailto:cam@mcc.id.au"> +<script src="/resources/testharness.js"></script> +<script src="/resources/testharnessreport.js"></script> +<div id="log"></div> +<script> + +// Valid custom property names, before and after CSS escaping. +var valid_names = [ + ["--a", "--a"], + ["--a;b", "--a\\;b"], + ["---", "---"], + ["--\\", "--\\\\"], + ["--ab", "--\\61 b"], + ["--0", "--\\30 "], +]; + +valid_names.forEach(function(t) { + var name = t[0]; + var escaped_name = t[1]; + + test(function() { + var e = document.createElement("span"); + e.style = escaped_name + ":value"; + + for (var after_refeeding = 0; after_refeeding <= 1; ++after_refeeding) { + var desc_suffix = (after_refeeding ? " (after " : " (before ") + + "serialization/re-parsing)"; + + assert_equals(e.style.length, 1, + "appears on specified style" + desc_suffix); + + assert_equals(e.style[0], name, + "name returned correctly from specified " + + "style indexed getter" + desc_suffix); + + assert_equals(e.style.getPropertyValue(name), "value", + "property value returned correctly from " + + "specified style getPropertyValue" + desc_suffix); + + e.style = e.style.cssText; + } + }, "custom property '" + name + "'"); +}); +</script> |