/* Any copyright is dedicated to the Public Domain. * http://creativecommons.org/publicdomain/zero/1.0/ */ "use strict"; // Test that the frames button is always visible when the user is on the options panel. // Test that the button is disabled if the current target has no frames. // Test that the button is enabled otherwise. const TEST_URL = "data:text/html;charset=utf8,test frames button visibility"; const TEST_IFRAME_URL = "data:text/plain,iframe"; const TEST_IFRAME_URL2 = "data:text/plain,iframe2"; const TEST_URL_FRAMES = TEST_URL + `` + ``; const FRAME_BUTTON_PREF = "devtools.command-button-frames.enabled"; add_task(async function() { // Hide the button by default. await pushPref(FRAME_BUTTON_PREF, false); const tab = await addTab(TEST_URL); info("Open the toolbox on the Options panel"); const toolbox = await gDevTools.showToolboxForTab(tab, { toolId: "options" }); const doc = toolbox.doc; const optionsPanel = toolbox.getCurrentPanel(); let framesButton = doc.getElementById("command-button-frames"); ok(!framesButton, "Frames button is not rendered."); const optionsDoc = optionsPanel.panelWin.document; const framesButtonCheckbox = optionsDoc.getElementById( "command-button-frames" ); framesButtonCheckbox.click(); info("Wait for the frame button to be rendered"); framesButton = await waitFor(() => doc.getElementById("command-button-frames") ); ok(framesButton.disabled, "Frames button is disabled."); info("Leave the options panel, the frames button should not be rendered."); await toolbox.selectTool("webconsole"); framesButton = doc.getElementById("command-button-frames"); ok(!framesButton, "Frames button is no longer rendered."); info("Go back to the options panel, the frames button should rendered."); await toolbox.selectTool("options"); framesButton = doc.getElementById("command-button-frames"); ok(framesButton, "Frames button is rendered again."); // Do not run the rest of this test when both fission and EFT is disabled as // it prevents creating a target for the iframe if (!isFissionEnabled() || !isEveryFrameTargetEnabled()) { return; } info("Navigate to a page with frames, the frames button should be enabled."); await navigateTo(TEST_URL_FRAMES); framesButton = doc.getElementById("command-button-frames"); ok(framesButton, "Frames button is still rendered."); await waitFor(() => { framesButton = doc.getElementById("command-button-frames"); return framesButton && !framesButton.disabled; }); const { targetCommand } = toolbox.commands; const iframeTarget = targetCommand .getAllTargets([targetCommand.TYPES.FRAME]) .find(target => target.url == TEST_IFRAME_URL); ok(iframeTarget, "Found the target for the iframe"); ok( !framesButton.classList.contains("checked"), "Before selecting an iframe, the button is not checked" ); await toolbox.commands.targetCommand.selectTarget(iframeTarget); ok( framesButton.classList.contains("checked"), "After selecting an iframe, the button is checked" ); info("Remove this first iframe, which is currently selected"); await SpecialPowers.spawn(gBrowser.selectedBrowser, [], function() { content.document.querySelector("iframe").remove(); }); await waitFor(() => { return targetCommand.selectedTargetFront == targetCommand.targetFront; }, "Wait for the selected target to be back on the top target"); ok( !framesButton.classList.contains("checked"), "The button is back unchecked after having removed the selected iframe" ); Services.prefs.clearUserPref(FRAME_BUTTON_PREF); });