| Index: LayoutTests/fast/css-grid-layout/named-grid-line-get-set.html
|
| diff --git a/LayoutTests/fast/css-grid-layout/named-grid-line-get-set.html b/LayoutTests/fast/css-grid-layout/named-grid-line-get-set.html
|
| new file mode 100755
|
| index 0000000000000000000000000000000000000000..314653379ca262db6e146dcd79d30244966b1a3e
|
| --- /dev/null
|
| +++ b/LayoutTests/fast/css-grid-layout/named-grid-line-get-set.html
|
| @@ -0,0 +1,153 @@
|
| +<!DOCTYPE HTML>
|
| +<html>
|
| +<head>
|
| +<script>
|
| +if (window.testRunner)
|
| + testRunner.overridePreference("WebKitCSSGridLayoutEnabled", 1);
|
| +</script>
|
| +<link href="resources/grid.css" rel="stylesheet">
|
| +<style>
|
| +.gridWithFixed {
|
| + -webkit-grid-columns: "first" 10px;
|
| + -webkit-grid-rows: "first" 15px;
|
| +}
|
| +.gridWithPercent {
|
| + -webkit-grid-columns: 53% "last";
|
| + -webkit-grid-rows: 27% "last";
|
| +}
|
| +.gridWithAuto {
|
| + -webkit-grid-columns: "first" auto;
|
| + -webkit-grid-rows: auto "last";
|
| +}
|
| +.gridWithMinMax {
|
| + -webkit-grid-columns: "first" minmax(10%, 15px);
|
| + -webkit-grid-rows: minmax(20px, 50%) "last";
|
| +}
|
| +.gridWithFixedMultiple {
|
| + -webkit-grid-columns: "first" "nav" 10px "last";
|
| + -webkit-grid-rows: "first" "nav" 15px "last";
|
| +}
|
| +.gridWithPercentageSameStringMultipleTimes {
|
| + -webkit-grid-columns: "first" "nav" 10% "nav" 15% "last";
|
| + -webkit-grid-rows: "first" "nav2" 25% "nav2" 75% "last";
|
| +}
|
| +</style>
|
| +<script src="../js/resources/js-test-pre.js"></script>
|
| +</head>
|
| +<body>
|
| +<div class="grid gridWithFixed" id="gridWithFixedElement"></div>
|
| +<div class="grid gridWithPercent" id="gridWithPercentElement"></div>
|
| +<div class="grid gridWithAuto" id="gridWithAutoElement"></div>
|
| +<div class="grid gridWithMinMax" id="gridWithMinMax"></div>
|
| +<div class="grid gridWithFixedMultiple" id="gridWithFixedMultiple"></div>
|
| +<div class="grid gridWithPercentageSameStringMultipleTimes" id="gridWithPercentageSameStringMultipleTimes"></div>
|
| +<script>
|
| + description('Test that setting and getting grid-columns and grid-rows works as expected');
|
| +
|
| + function testValue(gridElement, namedGridColumns, namedGridRows)
|
| + {
|
| + this.gridElement = gridElement;
|
| + shouldBeEqualToString("getComputedStyle(gridElement, '').getPropertyValue('-webkit-grid-columns')", namedGridColumns);
|
| + shouldBeEqualToString("getComputedStyle(gridElement, '').getPropertyValue('-webkit-grid-rows')", namedGridRows);
|
| + }
|
| +
|
| + function testCSSValue(gridElementId, namedGridColumns, namedGridRows)
|
| + {
|
| + testValue(document.getElementById(gridElementId), namedGridColumns, namedGridRows);
|
| + }
|
| +
|
| + debug("Test getting -webkit-grid-columns and -webkit-grid-rows set through CSS");
|
| + testCSSValue("gridWithFixedElement", "first 10px", "first 15px");
|
| + testCSSValue("gridWithPercentElement", "53% last", "27% last");
|
| + testCSSValue("gridWithAutoElement", "first auto", "auto last");
|
| + testCSSValue("gridWithMinMax", "first minmax(10%, 15px)", "minmax(20px, 50%) last");
|
| + testCSSValue("gridWithFixedMultiple", "nav first 10px last", "nav first 15px last");
|
| + testCSSValue("gridWithPercentageSameStringMultipleTimes", "nav first 10% nav 15% last", "first nav2 25% nav2 75% last");
|
| +
|
| + debug("");
|
| + debug("Test getting and setting -webkit-grid-columns and -webkit-grid-rows through JS");
|
| + var element = document.createElement("div");
|
| + document.body.appendChild(element);
|
| + element.style.webkitGridColumns = "'first' 18px";
|
| + element.style.webkitGridRows = "66px 'last'";
|
| + testValue(element, "first 18px", "66px last");
|
| +
|
| + element = document.createElement("div");
|
| + document.body.appendChild(element);
|
| + element.style.webkitGridColumns = "'first' 55%";
|
| + element.style.webkitGridRows = "40% 'last'";
|
| + testValue(element, "first 55%", "40% last");
|
| +
|
| + element = document.createElement("div");
|
| + document.body.appendChild(element);
|
| + element.style.webkitGridColumns = "'first' auto";
|
| + element.style.webkitGridRows = "auto 'last'";
|
| + testValue(element, "first auto", "auto last");
|
| +
|
| + element = document.createElement("div");
|
| + document.body.appendChild(element);
|
| + element.style.webkitGridColumns = "'first' -webkit-min-content";
|
| + element.style.webkitGridRows = "-webkit-min-content 'last'";
|
| + testValue(element, "first -webkit-min-content", "-webkit-min-content last");
|
| +
|
| + element = document.createElement("div");
|
| + document.body.appendChild(element);
|
| + element.style.webkitGridColumns = "'first' -webkit-max-content";
|
| + element.style.webkitGridRows = "-webkit-max-content 'last'";
|
| + testValue(element, "first -webkit-max-content", "-webkit-max-content last");
|
| +
|
| + element = document.createElement("div");
|
| + document.body.appendChild(element);
|
| + element.style.webkitGridColumns = "'first' minmax(55%, 45px)";
|
| + element.style.webkitGridRows = "minmax(30px, 40%) 'last'";
|
| + testValue(element, "first minmax(55%, 45px)", "minmax(30px, 40%) last");
|
| +
|
| + element = document.createElement("div");
|
| + document.body.appendChild(element);
|
| + element.style.font = "10px Ahem";
|
| + element.style.webkitGridColumns = "'first' minmax(22em, -webkit-max-content)";
|
| + element.style.webkitGridRows = "minmax(-webkit-max-content, 5em) 'last'";
|
| + testValue(element, "first minmax(220px, -webkit-max-content)", "minmax(-webkit-max-content, 50px) last");
|
| +
|
| + element = document.createElement("div");
|
| + document.body.appendChild(element);
|
| + element.style.font = "10px Ahem";
|
| + element.style.webkitGridColumns = "'first' minmax(22em, -webkit-max-content)";
|
| + element.style.webkitGridRows = "minmax(-webkit-max-content, 5em) 'last'";
|
| + testValue(element, "first minmax(220px, -webkit-max-content)", "minmax(-webkit-max-content, 50px) last");
|
| +
|
| + element = document.createElement("div");
|
| + document.body.appendChild(element);
|
| + element.style.webkitGridColumns = "'first' minmax(-webkit-min-content, -webkit-max-content)";
|
| + element.style.webkitGridRows = "minmax(-webkit-max-content, -webkit-min-content) 'last'";
|
| + testValue(element, "first minmax(-webkit-min-content, -webkit-max-content)", "minmax(-webkit-max-content, -webkit-min-content) last");
|
| +
|
| + element = document.createElement("div");
|
| + document.body.appendChild(element);
|
| + element.style.webkitGridColumns = "'first' 'nav' minmax(-webkit-min-content, -webkit-max-content) 'last'";
|
| + element.style.webkitGridRows = "'first' 'nav' minmax(-webkit-max-content, -webkit-min-content) 'last'";
|
| + testValue(element, "nav first minmax(-webkit-min-content, -webkit-max-content) last", "nav first minmax(-webkit-max-content, -webkit-min-content) last");
|
| +
|
| + element = document.createElement("div");
|
| + document.body.appendChild(element);
|
| + element.style.webkitGridColumns = "'first' 'nav' minmax(-webkit-min-content, -webkit-max-content) 'nav' auto 'last'";
|
| + element.style.webkitGridRows = "'first' 'nav2' minmax(-webkit-max-content, -webkit-min-content) 'nav2' minmax(10px, 15px) 'last'";
|
| + testValue(element, "nav first minmax(-webkit-min-content, -webkit-max-content) nav auto last", "first nav2 minmax(-webkit-max-content, -webkit-min-content) nav2 minmax(10px, 15px) last");
|
| +
|
| + element = document.createElement("div");
|
| + document.body.appendChild(element);
|
| + element.style.webkitGridColumns = "'foo' 'bar' auto 'foo' auto 'bar'";
|
| + element.style.webkitGridRows = "'foo' 'bar' auto 'foo' auto 'bar'";
|
| + testValue(element, "foo bar auto foo auto bar", "foo bar auto foo auto bar");
|
| +
|
| + debug("");
|
| + debug("Test getting and setting invalid -webkit-grid-columns and -webkit-grid-rows through JS");
|
| + element = document.createElement("div");
|
| + document.body.appendChild(element);
|
| + element.style.webkitGridColumns = "'foo'";
|
| + element.style.webkitGridRows = "'bar";
|
| + testValue(element, "none", "none");
|
| +</script>
|
| +<script src="../js/resources/js-test-post.js"></script>
|
| +</body>
|
| +</html>
|
|
|