fune/browser/components/customizableui/test/browser_980155_add_overflow_toolbar.js
Jared Wein 3f6801477a Bug 1242137 - Fix eslint errors in /browser/components/customizableui. r=gijs
--HG--
extra : commitid : CTMv8KOMjRK
extra : rebase_source : 768fb80e4652c1f0e14eea9e32da8eff795f1659
extra : amend_source : bd695a57c00c8004b048ccd4673465d66bea22c6
extra : histedit_source : ca0c6fcb719d0e7f0895de1bd429fa9804833f65
2016-01-23 14:55:27 -05:00

51 lines
2 KiB
JavaScript

/* 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 kToolbarName = "test-new-overflowable-toolbar";
const kTestWidgetPrefix = "test-widget-for-overflowable-toolbar-";
add_task(function* addOverflowingToolbar() {
let originalWindowWidth = window.outerWidth;
let widgetIds = [];
for (let i = 0; i < 10; i++) {
let id = kTestWidgetPrefix + i;
widgetIds.push(id);
let spec = {id: id, type: "button", removable: true, label: "test", tooltiptext: "" + i};
CustomizableUI.createWidget(spec);
}
let toolbarNode = createOverflowableToolbarWithPlacements(kToolbarName, widgetIds);
assertAreaPlacements(kToolbarName, widgetIds);
for (let id of widgetIds) {
document.getElementById(id).style.minWidth = "200px";
}
isnot(toolbarNode.overflowable, null, "Toolbar should have overflowable controller");
isnot(toolbarNode.customizationTarget, null, "Toolbar should have customization target");
isnot(toolbarNode.customizationTarget, toolbarNode, "Customization target should not be toolbar node");
let oldChildCount = toolbarNode.customizationTarget.childElementCount;
let overflowableList = document.getElementById(kToolbarName + "-overflow-list");
let oldOverflowCount = overflowableList.childElementCount;
isnot(oldChildCount, 0, "Toolbar should have non-overflowing widgets");
window.resizeTo(400, window.outerHeight);
yield waitForCondition(() => toolbarNode.hasAttribute("overflowing"));
ok(toolbarNode.hasAttribute("overflowing"), "Should have an overflowing toolbar.");
ok(toolbarNode.customizationTarget.childElementCount < oldChildCount, "Should have fewer children.");
ok(overflowableList.childElementCount > oldOverflowCount, "Should have more overflowed widgets.");
window.resizeTo(originalWindowWidth, window.outerHeight);
});
add_task(function* asyncCleanup() {
removeCustomToolbars();
yield resetCustomization();
});