mirror of
https://github.com/servo/servo.git
synced 2025-08-07 06:25:32 +01:00
Update web-platform-tests to revision 097043b336e46876e281ddec3bb014fe9c480128
This commit is contained in:
parent
ecd32570c0
commit
b68253eac0
405 changed files with 9164 additions and 3050 deletions
|
@ -9,52 +9,55 @@
|
|||
<script src="/resources/testharness.js"></script>
|
||||
<script src="/resources/testharnessreport.js"></script>
|
||||
<script src="/mathml/support/feature-detection.js"></script>
|
||||
<script src="/mathml/support/attribute-values.js"></script>
|
||||
<script>
|
||||
function getBox(aId) {
|
||||
return document.getElementById(aId).getBoundingClientRect();
|
||||
}
|
||||
window.addEventListener("DOMContentLoaded", function() {
|
||||
var content = getBox("content");
|
||||
for (transform in AttributeValueTransforms) {
|
||||
TransformAttributeValues(transform, ["display", "displaystyle"]);
|
||||
var content = getBox("content");
|
||||
|
||||
var before_block = getBox("before_block");
|
||||
var mspace_block = getBox("mspace_block");
|
||||
var after_block = getBox("after_block");
|
||||
test(function() {
|
||||
assert_true(MathMLFeatureDetection.has_mspace());
|
||||
assert_approx_equals(before_block.left, content.left, 1,
|
||||
"content before must be left aligned");
|
||||
assert_approx_equals((mspace_block.left + mspace_block.right) / 2,
|
||||
(content.left + content.right) / 2,
|
||||
1,
|
||||
"math must be centered.");
|
||||
assert_approx_equals(after_block.left, content.left, 1,
|
||||
"content before must be left aligned");
|
||||
assert_less_than_equal(before_block.bottom, mspace_block.top,
|
||||
"new line before math");
|
||||
assert_less_than_equal(mspace_block.bottom, after_block.top,
|
||||
"new line after math");
|
||||
}, "Test display math");
|
||||
var before_block = getBox("before_block");
|
||||
var mspace_block = getBox("mspace_block");
|
||||
var after_block = getBox("after_block");
|
||||
test(function() {
|
||||
assert_true(MathMLFeatureDetection.has_mspace());
|
||||
assert_approx_equals(before_block.left, content.left, 1,
|
||||
"content before must be left aligned");
|
||||
assert_approx_equals((mspace_block.left + mspace_block.right) / 2,
|
||||
(content.left + content.right) / 2,
|
||||
1,
|
||||
"math must be centered.");
|
||||
assert_approx_equals(after_block.left, content.left, 1,
|
||||
"content before must be left aligned");
|
||||
assert_less_than_equal(before_block.bottom, mspace_block.top,
|
||||
"new line before math");
|
||||
assert_less_than_equal(mspace_block.bottom, after_block.top,
|
||||
"new line after math");
|
||||
}, `Test display math ${transform}`);
|
||||
|
||||
var before_inline = getBox("before_inline");
|
||||
var mspace_inline = getBox("mspace_inline");
|
||||
var after_inline = getBox("after_inline");
|
||||
test(function() {
|
||||
assert_true(MathMLFeatureDetection.has_mspace());
|
||||
assert_approx_equals((before_inline.top + before_inline.bottom) / 2,
|
||||
(mspace_inline.top + mspace_inline.bottom) / 2,
|
||||
1,
|
||||
"content before must be horizontally aligned with math");
|
||||
assert_approx_equals((after_inline.top + after_inline.bottom) / 2,
|
||||
(mspace_inline.top + mspace_inline.bottom) / 2,
|
||||
1,
|
||||
"content after must be horizontally aligned with math");
|
||||
assert_less_than_equal(before_inline.right, mspace_inline.left,
|
||||
"content before must be on the left of math");
|
||||
assert_less_than_equal(mspace_inline.right, after_inline.left,
|
||||
"content after must be on the right of math");
|
||||
}, "Test inline math");
|
||||
|
||||
done();
|
||||
var before_inline = getBox("before_inline");
|
||||
var mspace_inline = getBox("mspace_inline");
|
||||
var after_inline = getBox("after_inline");
|
||||
test(function() {
|
||||
assert_true(MathMLFeatureDetection.has_mspace());
|
||||
assert_approx_equals((before_inline.top + before_inline.bottom) / 2,
|
||||
(mspace_inline.top + mspace_inline.bottom) / 2,
|
||||
1,
|
||||
"content before must be horizontally aligned with math");
|
||||
assert_approx_equals((after_inline.top + after_inline.bottom) / 2,
|
||||
(mspace_inline.top + mspace_inline.bottom) / 2,
|
||||
1,
|
||||
"content after must be horizontally aligned with math");
|
||||
assert_less_than_equal(before_inline.right, mspace_inline.left,
|
||||
"content before must be on the left of math");
|
||||
assert_less_than_equal(mspace_inline.right, after_inline.left,
|
||||
"content after must be on the right of math");
|
||||
}, `Test inline math ${transform}`);
|
||||
}
|
||||
done();
|
||||
});
|
||||
</script>
|
||||
<style>
|
||||
|
@ -69,7 +72,7 @@
|
|||
background: black;
|
||||
}
|
||||
mspace {
|
||||
background: black;
|
||||
background: blue;
|
||||
}
|
||||
</style>
|
||||
</head>
|
||||
|
|
|
@ -0,0 +1,59 @@
|
|||
<!DOCTYPE html>
|
||||
<html>
|
||||
<head>
|
||||
<meta charset="utf-8"/>
|
||||
<title>MathML inside foreignObject</title>
|
||||
<link rel="help" href="https://mathml-refresh.github.io/mathml-core/#html-and-svg">
|
||||
<meta name="assert" content="Verify that MathML can be used inside a foreignObject element.">
|
||||
<script src="/resources/testharness.js"></script>
|
||||
<script src="/resources/testharnessreport.js"></script>
|
||||
<script src="/mathml/support/feature-detection.js"></script>
|
||||
<script>
|
||||
setup({ explicit_done: true });
|
||||
window.addEventListener("DOMContentLoaded", function() {
|
||||
var scale = 2;
|
||||
var epsilon = 1;
|
||||
var mfrac = document.getElementById("mfrac");
|
||||
var num = mfrac.firstElementChild.getBoundingClientRect();
|
||||
var denom = mfrac.lastElementChild.getBoundingClientRect();
|
||||
test(function() {
|
||||
assert_true(MathMLFeatureDetection.has_mspace());
|
||||
// The values of width and height are inverted (because of the
|
||||
// rotation) and multiplied by the scale factor.
|
||||
assert_approx_equals(num.height, 30 * scale, epsilon, "numerator width");
|
||||
assert_approx_equals(num.width, 40 * scale, epsilon, "numerator height");
|
||||
assert_approx_equals(denom.height, 50 * scale, epsilon, "numerator width");
|
||||
assert_approx_equals(denom.width, 60 * scale, epsilon, "numerator height");
|
||||
}, "mspace layout in SVG foreignObject");
|
||||
test(function() {
|
||||
// The horizontal/vertical metrics are inverted (because of the
|
||||
// rotation) and multiplied by the scale factor.
|
||||
assert_true(MathMLFeatureDetection.has_mfrac());
|
||||
assert_greater_than_equal(num.right - denom.left,
|
||||
(40 + 60) * scale,
|
||||
"numerator is on the right of denominator");
|
||||
assert_approx_equals((num.top + num.bottom) / 2,
|
||||
(denom.top + denom.bottom) / 2,
|
||||
epsilon, "numerator and denominator are vertically aligned");
|
||||
}, "mfrac layout in SVG foreignObject");
|
||||
done();
|
||||
});
|
||||
</script>
|
||||
</head>
|
||||
<body>
|
||||
<div id="log"></div>
|
||||
<svg width="400px" height="400px">
|
||||
<g transform="rotate(90, 200, 200) scale(2)">
|
||||
<foreignObject width="400px" height="400px"
|
||||
requiredExtensions="http://www.w3.org/1998/Math/MathML">
|
||||
<math>
|
||||
<mfrac id="mfrac">
|
||||
<mspace width="30px" height="40px" style="background: cyan"></mspace>
|
||||
<mspace width="50px" height="60px" style="background: yellow"></mspace>
|
||||
</mfrac>
|
||||
</math>
|
||||
</foreignObject>
|
||||
</g>
|
||||
</svg>
|
||||
</body>
|
||||
</html>
|
Loading…
Add table
Add a link
Reference in a new issue