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;
});
|