From 43a97878ce14b72f0981164f87f2e35e14151312 Mon Sep 17 00:00:00 2001 From: Daniel Baumann Date: Sun, 7 Apr 2024 11:22:09 +0200 Subject: Adding upstream version 110.0.1. Signed-off-by: Daniel Baumann --- .../base/content/test/general/browser_bug585785.js | 48 ++++++++++++++++++++++ 1 file changed, 48 insertions(+) create mode 100644 browser/base/content/test/general/browser_bug585785.js (limited to 'browser/base/content/test/general/browser_bug585785.js') 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 } + ); +} -- cgit v1.2.3