| <!DOCTYPE html> |
| <html lang="en"> |
| <head> |
| <meta charset="UTF-8"> |
| <title>Testing substituting variable references inside of variable declerations</title> |
| |
| <meta rel="author" title="Kevin Babbitt"> |
| <meta rel="author" title="Greg Whitworth"> |
| <link rel="author" title="Microsoft Corporation" href="http://microsoft.com" /> |
| <link rel="help" href="http://www.w3.org/TR/css-variables-1/#using-variables"> |
| |
| <script src="/resources/testharness.js"></script> |
| <script src="/resources/testharnessreport.js"></script> |
| <style> |
| #target1 { |
| margin: var(--var2); |
| --var2: var(--var1) 10px; |
| --var1: var(--var0) 13px 17px; |
| --var0: 23px; |
| } |
| |
| #target2parent { |
| --var2: var(--var1, fallback); |
| --var1: var(--var2, fallback); |
| } |
| #target2 { |
| --var1: good; |
| } |
| |
| #target3 { |
| --var2: var(--var1, 3px); |
| --var1: var(--var0, 5px); |
| } |
| |
| #target4 { |
| --varA: var(--varB); |
| --varB: var(--varA); |
| --varC: var(--varB,13px); |
| } |
| |
| #target5 { |
| --varA: var(--varB); |
| --varB: var(--varA) var(--varC); |
| --varC: var(--varB,13px); |
| } |
| |
| #target6 { |
| --varA: var(--varB); |
| --varB: var(--varA) var(--varDoesNotExist,var(--varC)); |
| --varC: var(--varB,13px); |
| } |
| |
| #target7 { |
| --varDoesExist: 5px; |
| --varA: var(--varB); |
| --varB: var(--varA) var(--varDoesExist,var(--varC)); |
| --varC: var(--varB,13px); |
| } |
| |
| #target8 { |
| --varA: var(--varA, 9px); |
| --varB: var(--varA, 7px); |
| } |
| |
| #target9 { |
| --varA: good; |
| --varB: very var(--varA, var(--varC)); |
| --varC: var(--varB); |
| } |
| |
| #target10parent { |
| --varA: good; |
| --varB: Also good; |
| --varC: another good one; |
| } |
| |
| #target10 { |
| --varA: var(--varB); |
| --varB: var(--varA); |
| --varC: var(--varB); |
| } |
| </style> |
| </head> |
| <body> |
| <div id="target1"></div> |
| <div id="target2parent"> |
| <div id="target2"></div> |
| </div> |
| <div id="target3"></div> |
| <div id="target4"></div> |
| <div id="target5"></div> |
| <div id="target6"></div> |
| <div id="target7"></div> |
| <div id="target8"></div> |
| <div id="target9"></div> |
| <div id="target10parent"> |
| <div id="target10"></div> |
| </div> |
| |
| <script type="text/javascript"> |
| "use strict"; |
| |
| var testcases = [ |
| { element: "target1", propertyName: "--var2", expectedPropertyValue: "23px 13px 17px 10px" }, |
| { element: "target1", propertyName: "margin-top", expectedPropertyValue: "23px" }, |
| { element: "target1", propertyName: "margin-right", expectedPropertyValue: "13px" }, |
| { element: "target1", propertyName: "margin-bottom", expectedPropertyValue: "17px" }, |
| { element: "target1", propertyName: "margin-left", expectedPropertyValue: "10px" }, |
| |
| { element: "target2parent", propertyName: "--var1", expectedPropertyValue: "" }, |
| { element: "target2parent", propertyName: "--var2", expectedPropertyValue: "" }, |
| { element: "target2", propertyName: "--var1", expectedPropertyValue: "good" }, |
| { element: "target2", propertyName: "--var2", expectedPropertyValue: "" }, |
| |
| { element: "target3", propertyName: "--var1", expectedPropertyValue: "5px" }, |
| { element: "target3", propertyName: "--var2", expectedPropertyValue: "5px" }, |
| |
| { element: "target4", propertyName: "--varA", expectedPropertyValue: "" }, |
| { element: "target4", propertyName: "--varB", expectedPropertyValue: "" }, |
| { element: "target4", propertyName: "--varC", expectedPropertyValue: "13px" }, |
| |
| { element: "target5", propertyName: "--varA", expectedPropertyValue: "" }, |
| { element: "target5", propertyName: "--varB", expectedPropertyValue: "" }, |
| { element: "target5", propertyName: "--varC", expectedPropertyValue: "" }, |
| |
| { element: "target6", propertyName: "--varA", expectedPropertyValue: "" }, |
| { element: "target6", propertyName: "--varB", expectedPropertyValue: "" }, |
| { element: "target6", propertyName: "--varC", expectedPropertyValue: "" }, |
| |
| { element: "target7", propertyName: "--varA", expectedPropertyValue: "" }, |
| { element: "target7", propertyName: "--varB", expectedPropertyValue: "" }, |
| { element: "target7", propertyName: "--varC", expectedPropertyValue: "" }, |
| |
| { element: "target8", propertyName: "--varA", expectedPropertyValue: "" }, |
| { element: "target8", propertyName: "--varB", expectedPropertyValue: "7px" }, |
| |
| { element: "target9", propertyName: "--varA", expectedPropertyValue: "good" }, |
| { element: "target9", propertyName: "--varB", expectedPropertyValue: "" }, |
| { element: "target9", propertyName: "--varC", expectedPropertyValue: "" }, |
| |
| { element: "target10", propertyName: "--varA", expectedPropertyValue: "" }, |
| { element: "target10", propertyName: "--varB", expectedPropertyValue: "" }, |
| { element: "target10", propertyName: "--varC", expectedPropertyValue: "" }, |
| ]; |
| |
| testcases.forEach(function (testcase) { |
| test( function () { |
| var div = document.getElementById(testcase.element); |
| var actualPropertyValue = window.getComputedStyle(div).getPropertyValue(testcase.propertyName); |
| assert_equals(actualPropertyValue, testcase.expectedPropertyValue); |
| }, testcase.element + " " + testcase.propertyName); |
| }); |
| </script> |
| </body> |
| </html> |