forked from mirrors/gecko-dev
Bug 1798814 - Prevent non-extension buttons from entering the AREA_ADDONS area. r=cmkm
Differential Revision: https://phabricator.services.mozilla.com/D161096
This commit is contained in:
parent
2945d873b2
commit
373c121342
3 changed files with 85 additions and 0 deletions
|
|
@ -3381,6 +3381,14 @@ var CustomizableUIInternal = {
|
|||
) {
|
||||
return false;
|
||||
}
|
||||
|
||||
if (
|
||||
aArea == CustomizableUI.AREA_ADDONS &&
|
||||
!CustomizableUI.isWebExtensionWidget(aWidgetId)
|
||||
) {
|
||||
return false;
|
||||
}
|
||||
|
||||
let placement = this.getPlacementOfWidget(aWidgetId);
|
||||
// Items in the palette can move, and items can move within their area:
|
||||
if (!placement || placement.area == aArea) {
|
||||
|
|
|
|||
|
|
@ -124,6 +124,7 @@ skip-if = verify
|
|||
[browser_1702200_PanelMultiView_header_separator.js]
|
||||
[browser_1795260_searchbar_overflow_toolbar.js]
|
||||
tags = overflowable-toolbar
|
||||
[browser_addons_area.js]
|
||||
[browser_allow_dragging_removable_false.js]
|
||||
[browser_bookmarks_toolbar_collapsed_restore_default.js]
|
||||
[browser_bookmarks_toolbar_shown_newtab.js]
|
||||
|
|
|
|||
|
|
@ -0,0 +1,76 @@
|
|||
/* Any copyright is dedicated to the Public Domain.
|
||||
http://creativecommons.org/publicdomain/zero/1.0/ */
|
||||
|
||||
"use strict";
|
||||
|
||||
/**
|
||||
* Test that widgets provided by extensions can be added to the
|
||||
* ADDONS area, but all other widgets cannot.
|
||||
*/
|
||||
add_task(async function test_only_extension_widgets_in_addons_area() {
|
||||
registerCleanupFunction(async () => {
|
||||
await CustomizableUI.reset();
|
||||
});
|
||||
|
||||
Assert.ok(
|
||||
!CustomizableUI.canWidgetMoveToArea(
|
||||
"home-button",
|
||||
CustomizableUI.AREA_ADDONS
|
||||
),
|
||||
"Cannot move a built-in button to the ADDONS area."
|
||||
);
|
||||
|
||||
// Now double-check that we cannot accidentally default a non-extension
|
||||
// widget into the ADDONS area.
|
||||
const kTestDynamicWidget = "a-test-widget";
|
||||
CustomizableUI.createWidget({
|
||||
id: kTestDynamicWidget,
|
||||
label: "Test widget",
|
||||
defaultArea: CustomizableUI.AREA_ADDONS,
|
||||
});
|
||||
Assert.equal(
|
||||
CustomizableUI.getPlacementOfWidget(kTestDynamicWidget),
|
||||
null,
|
||||
"An attempt to put a non-extension widget into the ADDONS area by default should fail."
|
||||
);
|
||||
CustomizableUI.destroyWidget(kTestDynamicWidget);
|
||||
|
||||
const kWebExtensionButtonID1 = "a-test-extension-button";
|
||||
|
||||
CustomizableUI.createWidget({
|
||||
id: kWebExtensionButtonID1,
|
||||
label: "Test extension widget",
|
||||
defaultArea: CustomizableUI.AREA_NAVBAR,
|
||||
webExtension: true,
|
||||
});
|
||||
|
||||
Assert.ok(
|
||||
CustomizableUI.canWidgetMoveToArea(
|
||||
kWebExtensionButtonID1,
|
||||
CustomizableUI.AREA_ADDONS
|
||||
),
|
||||
"Can move extension button to the addons area."
|
||||
);
|
||||
|
||||
CustomizableUI.destroyWidget(kWebExtensionButtonID1);
|
||||
|
||||
// Now check that extension buttons can default to the ADDONS area, if need
|
||||
// be.
|
||||
|
||||
const kWebExtensionButtonID2 = "a-test-extension-button-2";
|
||||
|
||||
CustomizableUI.createWidget({
|
||||
id: kWebExtensionButtonID2,
|
||||
label: "Test extension widget 2",
|
||||
defaultArea: CustomizableUI.AREA_ADDONS,
|
||||
webExtension: true,
|
||||
});
|
||||
|
||||
Assert.equal(
|
||||
CustomizableUI.getPlacementOfWidget(kWebExtensionButtonID2)?.area,
|
||||
CustomizableUI.AREA_ADDONS,
|
||||
"An attempt to put an extension widget into the ADDONS area by default should work."
|
||||
);
|
||||
|
||||
CustomizableUI.destroyWidget(kWebExtensionButtonID2);
|
||||
});
|
||||
Loading…
Reference in a new issue