summaryrefslogtreecommitdiffstats
path: root/layout/generic/test/test_scrollframe_abspos_interrupt.html
diff options
context:
space:
mode:
authorDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-07 17:32:43 +0000
committerDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-07 17:32:43 +0000
commit6bf0a5cb5034a7e684dcc3500e841785237ce2dd (patch)
treea68f146d7fa01f0134297619fbe7e33db084e0aa /layout/generic/test/test_scrollframe_abspos_interrupt.html
parentInitial commit. (diff)
downloadthunderbird-upstream.tar.xz
thunderbird-upstream.zip
Adding upstream version 1:115.7.0.upstream/1%115.7.0upstream
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'layout/generic/test/test_scrollframe_abspos_interrupt.html')
-rw-r--r--layout/generic/test/test_scrollframe_abspos_interrupt.html60
1 files changed, 60 insertions, 0 deletions
diff --git a/layout/generic/test/test_scrollframe_abspos_interrupt.html b/layout/generic/test/test_scrollframe_abspos_interrupt.html
new file mode 100644
index 0000000000..fe25e991f9
--- /dev/null
+++ b/layout/generic/test/test_scrollframe_abspos_interrupt.html
@@ -0,0 +1,60 @@
+<!doctype html>
+<title>Test for bug 1526609</title>
+<script src="/tests/SimpleTest/SimpleTest.js"></script>
+<script src="/tests/SimpleTest/EventUtils.js"></script>
+<style>
+ body {
+ margin: 0;
+ }
+ .scroller {
+ overflow-y: auto;
+ position: relative;
+ width: 500px;
+ height: 300px;
+ }
+ .kid {
+ position: absolute;
+ width: 100%;
+ background: linear-gradient(to bottom, red, green);
+ line-height: 100px;
+ }
+</style>
+<div class="scroller" id="scroller">
+ <div class="kid"></div>
+</div>
+<script>
+{
+ let text = " foo bar ";
+
+ for (let i = 0; i < 16; ++i)
+ text = text + text;
+ document.querySelector(".kid").innerText = text;
+}
+
+SimpleTest.waitForExplicitFinish();
+
+const scroller = document.querySelector("#scroller");
+
+is(scroller.scrollTop, 0, "Initial scroll position");
+ok(scroller.scrollTopMax > 0, "Should be able to scroll down");
+
+scroller.scrollTop = scroller.scrollTopMax;
+is(scroller.scrollTop, scroller.scrollTopMax, "Should've scrolled");
+
+const origWidth = scroller.offsetWidth;
+const utils = SpecialPowers.DOMWindowUtils;
+
+// Take control of the refresh driver
+utils.advanceTimeAndRefresh(0);
+
+// Force the next reflow to get interrupted
+utils.forceReflowInterrupt();
+scroller.style.width = "300px";
+utils.advanceTimeAndRefresh(0);
+
+isnot(scroller.scrollTop, 0, "Shouldn't have lost scroll position");
+isnot(scroller.offsetWidth, origWidth, "Should've had to reflow");
+
+utils.restoreNormalRefresh();
+SimpleTest.finish();
+</script>