summaryrefslogtreecommitdiffstats
path: root/testing/web-platform/tests/css/cssom-view/scrolling-quirks-vs-nonquirks.html
diff options
context:
space:
mode:
Diffstat (limited to 'testing/web-platform/tests/css/cssom-view/scrolling-quirks-vs-nonquirks.html')
-rw-r--r--testing/web-platform/tests/css/cssom-view/scrolling-quirks-vs-nonquirks.html220
1 files changed, 220 insertions, 0 deletions
diff --git a/testing/web-platform/tests/css/cssom-view/scrolling-quirks-vs-nonquirks.html b/testing/web-platform/tests/css/cssom-view/scrolling-quirks-vs-nonquirks.html
new file mode 100644
index 0000000000..568f572ac2
--- /dev/null
+++ b/testing/web-platform/tests/css/cssom-view/scrolling-quirks-vs-nonquirks.html
@@ -0,0 +1,220 @@
+<!DOCTYPE html>
+<meta charset=utf-8>
+<title>cssom-view - scrolling quirks VS nonquirks mode</title>
+<script src="/resources/testharness.js"></script>
+<script src="/resources/testharnessreport.js"></script>
+<style>
+ iframe {
+ width: 300px;
+ height: 500px;
+ }
+</style>
+<iframe id="quirksframe"></iframe>
+<iframe id="nonquirksframe"></iframe>
+<div id="log"></div>
+<script>
+function setBodyContent(body) {
+ // Hide scrollbars and remove body margin to make measures more reliable.
+ body.style.overflow = "hidden";
+ body.style.margin = 0;
+
+ // Add an orange border to the body.
+ body.style.borderWidth = "10px 0px 0px 20px";
+ body.style.borderColor = "orange";
+ body.style.borderStyle = "solid";
+
+ // Create a 700x900 box with a green border.
+ body.innerHTML = "<div id='content' style='border-width: 30px 0px 0px 40px; border-style: solid; border-color: green; width: 660px; height: 870px; background: linear-gradient(135deg, red, blue);'></div>";
+}
+
+var quirksModeTest = async_test("Execution of tests in quirks mode");
+var quirksFrame = document.getElementById("quirksframe");
+quirksFrame.onload = function() {
+ var doc = quirksFrame.contentDocument;
+ setBodyContent(doc.body);
+ var content = doc.getElementById("content");
+
+ quirksModeTest.step(function () {
+ assert_equals(doc.compatMode, "BackCompat", "Should be in quirks mode.");
+ });
+
+ test(function () {
+ assert_equals(doc.scrollingElement, doc.body, "scrollingElement should be HTML body");
+ }, "scrollingElement in quirks mode");
+
+ test(function () {
+ doc.documentElement.scroll(50, 60);
+ assert_equals(doc.documentElement.scrollLeft, 0, "scrollLeft should be 0");
+ assert_equals(doc.documentElement.scrollTop, 0, "scrollTop should be 0");
+ }, "scroll() on the root element in quirks mode");
+
+ test(function () {
+ doc.documentElement.scrollBy(10, 20);
+ assert_equals(doc.documentElement.scrollLeft, 0, "scrollLeft should be 0");
+ assert_equals(doc.documentElement.scrollTop, 0, "scrollTop should be 0");
+ }, "scrollBy() on the root element in quirks mode");
+
+ test(function () {
+ doc.documentElement.scrollLeft = 70;
+ doc.documentElement.scrollTop = 80;
+ assert_equals(doc.documentElement.scrollLeft, 0, "scrollLeft should be 0");
+ assert_equals(doc.documentElement.scrollTop, 0, "scrollTop should be 0");
+ }, "scrollLeft/scrollTop on the root element in quirks mode");
+
+ test(function () {
+ assert_equals(doc.documentElement.scrollWidth, 720, "scrollWidth should be 720");
+ assert_equals(doc.documentElement.scrollHeight, 910, "scrollHeight should be 910");
+ }, "scrollWidth/scrollHeight on the root element in quirks mode");
+
+ test(function () {
+ assert_equals(doc.documentElement.clientWidth, 300, "clientWidth should be 300");
+ assert_equals(doc.documentElement.clientHeight, 910, "clientHeight should be 910");
+ }, "clientWidth/clientHeight on the root element in quirks mode");
+
+ test(function () {
+ doc.body.scroll(90, 100);
+ assert_equals(doc.body.scrollLeft, 90, "scrollLeft should be 90");
+ assert_equals(doc.body.scrollTop, 100, "scrollTop should be 100");
+ }, "scroll() on the HTML body element in quirks mode");
+
+ test(function () {
+ doc.body.scrollBy(10, 20);
+ assert_equals(doc.body.scrollLeft, 100, "scrollLeft should be 100");
+ assert_equals(doc.body.scrollTop, 120, "scrollTop should be 120");
+ }, "scrollBy() on the HTML body element in quirks mode");
+
+ test(function () {
+ doc.body.scrollLeft = 120;
+ doc.body.scrollTop = 110;
+ assert_equals(doc.body.scrollLeft, 120, "scrollLeft should be 120");
+ assert_equals(doc.body.scrollTop, 110, "scrollTop should be 110");
+ }, "scrollLeft/scrollTop on the HTML body element in quirks mode");
+
+ test(function () {
+ assert_equals(doc.body.scrollWidth, 720, "scrollWidth should be 720");
+ assert_equals(doc.body.scrollHeight, 910, "scrollHeight should be 910");
+ }, "scrollWidth/scrollHeight on the HTML body element in quirks mode");
+
+ test(function () {
+ assert_equals(doc.body.clientWidth, 300, "clientWidth should be 300");
+ assert_equals(doc.body.clientHeight, 500, "clientHeight should be 500");
+ }, "clientWidth/clientHeight on the HTML body element in quirks mode");
+
+ test(function () {
+ doc.scrollingElement.scroll(0, 0);
+ content.scrollLeft = 130;
+ content.scrollTop = 140;
+ assert_equals(content.scrollLeft, 0, "scrollLeft should be 0");
+ assert_equals(content.scrollTop, 0, "scrollTop should be 0");
+ }, "scrollLeft/scrollRight of the content in quirks mode");
+
+ test(function () {
+ assert_equals(content.scrollWidth, 660, "scrollWidth should be 660");
+ assert_equals(content.scrollHeight, 870, "scrollHeight should be 870");
+ }, "scrollWidth/scrollHeight of the content in quirks mode");
+
+ test(function () {
+ assert_equals(content.clientWidth, 660, "clientWidth should be 660");
+ assert_equals(content.clientHeight, 870, "clientHeight should be 870");
+ }, "clientWidth/clientHeight of the content in quirks mode");
+
+ quirksModeTest.done();
+}
+quirksFrame.src = URL.createObjectURL(new Blob([""], { type: "text/html" }));
+
+var nonQuirksModeTest = async_test("Execution of tests in non-quirks mode");
+var nonQuirksFrame = document.getElementById("nonquirksframe");
+nonQuirksFrame.onload = function() {
+ var doc = nonQuirksFrame.contentDocument;
+ setBodyContent(doc.body);
+ var content = doc.getElementById("content");
+
+ nonQuirksModeTest.step(function() {
+ assert_equals(doc.compatMode, "CSS1Compat", "Should be in standards mode.");
+ });
+
+ test(function () {
+ assert_equals(doc.scrollingElement, doc.documentElement, "scrollingElement should be documentElement");
+ }, "scrollingElement in non-quirks mode");
+
+ test(function () {
+ doc.documentElement.scroll(50, 60);
+ assert_equals(doc.documentElement.scrollLeft, 50, "scrollLeft should be 50");
+ assert_equals(doc.documentElement.scrollTop, 60, "scrollTop should be 60");
+ }, "scroll() on the root element in non-quirks mode");
+
+ test(function () {
+ doc.documentElement.scrollBy(10, 20);
+ assert_equals(doc.documentElement.scrollLeft, 60, "scrollLeft should be 60");
+ assert_equals(doc.documentElement.scrollTop, 80, "scrollTop should be 80");
+ }, "scrollBy() on the root element in non-quirks mode");
+
+ test(function () {
+ doc.documentElement.scrollLeft = 70;
+ doc.documentElement.scrollTop = 80;
+ assert_equals(doc.documentElement.scrollLeft, 70, "scrollLeft should be 70");
+ assert_equals(doc.documentElement.scrollTop, 80, "scrollTop should be 80");
+ }, "scrollLeft/scrollTop on the root element in non-quirks mode");
+
+ test(function () {
+ assert_equals(doc.documentElement.scrollWidth, 720, "scrollWidth should be 720");
+ assert_equals(doc.documentElement.scrollHeight, 910, "scrollHeight should be 910");
+ }, "scrollWidth/scrollHeight on the root element in non-quirks mode");
+
+ test(function () {
+ assert_equals(doc.documentElement.clientWidth, 300, "clientWidth should be 300");
+ assert_equals(doc.documentElement.clientHeight, 500, "clientHeight should be 500");
+ }, "clientWidth/clientHeight on the root element in non-quirks mode");
+
+ test(function () {
+ doc.body.scroll(90, 100);
+ assert_equals(doc.body.scrollLeft, 0, "scrollLeft should be 0");
+ assert_equals(doc.body.scrollTop, 0, "scrollTop should be 0");
+ }, "scroll() on the HTML body element in non-quirks mode");
+
+ test(function () {
+ doc.body.scrollBy(10, 20);
+ assert_equals(doc.body.scrollLeft, 0, "scrollLeft should be 0");
+ assert_equals(doc.body.scrollTop, 0, "scrollTop should be 0");
+ }, "scrollBy() on the HTML body element in non-quirks mode");
+
+ test(function () {
+ doc.body.scrollLeft = 120;
+ doc.body.scrollTop = 110;
+ assert_equals(doc.body.scrollLeft, 0, "scrollLeft should be 0");
+ assert_equals(doc.body.scrollTop, 0, "scrollTop should be 0");
+ }, "scrollLeft/scrollTop on the HTML body element in non-quirks mode");
+
+ test(function () {
+ assert_equals(doc.body.scrollWidth, 700, "scrollWidth should be 700");
+ assert_equals(doc.body.scrollHeight, 900, "scrollHeight should be 900");
+ }, "scrollWidth/scrollHeight on the HTML body element in non-quirks mode");
+
+ test(function () {
+ assert_equals(doc.body.clientWidth, 280, "clientWidth should be 280");
+ assert_equals(doc.body.clientHeight, 900, "clientHeight should be 900");
+ }, "clientWidth/clientHeight on the HTML body element in non-quirks mode");
+
+ test(function () {
+ doc.scrollingElement.scroll(0, 0);
+ content.scrollLeft = 130;
+ content.scrollTop = 140;
+ assert_equals(content.scrollLeft, 0, "scrollLeft should be 0");
+ assert_equals(content.scrollTop, 0, "scrollTop should be 0");
+ }, "scrollLeft/scrollRight of the content in non-quirks mode");
+
+ test(function () {
+ assert_equals(content.scrollWidth, 660, "scrollWidth should be 660");
+ assert_equals(content.scrollHeight, 870, "scrollHeight should be 870");
+ }, "scrollWidth/scrollHeight of the content in non-quirks mode");
+
+ test(function () {
+ assert_equals(content.clientWidth, 660, "clientWidth should be ");
+ assert_equals(content.clientHeight, 870, "clientHeight should be 870");
+ }, "clientWidth/clientHeight of the content in non-quirks mode");
+
+ nonQuirksModeTest.done();
+}
+nonQuirksFrame.src = URL.createObjectURL(new Blob(["<!doctype html>"], { type: "text/html" }));
+
+</script>