Bug 981305 - don't insert leading or duplicate separators, r=mconley

This commit is contained in:
Gijs Kruitbosch 2014-03-21 17:02:41 +00:00
parent a3d7d2c5f0
commit ecde861719
3 changed files with 57 additions and 0 deletions

View File

@ -300,6 +300,11 @@ const CustomizableWidgets = [{
let item; let item;
if (node.localName == "menuseparator") { if (node.localName == "menuseparator") {
// Don't insert duplicate or leading separators. This can happen if there are
// menus (which we don't copy) above the separator.
if (!fragment.lastChild || fragment.lastChild.localName == "menuseparator") {
continue;
}
item = doc.createElementNS(kNSXUL, "menuseparator"); item = doc.createElementNS(kNSXUL, "menuseparator");
} else if (node.localName == "menuitem") { } else if (node.localName == "menuitem") {
item = doc.createElementNS(kNSXUL, "toolbarbutton"); item = doc.createElementNS(kNSXUL, "toolbarbutton");

View File

@ -81,4 +81,5 @@ skip-if = os == "linux"
[browser_978084_dragEnd_after_move.js] [browser_978084_dragEnd_after_move.js]
[browser_980155_add_overflow_toolbar.js] [browser_980155_add_overflow_toolbar.js]
[browser_981418-widget-onbeforecreated-handler.js] [browser_981418-widget-onbeforecreated-handler.js]
[browser_981305_separator_insertion.js]
[browser_panel_toggle.js] [browser_panel_toggle.js]

View File

@ -0,0 +1,51 @@
/* 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";
let tempElements = [];
// Shouldn't insert multiple separators into the developer tools subview
add_task(function testMultipleDevtoolsSeparators() {
let devtoolsSubMenu = document.getElementById("menuWebDeveloperPopup");
// Last element is null to insert at the end:
let beforeEls = [devtoolsSubMenu.firstChild, devtoolsSubMenu.lastChild, null];
for (let i = 0; i < beforeEls.length; i++) {
let sep = document.createElement("menuseparator");
tempElements.push(sep);
devtoolsSubMenu.insertBefore(sep, beforeEls[i]);
let menu = document.createElement("menu");
tempElements.push(menu);
devtoolsSubMenu.insertBefore(menu, beforeEls[i]);
// And another separator for good measure:
sep = document.createElement("menuseparator");
tempElements.push(sep);
devtoolsSubMenu.insertBefore(sep, beforeEls[i]);
}
yield PanelUI.show();
let devtoolsButton = document.getElementById("developer-button");
devtoolsButton.click();
yield waitForCondition(() => !PanelUI.multiView.hasAttribute("transitioning"));
let subview = document.getElementById("PanelUI-developerItems");
ok(subview.firstChild, "Subview should have a kid");
is(subview.firstChild.localName, "toolbarbutton", "There should be no separators to start with");
for (let kid of subview.children) {
if (kid.localName == "menuseparator") {
ok(kid.previousSibling && kid.previousSibling.localName != "menuseparator",
"Separators should never have another separator next to them, and should never be the first node.");
}
}
let panelHiddenPromise = promisePanelHidden(window);
PanelUI.hide();
yield panelHiddenPromise;
});
registerCleanupFunction(function() {
for (let el of tempElements) {
el.remove();
}
tempElements = null;
});