summaryrefslogtreecommitdiffstats
path: root/browser/components/customizableui/test/browser_989751_subviewbutton_class.js
blob: dd809d6403558c7117d14df9dc30bf44226d8eb1 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
/* This Source Code Form is subject to the terms of the Mozilla Public
 * License, v. 2.0. If a copy of the MPL was not distributed with this
 * file, You can obtain one at http://mozilla.org/MPL/2.0/. */

"use strict";

const kCustomClass = "acustomclassnoonewilluse";
const kDevPanelId = "PanelUI-developer-tools";
var tempElement = null;

function insertClassNameToMenuChildren(parentMenu) {
  // Skip hidden menuitem elements, not copied via fillSubviewFromMenuItems.
  let el = parentMenu.querySelector("menuitem:not([hidden])");
  el.classList.add(kCustomClass);
  tempElement = el;
}

function checkSubviewButtonClass(menuId, buttonId, subviewId) {
  return async function() {
    // Initialize DevTools before starting the test in order to create menuitems in
    // menuWebDeveloperPopup.
    ChromeUtils.importESModule(
      "resource://devtools/shared/loader/Loader.sys.mjs"
    ).require("devtools/client/framework/devtools-browser");

    info(
      "Checking for items without the subviewbutton class in " +
        buttonId +
        " widget"
    );
    let menu = document.getElementById(menuId);
    insertClassNameToMenuChildren(menu);

    CustomizableUI.addWidgetToArea(
      buttonId,
      CustomizableUI.AREA_FIXED_OVERFLOW_PANEL
    );

    await waitForOverflowButtonShown();

    await document.getElementById("nav-bar").overflowable.show();

    let button = document.getElementById(buttonId);
    button.click();

    await BrowserTestUtils.waitForEvent(PanelUI.overflowPanel, "ViewShown");
    let subview = document.getElementById(subviewId);
    ok(subview.firstElementChild, "Subview should have a kid");

    // The Developer Panel contains the Customize Toolbar item,
    // as well as the Developer Tools items (bug 1703150). We only want to query for
    // the Developer Tools items in this case.
    let query = "#appmenu-developer-tools-view toolbarbutton";
    let subviewchildren = subview.querySelectorAll(query);

    for (let i = 0; i < subviewchildren.length; i++) {
      let item = subviewchildren[i];
      let itemReadable =
        "Item '" + item.label + "' (classes: " + item.className + ")";
      ok(
        item.classList.contains("subviewbutton"),
        itemReadable + " should have the subviewbutton class."
      );
      if (i == 0) {
        ok(
          item.classList.contains(kCustomClass),
          itemReadable + " should still have its own class, too."
        );
      }
    }

    let panelHiddenPromise = promiseOverflowHidden(window);
    PanelUI.overflowPanel.hidePopup();
    await panelHiddenPromise;

    CustomizableUI.reset();
  };
}

add_task(
  checkSubviewButtonClass(
    "menuWebDeveloperPopup",
    "developer-button",
    kDevPanelId
  )
);

registerCleanupFunction(function() {
  tempElement.classList.remove(kCustomClass);
  tempElement = null;
});