diff options
author | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-28 14:29:10 +0000 |
---|---|---|
committer | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-28 14:29:10 +0000 |
commit | 2aa4a82499d4becd2284cdb482213d541b8804dd (patch) | |
tree | b80bf8bf13c3766139fbacc530efd0dd9d54394c /browser/base/content/test/general/browser_bug585785.js | |
parent | Initial commit. (diff) | |
download | firefox-2aa4a82499d4becd2284cdb482213d541b8804dd.tar.xz firefox-2aa4a82499d4becd2284cdb482213d541b8804dd.zip |
Adding upstream version 86.0.1.upstream/86.0.1upstream
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'browser/base/content/test/general/browser_bug585785.js')
-rw-r--r-- | browser/base/content/test/general/browser_bug585785.js | 48 |
1 files changed, 48 insertions, 0 deletions
diff --git a/browser/base/content/test/general/browser_bug585785.js b/browser/base/content/test/general/browser_bug585785.js new file mode 100644 index 0000000000..094f132086 --- /dev/null +++ b/browser/base/content/test/general/browser_bug585785.js @@ -0,0 +1,48 @@ +var tab; + +function test() { + waitForExplicitFinish(); + + // Force-enable tab animations + gReduceMotionOverride = false; + + tab = BrowserTestUtils.addTab(gBrowser); + isnot( + tab.getAttribute("fadein"), + "true", + "newly opened tab is yet to fade in" + ); + + // Try to remove the tab right before the opening animation's first frame + window.requestAnimationFrame(checkAnimationState); +} + +function checkAnimationState() { + is(tab.getAttribute("fadein"), "true", "tab opening animation initiated"); + + info(window.getComputedStyle(tab).maxWidth); + gBrowser.removeTab(tab, { animate: true }); + if (!tab.parentNode) { + ok( + true, + "tab removed synchronously since the opening animation hasn't moved yet" + ); + finish(); + return; + } + + info( + "tab didn't close immediately, so the tab opening animation must have started moving" + ); + info("waiting for the tab to close asynchronously"); + tab.addEventListener( + "TabAnimationEnd", + function listener() { + executeSoon(function() { + ok(!tab.parentNode, "tab removed asynchronously"); + finish(); + }); + }, + { once: true } + ); +} |