119 lines
9.1 KiB
HTML
119 lines
9.1 KiB
HTML
<!DOCTYPE html>
|
|
<html>
|
|
<head>
|
|
<script src="../../resources/js-test-pre.js"></script>
|
|
</head>
|
|
<body>
|
|
<script>
|
|
|
|
function testGradient(css)
|
|
{
|
|
var div = document.createElement('div');
|
|
div.setAttribute('style', css);
|
|
document.body.appendChild(div);
|
|
|
|
var result = getComputedStyle(div).backgroundImage;
|
|
document.body.removeChild(div);
|
|
return result;
|
|
}
|
|
|
|
debug('<p>linear-gradient</p>');
|
|
|
|
shouldBe('testGradient("background-image: linear-gradient(black 0%)")', '"none"');
|
|
shouldBe('testGradient("background-image: linear-gradient(top)")', '"none"');
|
|
shouldBe('testGradient("background-image: linear-gradient(to top)")', '"none"');
|
|
shouldBe('testGradient("background-image: linear-gradient(10deg)")', '"none"');
|
|
shouldBe('testGradient("background-image: linear-gradient(10deg black, white)")', '"none"');
|
|
shouldBe('testGradient("background-image: linear-gradient(to black, white)")', '"none"');
|
|
shouldBe('testGradient("background-image: linear-gradient(to left black, white)")', '"none"');
|
|
shouldBe('testGradient("background-image: linear-gradient(to top center, black 0%, white)")', '"none"');
|
|
shouldBe('testGradient("background-image: linear-gradient(10px 20%, black 0%)")', '"none"');
|
|
shouldBe('testGradient("background-image: linear-gradient(to left left)")', '"none"');
|
|
shouldBe('testGradient("background-image: linear-gradient(to left center)")', '"none"');
|
|
shouldBe('testGradient("background-image: linear-gradient(to left 10deg, black 0%, white)")', '"none"');
|
|
shouldBe('testGradient("background-image: linear-gradient(black)")', '"none"');
|
|
shouldBe('testGradient("background-image: linear-gradient(10deg, black 0%, 25%, 50%, white)")', '"none"');
|
|
shouldBe('testGradient("background-image: linear-gradient(10deg, black 0%, 50%)")', '"none"');
|
|
shouldBe('testGradient("background-image: linear-gradient(10deg, 50%, white)")', '"none"');
|
|
shouldBe('testGradient("background-image: linear-gradient(10deg, 0%, black, white)")', '"none"');
|
|
shouldBe('testGradient("background-image: linear-gradient(10deg, white, black, 80%)")', '"none"');
|
|
shouldBe('testGradient("background-image: linear-gradient(10deg, black, , white)")', '"none"');
|
|
|
|
shouldBe('testGradient("background-image: linear-gradient(black, white)")', '"linear-gradient(black, white)"');
|
|
shouldBe('testGradient("background-image: linear-gradient(black 0, white)")', '"linear-gradient(black 0px, white)"');
|
|
shouldBe('testGradient("background-image: linear-gradient(black 0%, white)")', '"linear-gradient(black 0%, white)"');
|
|
shouldBe('testGradient("background-image: linear-gradient(black 0%, white)")', '"linear-gradient(black 0%, white)"');
|
|
shouldBe('testGradient("background-image: linear-gradient(black 10px, white 20px)")', '"linear-gradient(black 10px, white 20px)"');
|
|
shouldBe('testGradient("background-image: linear-gradient(to top left, black 0%, white)")', '"linear-gradient(to left top, black 0%, white)"');
|
|
shouldBe('testGradient("background-image: linear-gradient(to top, black 0%, white)")', '"linear-gradient(to top, black 0%, white)"');
|
|
shouldBe('testGradient("background-image: linear-gradient(10deg, black 0%, white)")', '"linear-gradient(10deg, black 0%, white)"');
|
|
|
|
shouldBe('testGradient("background-image: linear-gradient(10deg, black 0%, 25%, white)")', '"linear-gradient(10deg, black 0%, 25%, white)"');
|
|
shouldBe('testGradient("background-image: linear-gradient(10deg, black 0%, 0%, white)")', '"linear-gradient(10deg, black 0%, 0%, white)"');
|
|
shouldBe('testGradient("background-image: linear-gradient(10deg, black 0%, 100%, white)")', '"linear-gradient(10deg, black 0%, 100%, white)"');
|
|
shouldBe('testGradient("background-image: linear-gradient(10deg, black 0%, 50%, green 50%, 50%, white)")', '"linear-gradient(10deg, black 0%, 50%, green 50%, 50%, white)"');
|
|
|
|
var s = "linear-gradient(";
|
|
for(var x = 0; x < 500; x++)
|
|
s += "white " + (x/500) + "%, " + ((2 * x + 1) / 1000) + "%, ";
|
|
s += "black)";
|
|
shouldBe('testGradient("background-image: ' + s + '")', '"' + s + '"');
|
|
|
|
debug('<p>repeating-linear-gradient</p>');
|
|
shouldBe('testGradient("background-image: repeating-linear-gradient(black, white)")', '"repeating-linear-gradient(black, white)"');
|
|
shouldBe('testGradient("background-image: repeating-linear-gradient(black, 35%, white)")', '"repeating-linear-gradient(black, 35%, white)"');
|
|
|
|
debug('<p>radial-gradient</p>');
|
|
|
|
shouldBe('testGradient("background-image: radial-gradient(white, black)")', '"radial-gradient(white, black)"');
|
|
shouldBe('testGradient("background-image: radial-gradient(at bottom right, white, black)")', '"radial-gradient(at right bottom, white, black)"');
|
|
shouldBe('testGradient("background-image: radial-gradient(farthest-corner, white, black)")', '"radial-gradient(white, black)"');
|
|
shouldBe('testGradient("background-image: radial-gradient(farthest-corner, white, 35%, black)")', '"radial-gradient(white, 35%, black)"');
|
|
shouldBe('testGradient("background-image: radial-gradient(closest-side, white, black)")', '"radial-gradient(closest-side, white, black)"');
|
|
shouldBe('testGradient("background-image: radial-gradient(ellipse, white, black)")', '"radial-gradient(white, black)"');
|
|
shouldBe('testGradient("background-image: radial-gradient(ellipse farthest-corner, white, black)")', '"radial-gradient(white, black)"');
|
|
shouldBe('testGradient("background-image: radial-gradient(ellipse closest-side, white, black)")', '"radial-gradient(closest-side, white, black)"');
|
|
shouldBe('testGradient("background-image: radial-gradient(circle, white, black)")', '"radial-gradient(circle, white, black)"');
|
|
shouldBe('testGradient("background-image: radial-gradient(circle farthest-corner, white, black)")', '"radial-gradient(circle, white, black)"');
|
|
shouldBe('testGradient("background-image: radial-gradient(circle closest-side, white, black)")', '"radial-gradient(circle closest-side, white, black)"');
|
|
shouldBe('testGradient("background-image: radial-gradient(circle closest-side at top, white, black)")', '"radial-gradient(circle closest-side at center top, white, black)"');
|
|
shouldBe('testGradient("background-image: radial-gradient(circle closest-side at top left, white, black)")', '"radial-gradient(circle closest-side at left top, white, black)"');
|
|
shouldBe('testGradient("background-image: radial-gradient(circle closest-side at 10px 20%, white, black)")', '"radial-gradient(circle closest-side at 10px 20%, white, black)"');
|
|
shouldBe('testGradient("background-image: radial-gradient(at 10px 20% circle closest-side, white, black)")', '"none"');
|
|
shouldBe('testGradient("background-image: radial-gradient(circle at 10px 20% circle, white, black)")', '"none"');
|
|
shouldBe('testGradient("background-image: radial-gradient(circle 10px closest-side, white, black)")', '"none"');
|
|
shouldBe('testGradient("background-image: radial-gradient(circle 10%, white, black)")', '"none"');
|
|
shouldBe('testGradient("background-image: radial-gradient(circle 10px 10px, white, black)")', '"none"');
|
|
shouldBe('testGradient("background-image: radial-gradient(ellipse 10%, white, black)")', '"none"');
|
|
shouldBe('testGradient("background-image: radial-gradient(ellipse 10px, white, black)")', '"none"');
|
|
shouldBe('testGradient("background-image: radial-gradient(25%, black)")', '"none"');
|
|
shouldBe('testGradient("background-image: radial-gradient(white, 25%)")', '"none"');
|
|
shouldBe('testGradient("background-image: radial-gradient(white, black, 25%)")', '"none"');
|
|
shouldBe('testGradient("background-image: radial-gradient(25%, white, black)")', '"none"');
|
|
shouldBe('testGradient("background-image: radial-gradient(white,, black)")', '"none"');
|
|
shouldBe('testGradient("background-image: radial-gradient(ellipse 10px, white, 25%, 75%, black)")', '"none"');
|
|
shouldBe('testGradient("background-image: radial-gradient(ellipse 10px 20px, white, black)")', '"radial-gradient(10px 20px, white, black)"');
|
|
shouldBe('testGradient("background-image: radial-gradient(circle 10px, white, black)")', '"radial-gradient(10px, white, black)"');
|
|
shouldBe('testGradient("background-image: radial-gradient(10px 10px at center, white, black)")', '"radial-gradient(10px 10px, white, black)"');
|
|
shouldBe('testGradient("background-image: radial-gradient(10px 10px at center, white, 50%, black)")', '"radial-gradient(10px 10px, white, 50%, black)"');
|
|
shouldBe('testGradient("background-image: radial-gradient(10px 10px at center, white, 0%, black)")', '"radial-gradient(10px 10px, white, 0%, black)"');
|
|
shouldBe('testGradient("background-image: radial-gradient(10px 10px at center, white, 100%, black)")', '"radial-gradient(10px 10px, white, 100%, black)"');
|
|
|
|
var s = "radial-gradient(10px 10px at 50% 50%, ";
|
|
for(var x = 0; x < 500; x++)
|
|
s += "white " + (x/500) + "%, " + ((2 * x + 1) / 1000) + "%, ";
|
|
s += "black)";
|
|
// Since we serialize to the shortest form, the default center position is removed from the computed value
|
|
var computedStr = s.replace(" at 50% 50%", "");
|
|
shouldBe('testGradient("background-image: ' + s + '")', '"' + computedStr + '"');
|
|
|
|
debug('<p>repeating-radial-gradient</p>');
|
|
shouldBe('testGradient("background-image: repeating-radial-gradient(white, black)")', '"repeating-radial-gradient(white, black)"');
|
|
shouldBe('testGradient("background-image: repeating-radial-gradient(white, 81%, black)")', '"repeating-radial-gradient(white, 81%, black)"');
|
|
|
|
</script>
|
|
|
|
<script src="../../resources/js-test-post.js"></script>
|
|
</body>
|
|
</html>
|