haikuwebkit/LayoutTests/printing/break-inside-avoid.html

59 lines
2.1 KiB
HTML

<!DOCTYPE HTML PUBLIC "-//IETF//DTD HTML//EN">
<html>
<head>
<script src="../resources/js-test-pre.js"></script>
<script src="resources/paged-media-test-utils.js"></script>
</head>
<body>
<p id="description"></p>
<div id="console"></div>
<div id="sandbox"></div>
<script>
description("Test for page-break-inside:avoid");
function test()
{
createBlockWithRatioToPageHeight("page1-1", 0.5).style.breakBefore = "page";
// block 'page1-2' should be splitted.
createBlockWithNumberOfLines("page1-2", 20);
createBlockWithRatioToPageHeight("page2", 0.1);
createBlockWithRatioToPageHeight("page3", 0.5).style.breakBefore = "page";
// We should place block 'page4' in the next page because of 'page-break-inside: avoid'.
createBlockWithNumberOfLines("page4", 20).style.breakInside = "avoid";
createBlockWithRatioToPageHeight("page5", 0.8).style.breakBefore = "page";
// block 'page5-2' is a very large block, occupying more than 2 pages.
// We don't define from where this large block starts. Maybe from the next page.
createBlockWithNumberOfLines("page5or6", 20 * 2 + 10).style.breakInside = "avoid";
createBlockWithRatioToPageHeight("page8", 0.1);
createBlockWithRatioToPageHeight("page9-1", 0.1).style.breakBefore = "page";
createBlockWithRatioToPageHeight("page9-2", 0.1).style.breakAfter = "page";
// Make sure page-break only happens once, not twice.
createBlockWithNumberOfLines("page10", 20).style.breakInside = "avoid";
pageNumberForElementShouldBe('page1-1', 1);
pageNumberForElementShouldBe('page1-2', 1);
pageNumberForElementShouldBe('page2', 2);
pageNumberForElementShouldBe('page3', 3);
pageNumberForElementShouldBe('page4', 4);
pageNumberForElementShouldBe('page5', 5);
pageNumberForElementShouldBe('page8', 8);
pageNumberForElementShouldBe('page9-1', 9);
pageNumberForElementShouldBe('page9-2', 9);
pageNumberForElementShouldBe('page10', 10);
document.body.removeChild(document.getElementById("sandbox"));
}
var successfullyParsed = true;
</script>
<script>runPrintingTest(test);</script>
<script src="../resources/js-test-post.js"></script>
</body>
</html>