summaryrefslogtreecommitdiffstats
path: root/testing/web-platform/tests/css/css-cascade/layer-vs-inline-style.html
diff options
context:
space:
mode:
Diffstat (limited to 'testing/web-platform/tests/css/css-cascade/layer-vs-inline-style.html')
-rw-r--r--testing/web-platform/tests/css/css-cascade/layer-vs-inline-style.html60
1 files changed, 60 insertions, 0 deletions
diff --git a/testing/web-platform/tests/css/css-cascade/layer-vs-inline-style.html b/testing/web-platform/tests/css/css-cascade/layer-vs-inline-style.html
new file mode 100644
index 0000000000..9ddfbc3907
--- /dev/null
+++ b/testing/web-platform/tests/css/css-cascade/layer-vs-inline-style.html
@@ -0,0 +1,60 @@
+<!DOCTYPE html>
+<link rel="help" href="https://drafts.csswg.org/css-cascade-5/#cascade-sort">
+<link rel="author" title="Xiaocheng Hu" href="mailto:xiaochengh@chromium.org">
+<script src="/resources/testharness.js"></script>
+<script src="/resources/testharnessreport.js"></script>
+<style>
+#target, #reference {
+ width: 100px;
+ height: 100px;
+}
+
+#reference {
+ background-color: green;
+}
+</style>
+
+<div id="target"></div>
+<div id="reference"></div>
+
+<script>
+// In all tests, #target should have green background color, same as #reference
+
+const testCases = [
+ {
+ title: 'Normal inline style > normal layered style',
+ style: '@layer { #target { background-color: red; }}',
+ inlineStyle: 'background-color: green'
+ },
+ {
+ title: 'Normal inline style < important layered style',
+ style: '@layer { #target { background-color: green !important; }}',
+ inlineStyle: 'background-color: red'
+ },
+ {
+ title: 'Important inline style > normal layered style',
+ style: '@layer { #target { background-color: red; }}',
+ inlineStyle: 'background-color: green !important'
+ },
+ {
+ title: 'Important inline style > important layered style',
+ style: '@layer { #target { background-color: red !important; }}',
+ inlineStyle: 'background-color: green !important'
+ },
+];
+
+for (let testCase of testCases) {
+ var documentStyle = document.createElement('style');
+ documentStyle.appendChild(document.createTextNode(testCase['style']));
+ document.head.appendChild(documentStyle);
+
+ target.style = testCase['inlineStyle'];
+
+ test(function () {
+ assert_equals(getComputedStyle(target).backgroundColor,
+ getComputedStyle(reference).backgroundColor);
+ }, testCase['title']);
+
+ documentStyle.remove();
+}
+</script>