mirror of
https://github.com/servo/servo.git
synced 2025-08-15 02:15:33 +01:00
Update web-platform-tests to revision 5ca972e15cfa80277964645d9ee5ccd87a661337
This commit is contained in:
parent
072badabac
commit
908e01b499
30 changed files with 811 additions and 289 deletions
|
@ -66,12 +66,6 @@ function assert_style_value_equals(a, b) {
|
|||
case 'CSSMatrixComponent':
|
||||
assert_matrix_approx_equals(a.matrix, b.matrix, 1e-6);
|
||||
break;
|
||||
case 'CSSURLImageValue':
|
||||
assert_equals(a.instrinsicWidth, b.instrinsicWidth);
|
||||
assert_equals(a.instrinsicHeight, b.instrinsicHeight);
|
||||
assert_equals(a.instrinsicRatio, b.instrinsicRatio);
|
||||
assert_equals(a.url, b.url);
|
||||
break;
|
||||
default:
|
||||
assert_equals(a, b);
|
||||
break;
|
||||
|
|
|
@ -0,0 +1,30 @@
|
|||
<!doctype html>
|
||||
<meta charset="utf-8">
|
||||
<title>CSSImageValue normalization tests</title>
|
||||
<link rel="help" href="https://drafts.css-houdini.org/css-typed-om-1/#resourcevalue-normalization">
|
||||
<script src="/resources/testharness.js"></script>
|
||||
<script src="/resources/testharnessreport.js"></script>
|
||||
<script src="../resources/testhelper.js"></script>
|
||||
<body>
|
||||
<script>
|
||||
'use strict';
|
||||
|
||||
const gTestUrl = '/media/1x1-green.png';
|
||||
const gBadTestUrl = document.location.href;
|
||||
|
||||
test(t => {
|
||||
const result = CSSStyleValue.parse('background-image', 'url("' + gTestUrl + '")');
|
||||
assert_class_string(result, 'CSSImageValue');
|
||||
}, 'Normalizing a valid <url> returns a CSSImageValue');
|
||||
|
||||
test(t => {
|
||||
const result = CSSStyleValue.parse('background-image', 'url("' + gBadTestUrl + '")');
|
||||
assert_class_string(result, 'CSSImageValue');
|
||||
}, 'Normalizing a bad <url> returns a CSSImageValue');
|
||||
|
||||
test(t => {
|
||||
const result = CSSStyleValue.parse('background-image', 'linear-gradient(red, orange)');
|
||||
assert_equals(result.constructor.name, 'CSSImageValue');
|
||||
}, 'Normalizing a <gradient> returns a CSSImageValue');
|
||||
|
||||
</script>
|
|
@ -1,56 +0,0 @@
|
|||
<!doctype html>
|
||||
<meta charset="utf-8">
|
||||
<title>CSSResourceValue normalization tests</title>
|
||||
<link rel="help" href="https://drafts.css-houdini.org/css-typed-om-1/#resourcevalue-normalization">
|
||||
<script src="/resources/testharness.js"></script>
|
||||
<script src="/resources/testharnessreport.js"></script>
|
||||
<script src="../resources/testhelper.js"></script>
|
||||
<body>
|
||||
<script>
|
||||
'use strict';
|
||||
|
||||
const gTestUrl = '/media/1x1-green.png';
|
||||
const gBadTestUrl = document.location.href;
|
||||
|
||||
async_test(t => {
|
||||
const result = CSSStyleValue.parse('background-image', 'url("' + gTestUrl + '")');
|
||||
assert_equals(result.constructor.name, 'CSSURLImageValue');
|
||||
assert_equals(result.intrinsicWidth, null);
|
||||
assert_equals(result.intrinsicHeight, null);
|
||||
assert_equals(result.intrinsicRatio, null);
|
||||
assert_equals(result.state, 'unloaded');
|
||||
|
||||
let image = loadImageResource(t, result);
|
||||
image.addEventListener('load', t.step_func_done(() => {
|
||||
assert_equals(result.url, gTestUrl);
|
||||
assert_equals(result.state, 'loaded');
|
||||
assert_equals(result.intrinsicWidth, 1);
|
||||
assert_equals(result.intrinsicHeight, 1);
|
||||
assert_equals(result.intrinsicRatio, 1);
|
||||
}));
|
||||
}, 'Normalizing a valid <url> returns a CSSURLImageValue that eventually loads');
|
||||
|
||||
async_test(t => {
|
||||
const result = CSSStyleValue.parse('background-image', 'url("' + gBadTestUrl + '")');
|
||||
assert_equals(result.constructor.name, 'CSSURLImageValue');
|
||||
|
||||
let image = loadImageResource(t, result);
|
||||
image.addEventListener('error', t.step_func_done(() => {
|
||||
assert_equals(result.url, gBadTestUrl);
|
||||
assert_equals(result.state, 'error');
|
||||
assert_equals(result.intrinsicWidth, null);
|
||||
assert_equals(result.intrinsicHeight, null);
|
||||
assert_equals(result.intrinsicRatio, null);
|
||||
}));
|
||||
}, 'Normalizing a bad <url> returns a CSSURLImageValue in error state');
|
||||
|
||||
test(t => {
|
||||
const result = CSSStyleValue.parse('background-image', 'linear-gradient(red, orange)');
|
||||
assert_equals(result.constructor.name, 'CSSImageValue');
|
||||
assert_equals(result.state, 'loaded');
|
||||
assert_equals(result.intrinsicWidth, null);
|
||||
assert_equals(result.intrinsicHeight, null);
|
||||
assert_equals(result.intrinsicRatio, null);
|
||||
}, 'Normalizing a <gradient> returns a CSSImageValue');
|
||||
|
||||
</script>
|
|
@ -0,0 +1,19 @@
|
|||
<!doctype html>
|
||||
<meta charset="utf-8">
|
||||
<title>CSSURLImageValue serialization tests</title>
|
||||
<link rel="help" href="https://drafts.css-houdini.org/css-typed-om-1/#urlimagevalue-serialization">
|
||||
<script src="/resources/testharness.js"></script>
|
||||
<script src="/resources/testharnessreport.js"></script>
|
||||
<script src="../resources/testhelper.js"></script>
|
||||
<body>
|
||||
<div id="log"></div>
|
||||
<div id="testUrl" style="background-image: url('/media/1x1-green.png')"></div>
|
||||
<script>
|
||||
'use strict';
|
||||
|
||||
test(() => {
|
||||
const result = document.getElementById('testUrl').attributeStyleMap.get('background-image');
|
||||
assert_equals(result.toString(), 'url("/media/1x1-green.png")');
|
||||
}, 'CSSUrlImageValue serializes correctly');
|
||||
|
||||
</script>
|
|
@ -1,15 +0,0 @@
|
|||
<!doctype html>
|
||||
<meta charset="utf-8">
|
||||
<title>IDL-constructed CSSURLImageValue serialization tests</title>
|
||||
<link rel="help" href="https://drafts.css-houdini.org/css-typed-om-1/#urlimagevalue-serialization">
|
||||
<script src="/resources/testharness.js"></script>
|
||||
<script src="/resources/testharnessreport.js"></script>
|
||||
<script src="../resources/testhelper.js"></script>
|
||||
<script>
|
||||
'use strict';
|
||||
|
||||
test(() => {
|
||||
assert_equals(new CSSURLImageValue('http://foo.bar').toString(), 'url("http://foo.bar")');
|
||||
}, 'CSSUrlImageValue constructed from IDL serializes correctly');
|
||||
|
||||
</script>
|
|
@ -1,22 +0,0 @@
|
|||
<!doctype html>
|
||||
<meta charset=utf-8>
|
||||
<title>CSSURLImageValue IDL</title>
|
||||
<link rel="help" href="https://drafts.css-houdini.org/css-typed-om-1/#cssurlimagevalue">
|
||||
<script src="/resources/testharness.js"></script>
|
||||
<script src="/resources/testharnessreport.js"></script>
|
||||
<script src="/resources/WebIDLParser.js"></script>
|
||||
<script src="/resources/idlharness.js"></script>
|
||||
<script type="text/plain" id="idl">
|
||||
[Exposed=(Window, Worker, PaintWorklet, LayoutWorklet),
|
||||
Constructor(USVString url)]
|
||||
interface CSSURLImageValue : CSSImageValue {
|
||||
readonly attribute USVString url;
|
||||
};
|
||||
</script>
|
||||
<script>
|
||||
'use strict';
|
||||
const idlArray = new IdlArray();
|
||||
idlArray.add_untested_idls('interface CSSImageValue { stringifier; };');
|
||||
idlArray.add_idls(document.getElementById('idl').textContent);
|
||||
idlArray.test();
|
||||
</script>
|
|
@ -1,17 +0,0 @@
|
|||
<!doctype html>
|
||||
<meta charset="utf-8">
|
||||
<title>CSSURLImageValue Error Handling</title>
|
||||
<link rel="help" href="https://drafts.css-houdini.org/css-typed-om-1/#imagevalue-objects">
|
||||
<meta name="assert" content="Test CSSURLImageValue constructor error handling" />
|
||||
<script src="/resources/testharness.js"></script>
|
||||
<script src="/resources/testharnessreport.js"></script>
|
||||
<body>
|
||||
<div id="log">
|
||||
<script>
|
||||
'use strict';
|
||||
|
||||
test(() => {
|
||||
assert_throws(new TypeError(), () => new CSSURLImageValue("file://:invalid url"));
|
||||
}, 'Constructing a CSSURLImageValue with an invalid URL throws a TypeError');
|
||||
|
||||
</script>
|
|
@ -1,81 +0,0 @@
|
|||
<!doctype html>
|
||||
<meta charset="utf-8">
|
||||
<title>CSSURLImageValue</title>
|
||||
<link rel="help" href="https://drafts.css-houdini.org/css-typed-om-1/#imagevalue-objects">
|
||||
<meta name="assert" content="Test CSSURLImageValue constructor and attributes" />
|
||||
<script src="/resources/testharness.js"></script>
|
||||
<script src="/resources/testharnessreport.js"></script>
|
||||
<script src="../resources/testhelper.js"></script>
|
||||
<body>
|
||||
<div id="log">
|
||||
<script>
|
||||
'use strict';
|
||||
|
||||
const gTestUrl = '/media/1x1-green.png';
|
||||
const gBase64TestUrl = '';
|
||||
const gBadTestUrl = document.location.href;
|
||||
|
||||
test(() => {
|
||||
const result = new CSSURLImageValue(gTestUrl);
|
||||
|
||||
assert_not_equals(result, null,
|
||||
'A CSSURLImageValue should be created');
|
||||
assert_equals(result.url, gTestUrl,
|
||||
'url member should be same as passed in the constructor');
|
||||
assert_equals(result.intrinsicWidth, null, 'intrinsicWidth');
|
||||
assert_equals(result.intrinsicHeight, null, 'intrinsicHeight');
|
||||
assert_equals(result.intrinsicRatio, null, 'intrinsicRatio');
|
||||
assert_equals(result.state, 'unloaded', 'state');
|
||||
}, 'Constructing a CSSURLImageValue with a valid URL puts it in an ' +
|
||||
'unloaded state');
|
||||
|
||||
async_test(t => {
|
||||
const result = new CSSURLImageValue(gTestUrl);
|
||||
let image = loadImageResource(t, result);
|
||||
|
||||
image.addEventListener('load', t.step_func_done(() => {
|
||||
assert_equals(result.url, gTestUrl,
|
||||
'url member should be same as passed in the constructor');
|
||||
assert_equals(result.state, 'loaded', 'state');
|
||||
assert_equals(result.intrinsicWidth, 1,
|
||||
'intrinsicWidth member should be width of loaded image');
|
||||
assert_equals(result.intrinsicHeight, 1,
|
||||
'intrinsicHeight member should be height of loaded image');
|
||||
assert_equals(result.intrinsicRatio, 1,
|
||||
'intrinsicRatio member should be ratio of loaded image');
|
||||
}));
|
||||
}, 'Constructing a CSSURLImageValue from a URL sets its state to loaded');
|
||||
|
||||
async_test(t => {
|
||||
const result = new CSSURLImageValue(gBase64TestUrl);
|
||||
let image = loadImageResource(t, result);
|
||||
|
||||
image.addEventListener('load', t.step_func_done(() => {
|
||||
assert_equals(result.url, gBase64TestUrl,
|
||||
'url member should be same as passed in the constructor');
|
||||
assert_equals(result.state, 'loaded', 'state');
|
||||
assert_equals(result.intrinsicWidth, 1,
|
||||
'intrinsicWidth member should be width of loaded image');
|
||||
assert_equals(result.intrinsicHeight, 1,
|
||||
'intrinsicHeight member should be height of loaded image');
|
||||
assert_equals(result.intrinsicRatio, 1,
|
||||
'intrinsicRatio member should be ratio of loaded image');
|
||||
}));
|
||||
}, 'Constructing a CSSURLImageValue from a base64 URL sets its state to loaded');
|
||||
|
||||
async_test(t => {
|
||||
const result = new CSSURLImageValue(gBadTestUrl);
|
||||
let image = loadImageResource(t, result);
|
||||
|
||||
image.addEventListener('error', t.step_func_done(() => {
|
||||
assert_equals(result.url, gBadTestUrl,
|
||||
'url member should be same as passed in the constructor');
|
||||
assert_equals(result.state, 'error', 'state');
|
||||
assert_equals(result.intrinsicWidth, null, 'intrinsicWidth');
|
||||
assert_equals(result.intrinsicHeight, null, 'intrinsicHeight');
|
||||
assert_equals(result.intrinsicRatio, null, 'intrinsicRatio');
|
||||
}));
|
||||
}, 'Constructing a CSSURLImageValue from a URL to an invalid image sets ' +
|
||||
'its state to error');
|
||||
|
||||
</script>
|
|
@ -145,22 +145,6 @@ const gTestSyntaxExamples = {
|
|||
}
|
||||
],
|
||||
},
|
||||
'<image>': {
|
||||
description: 'an image',
|
||||
examples: [
|
||||
{
|
||||
description: "a PNG image",
|
||||
input: new CSSURLImageValue('/media/1x1.png'),
|
||||
defaultComputed: (_, result) => {
|
||||
// URLs compute to absolute URLs
|
||||
assert_true(result instanceof CSSURLImageValue,
|
||||
'Computed value should be a CSSURLImageValue');
|
||||
assert_true(result.url.endsWith('/media/1x1.png'),
|
||||
'Computed value should be an absolute URL');
|
||||
}
|
||||
}
|
||||
],
|
||||
},
|
||||
'<transform>': {
|
||||
description: 'a transform',
|
||||
examples: [
|
||||
|
@ -218,6 +202,24 @@ function testPropertyValid(propertyName, examples, specified, computed, descript
|
|||
}, `Can set '${propertyName}' to ${description}`);
|
||||
}
|
||||
|
||||
// We have to special case CSSImageValue as they cannot be created with a
|
||||
// constructor and are completely opaque.
|
||||
function testIsImageValidForProperty(propertyName) {
|
||||
test(t => {
|
||||
let element1 = createDivWithStyle(t, `${propertyName}: url("/media/1x1-green.png")`);
|
||||
let element2 = createDivWithStyle(t);
|
||||
|
||||
const result = element1.attributeStyleMap.get(propertyName);
|
||||
assert_not_equals(result, null, 'Image value must not be null');
|
||||
assert_class_string(result, 'CSSImageValue',
|
||||
'Image value must be a CSSImageValue');
|
||||
|
||||
element2.attributeStyleMap.set(propertyName, result);
|
||||
assert_equals(element2.style[propertyName], element1.style[propertyName],
|
||||
'Image value can be set on different element');
|
||||
}, `Can set '${propertyName}' to an image`);
|
||||
}
|
||||
|
||||
// Test that styleMap.set throws for invalid values
|
||||
function testPropertyInvalid(propertyName, examples, description) {
|
||||
test(t => {
|
||||
|
@ -289,6 +291,12 @@ function runPropertyTests(propertyName, testCases) {
|
|||
'CSS-wide keywords');
|
||||
|
||||
for (const testCase of testCases) {
|
||||
// <image> is a special case
|
||||
if (testCase.syntax === '<image>') {
|
||||
testIsImageValidForProperty(propertyName);
|
||||
continue;
|
||||
}
|
||||
|
||||
// Retrieve test examples for this test case's syntax. If the syntax
|
||||
// looks like a keyword, then create an example on the fly.
|
||||
const syntaxExamples = testCase.syntax.match(/^[a-z\-]+$/) ?
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue