blob: f9ccc896432425a96a2e393d61805b44a264e7bf [file] [log] [blame]
<!doctype html>
<html>
<head>
<script src="../../http/tests/inspector/resources/inspector-test.js"></script>
<script>
function test()
{
const color = undefined;
const outlineColor = undefined;
const useViewportCoordinates = false;
const usePageCoordinates = true;
function getHighlightRects(callback) {
InspectorTest.evaluateInPage("JSON.stringify(Array.from(window.internals.inspectorHighlightRects()))", (error, payload, wasThrown) => {
InspectorTest.assert(!error, "Unexpected error dumping highlight: " + error);
InspectorTest.assert(!wasThrown, "Unexpected exception when dumping highlight.");
callback(JSON.parse(payload.value));
});
}
function dumpHighlightRects(callback) {
getHighlightRects((highlightRects) => {
InspectorTest.expectThat(highlightRects.length === 1, "Should be one highlight rect.");
InspectorTest.log("Highlight Rect: " + JSON.stringify(highlightRects[0]));
callback();
});
}
let suite = InspectorTest.createAsyncSuite("DOM.highlightRect");
suite.addTestCase({
name: "CheckEmptyHighlight",
description: "Should not be a highlight yet.",
test(resolve, reject) {
getHighlightRects((highlightRects) => {
InspectorTest.expectThat(highlightRects.length === 0, "Should not be a highlight yet.");
resolve();
});
}
});
suite.addTestCase({
name: "HighlightSmallRectViewportCoordinates",
description: "Should create a highlight using viewport coordinates.",
test(resolve, reject) {
let rect = new WebInspector.Rect(0, 0, 100, 200);
DOMAgent.highlightRect(rect.origin.x, rect.origin.y, rect.size.width, rect.size.height, color, outlineColor, useViewportCoordinates, (error) => {
dumpHighlightRects(resolve);
});
}
});
suite.addTestCase({
name: "HighlightSmallRectPageCoordinates",
description: "Should create a highlight using page coordinates.",
test(resolve, reject) {
let rect = new WebInspector.Rect(0, 0, 100, 200);
DOMAgent.highlightRect(rect.origin.x, rect.origin.y, rect.size.width, rect.size.height, color, outlineColor, usePageCoordinates, (error) => {
dumpHighlightRects(resolve);
});
}
});
suite.addTestCase({
name: "HighlightSmallRectUnspecifiedCoordinatesUsesViewportCoordinates",
description: "Should create a highlight using viewport coordinates if unspecified.",
test(resolve, reject) {
let rect = new WebInspector.Rect(0, 0, 100, 200);
DOMAgent.highlightRect(rect.origin.x, rect.origin.y, rect.size.width, rect.size.height, color, outlineColor, (error) => {
dumpHighlightRects(resolve);
});
}
});
suite.addTestCase({
name: "HighlightLargeRectViewportCoordinates",
description: "Should create a large highlight using viewport coordinates.",
test(resolve, reject) {
let rect = new WebInspector.Rect(0, 0, 100000, 200000);
DOMAgent.highlightRect(rect.origin.x, rect.origin.y, rect.size.width, rect.size.height, color, outlineColor, useViewportCoordinates, (error) => {
dumpHighlightRects(resolve);
});
}
});
suite.addTestCase({
name: "HighlightLargeRectPageCoordinates",
description: "Should create a large highlight using page coordinates.",
test(resolve, reject) {
let rect = new WebInspector.Rect(0, 0, 100000, 200000);
DOMAgent.highlightRect(rect.origin.x, rect.origin.y, rect.size.width, rect.size.height, color, outlineColor, usePageCoordinates, (error) => {
dumpHighlightRects(resolve);
});
}
});
suite.addTestCase({
name: "HighlightEmptyRect",
description: "Should create an empty highlight.",
test(resolve, reject) {
let rect = new WebInspector.Rect(0, 0, 0, 0);
DOMAgent.highlightRect(rect.origin.x, rect.origin.y, rect.size.width, rect.size.height, color, outlineColor, false, (error) => {
dumpHighlightRects(resolve);
});
}
});
InspectorTest.evaluateInPage("window.scrollTo(10, 10)", () => {
suite.runTestCasesAndFinish();
});
}
</script>
</head>
<body onload="runTest()">
<p>Tests for the DOM.highlightRect command.</p>
<!-- Ensure the page is scrollable so we can test highlight rects relative to a scroll page -->
<div style="height:2000px; width: 2000px; background:blue"></div>
</body>
</html>