From 6bf0a5cb5034a7e684dcc3500e841785237ce2dd Mon Sep 17 00:00:00 2001 From: Daniel Baumann Date: Sun, 7 Apr 2024 19:32:43 +0200 Subject: Adding upstream version 1:115.7.0. Signed-off-by: Daniel Baumann --- .../base/content/test/general/browser_bug521216.js | 68 ++++++++++++++++++++++ 1 file changed, 68 insertions(+) create mode 100644 browser/base/content/test/general/browser_bug521216.js (limited to 'browser/base/content/test/general/browser_bug521216.js') diff --git a/browser/base/content/test/general/browser_bug521216.js b/browser/base/content/test/general/browser_bug521216.js new file mode 100644 index 0000000000..8c885bbcc8 --- /dev/null +++ b/browser/base/content/test/general/browser_bug521216.js @@ -0,0 +1,68 @@ +var expected = [ + "TabOpen", + "onStateChange", + "onLocationChange", + "onLinkIconAvailable", +]; +var actual = []; +var tabIndex = -1; +this.__defineGetter__("tab", () => gBrowser.tabs[tabIndex]); + +function test() { + waitForExplicitFinish(); + tabIndex = gBrowser.tabs.length; + gBrowser.addTabsProgressListener(progressListener); + gBrowser.tabContainer.addEventListener("TabOpen", TabOpen); + BrowserTestUtils.addTab( + gBrowser, + "data:text/html," + ); +} + +function recordEvent(aName) { + info("got " + aName); + if (!actual.includes(aName)) { + actual.push(aName); + } + if (actual.length == expected.length) { + is( + actual.toString(), + expected.toString(), + "got events and progress notifications in expected order" + ); + + executeSoon( + // eslint-disable-next-line no-shadow + function (tab) { + gBrowser.removeTab(tab); + gBrowser.removeTabsProgressListener(progressListener); + gBrowser.tabContainer.removeEventListener("TabOpen", TabOpen); + finish(); + }.bind(null, tab) + ); + } +} + +function TabOpen(aEvent) { + if (aEvent.target == tab) { + recordEvent("TabOpen"); + } +} + +var progressListener = { + onLocationChange: function onLocationChange(aBrowser) { + if (aBrowser == tab.linkedBrowser) { + recordEvent("onLocationChange"); + } + }, + onStateChange: function onStateChange(aBrowser) { + if (aBrowser == tab.linkedBrowser) { + recordEvent("onStateChange"); + } + }, + onLinkIconAvailable: function onLinkIconAvailable(aBrowser) { + if (aBrowser == tab.linkedBrowser) { + recordEvent("onLinkIconAvailable"); + } + }, +}; -- cgit v1.2.3