add_task(async function () { const URL = "data:text/html,<!DOCTYPE html><html><body><input autofocus id='target'></body></html>"; const foregroundTab = gBrowser.selectedTab; const backgroundTab = BrowserTestUtils.addTab(gBrowser); // Ensure tab is still in the foreground. is( gBrowser.selectedTab, foregroundTab, "foregroundTab should still be selected" ); // Load the second tab in the background. const loadedPromise = BrowserTestUtils.browserLoaded( backgroundTab.linkedBrowser, /* includesubframes */ false, URL ); BrowserTestUtils.loadURIString(backgroundTab.linkedBrowser, URL); await loadedPromise; // Get active element in the tab. let tagName = await SpecialPowers.spawn( backgroundTab.linkedBrowser, [], async function () { // Spec asks us to flush autofocus candidates in the // `update-the-rendering` step, so we need to wait // for a rAF to ensure autofocus candidates are // flushed. await new Promise(r => { content.requestAnimationFrame(r); }); return content.document.activeElement.tagName; } ); is( tagName, "INPUT", "The background tab's focused element should be the <input>" ); is( gBrowser.selectedTab, foregroundTab, "foregroundTab tab should still be selected, shouldn't cause a tab switch" ); is( document.activeElement, foregroundTab.linkedBrowser, "The background tab's focused element should not cause the tab to be selected" ); // Cleaning up. BrowserTestUtils.removeTab(backgroundTab); });