function pageScript() { window.addEventListener( "beforeunload", function(event) { var str = "Some text that causes the beforeunload dialog to be shown"; event.returnValue = str; return str; }, true ); } SpecialPowers.pushPrefEnv({ set: [["dom.require_user_interaction_for_beforeunload", true]], }); SpecialPowers.pushPrefEnv({ set: [["prompts.contentPromptSubDialog", false]], }); const PAGE_URL = "data:text/html," + encodeURIComponent(""); add_task(async function doClick() { // The onbeforeunload dialog should appear. let dialogShown = false; function onDialogShown(node) { dialogShown = true; let dismissButton = node.querySelector(".tabmodalprompt-button0"); dismissButton.click(); } let obsName = "tabmodal-dialog-loaded"; Services.obs.addObserver(onDialogShown, obsName); await openPage(true); Services.obs.removeObserver(onDialogShown, obsName); Assert.ok(dialogShown, "Should have shown dialog."); }); add_task(async function noClick() { // The onbeforeunload dialog should NOT appear. await openPage(false); info("If we time out here, then the dialog was shown..."); }); async function openPage(shouldClick) { // Open about:blank in a new tab. await BrowserTestUtils.withNewTab( { gBrowser, url: "about:blank" }, async function(browser) { // Load the page. BrowserTestUtils.loadURI(browser, PAGE_URL); await BrowserTestUtils.browserLoaded(browser); if (shouldClick) { await BrowserTestUtils.synthesizeMouse("body", 2, 2, {}, browser); } let hasInteractedWith = await SpecialPowers.spawn( browser, [""], function() { return content.document.userHasInteracted; } ); is( shouldClick, hasInteractedWith, "Click should update document interactivity state" ); // And then navigate away. BrowserTestUtils.loadURI(browser, "http://example.com/"); await BrowserTestUtils.browserLoaded(browser); } ); }