Source code

Revision control

Copy as Markdown

Other Tools

Test Info:

/* This Source Code Form is subject to the terms of the Mozilla Public
* License, v. 2.0. If a copy of the MPL was not distributed with this
* file, You can obtain one at http://mozilla.org/MPL/2.0/. */
"use strict";
requestLongerTimeout(2);
// Test that highlighting various inline boxes displays the right number of
// polygons in the page.
const TEST_URL = URL_ROOT + "doc_inspector_highlighter_inline.html";
const TEST_DATA = [
"body",
"h1",
"h2",
"h2 em",
"p",
"p span",
// The following test case used to fail. See bug 1139925.
"[dir=rtl] > span",
];
add_task(async function () {
info("Loading the test document and opening the inspector");
const { inspector, highlighterTestFront } = await openInspectorForURL(
TEST_URL
);
for (const selector of TEST_DATA) {
info("Selecting and highlighting node " + selector);
await selectAndHighlightNode(selector, inspector);
info("Get all quads for this node");
const data = await getAllAdjustedQuadsForContentPageElement(selector);
info(
"Iterate over the box-model regions and verify that the highlighter " +
"is correct"
);
for (const region of ["margin", "border", "padding", "content"]) {
const { points } = await highlighterTestFront.getHighlighterRegionPath(
region
);
is(
points.length,
data[region].length,
"The highlighter's " +
region +
" path defines the correct number of boxes"
);
}
info(
"Verify that the guides define a rectangle that contains all " +
"content boxes"
);
const expectedContentRect = {
p1: { x: Infinity, y: Infinity },
p2: { x: -Infinity, y: Infinity },
p3: { x: -Infinity, y: -Infinity },
p4: { x: Infinity, y: -Infinity },
};
for (const { p1, p2, p3, p4 } of data.content) {
expectedContentRect.p1.x = Math.min(expectedContentRect.p1.x, p1.x);
expectedContentRect.p1.y = Math.min(expectedContentRect.p1.y, p1.y);
expectedContentRect.p2.x = Math.max(expectedContentRect.p2.x, p2.x);
expectedContentRect.p2.y = Math.min(expectedContentRect.p2.y, p2.y);
expectedContentRect.p3.x = Math.max(expectedContentRect.p3.x, p3.x);
expectedContentRect.p3.y = Math.max(expectedContentRect.p3.y, p3.y);
expectedContentRect.p4.x = Math.min(expectedContentRect.p4.x, p4.x);
expectedContentRect.p4.y = Math.max(expectedContentRect.p4.y, p4.y);
}
const contentRect = await highlighterTestFront.getGuidesRectangle();
for (const point of ["p1", "p2", "p3", "p4"]) {
is(
Math.round(contentRect[point].x),
Math.round(expectedContentRect[point].x),
"x coordinate of point " +
point +
" of the content rectangle defined by the outer guides is correct"
);
is(
Math.round(contentRect[point].y),
Math.round(expectedContentRect[point].y),
"y coordinate of point " +
point +
" of the content rectangle defined by the outer guides is correct"
);
}
}
});