diff options
author | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-07 17:32:43 +0000 |
---|---|---|
committer | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-07 17:32:43 +0000 |
commit | 6bf0a5cb5034a7e684dcc3500e841785237ce2dd (patch) | |
tree | a68f146d7fa01f0134297619fbe7e33db084e0aa /layout/base/crashtests/1338772-1.html | |
parent | Initial commit. (diff) | |
download | thunderbird-6bf0a5cb5034a7e684dcc3500e841785237ce2dd.tar.xz thunderbird-6bf0a5cb5034a7e684dcc3500e841785237ce2dd.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/base/crashtests/1338772-1.html')
-rw-r--r-- | layout/base/crashtests/1338772-1.html | 42 |
1 files changed, 42 insertions, 0 deletions
diff --git a/layout/base/crashtests/1338772-1.html b/layout/base/crashtests/1338772-1.html new file mode 100644 index 0000000000..70bf09dcaa --- /dev/null +++ b/layout/base/crashtests/1338772-1.html @@ -0,0 +1,42 @@ +<!DOCTYPE html> +<html class="reftest-wait"> +<script> +function loadHandler() { + var outer = document.getElementById("outer"); + var inner = document.createElement("iframe"); + inner.height = "1px"; + outer.contentDocument.body.appendChild(inner); + + // Flush reflow inside our inner iframe. This ensures that our inner.height + // tweak further down will actually invoke the resize handler. + inner.contentWindow.offsetTop; + + // Set up resize handler (which ends the test, one way or another) + inner.contentWindow.onresize = () => { + outer.remove(); + document.documentElement.removeAttribute("class"); + }; + + // Trigger the resize handler: + inner.height = "5px"; + inner.offsetTop; +} + +// This function is a hack to avoid sporadic test-failures with... +// "...timed out waiting for reftest-wait to be removed". +// Occasionally, it seems this test loses a race condition of some sort, and +// its resize handler isn't invoked. When that happens (and specifically, when +// the test runs for longer than 500ms), we clear reftest-wait and call the +// run a "pass" (which is kind of valid, because we didn't crash!) and move on. +function setupFailsafe() { + setTimeout(() => { + document.documentElement.removeAttribute("class"); + }, 500); +} +</script> +<body onload="setupFailsafe()"> + <iframe id="outer" + src="data:text/html,<html><body>" + onload="loadHandler()"> + </iframe> +</body> |