fune/browser/base/content/test/popupNotifications/browser_popupNotification_checkbox.js
Jared Wein 43bac26d30 Bug 1331661 - Enable the 'quotes' rule for eslint and fix most of the errors with --fix. r=Gijs
MozReview-Commit-ID: 6tv0Z06CO4a

--HG--
extra : rebase_source : 014c0b04d8538dc5f15bc6dd4ed6bd220c55c5d4
2017-01-17 09:48:17 -06:00

208 lines
7.4 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/. */
function test() {
waitForExplicitFinish();
ok(PopupNotifications, "PopupNotifications object exists");
ok(PopupNotifications.panel, "PopupNotifications panel exists");
setup();
}
function checkCheckbox(checkbox, label, checked = false, hidden = false) {
is(checkbox.label, label, "Checkbox should have the correct label");
is(checkbox.hidden, hidden, "Checkbox should be shown");
is(checkbox.checked, checked, "Checkbox should be checked by default");
}
function checkMainAction(notification, disabled = false) {
let mainAction = notification.button;
let warningLabel = document.getAnonymousElementByAttribute(notification, "class", "popup-notification-warning");
is(warningLabel.hidden, !disabled, "Warning label should be shown");
is(mainAction.disabled, disabled, "MainAction should be disabled");
}
function promiseElementVisible(element) {
// HTMLElement.offsetParent is null when the element is not visisble
// (or if the element has |position: fixed|). See:
// https://developer.mozilla.org/en-US/docs/Web/API/HTMLElement/offsetParent
return BrowserTestUtils.waitForCondition(() => element.offsetParent !== null,
"Waiting for element to be visible");
}
var gNotification;
var tests = [
// Test that passing the checkbox field shows the checkbox.
{ id: "show_checkbox",
run() {
this.notifyObj = new BasicNotification(this.id);
this.notifyObj.options.checkbox = {
label: "This is a checkbox",
};
gNotification = showNotification(this.notifyObj);
},
onShown(popup) {
checkPopup(popup, this.notifyObj);
let notification = popup.childNodes[0];
checkCheckbox(notification.checkbox, "This is a checkbox");
triggerMainCommand(popup);
},
onHidden() { }
},
// Test checkbox being checked by default
{ id: "checkbox_checked",
run() {
this.notifyObj = new BasicNotification(this.id);
this.notifyObj.options.checkbox = {
label: "Check this",
checked: true,
};
gNotification = showNotification(this.notifyObj);
},
onShown(popup) {
checkPopup(popup, this.notifyObj);
let notification = popup.childNodes[0];
checkCheckbox(notification.checkbox, "Check this", true);
triggerMainCommand(popup);
},
onHidden() { }
},
// Test checkbox passing the checkbox state on mainAction
{ id: "checkbox_passCheckboxChecked_mainAction",
run() {
this.notifyObj = new BasicNotification(this.id);
this.notifyObj.mainAction.callback = ({checkboxChecked}) => this.mainActionChecked = checkboxChecked;
this.notifyObj.options.checkbox = {
label: "This is a checkbox",
};
gNotification = showNotification(this.notifyObj);
},
*onShown(popup) {
checkPopup(popup, this.notifyObj);
let notification = popup.childNodes[0];
let checkbox = notification.checkbox;
checkCheckbox(checkbox, "This is a checkbox");
yield promiseElementVisible(checkbox);
EventUtils.synthesizeMouseAtCenter(checkbox, {});
checkCheckbox(checkbox, "This is a checkbox", true);
triggerMainCommand(popup);
},
onHidden() {
is(this.mainActionChecked, true, "mainAction callback is passed the correct checkbox value");
}
},
// Test checkbox passing the checkbox state on secondaryAction
{ id: "checkbox_passCheckboxChecked_secondaryAction",
run() {
this.notifyObj = new BasicNotification(this.id);
this.notifyObj.secondaryActions = [{
label: "Test Secondary",
accessKey: "T",
callback: ({checkboxChecked}) => this.secondaryActionChecked = checkboxChecked,
}];
this.notifyObj.options.checkbox = {
label: "This is a checkbox",
};
gNotification = showNotification(this.notifyObj);
},
*onShown(popup) {
checkPopup(popup, this.notifyObj);
let notification = popup.childNodes[0];
let checkbox = notification.checkbox;
checkCheckbox(checkbox, "This is a checkbox");
yield promiseElementVisible(checkbox);
EventUtils.synthesizeMouseAtCenter(checkbox, {});
checkCheckbox(checkbox, "This is a checkbox", true);
triggerSecondaryCommand(popup, 0);
},
onHidden() {
is(this.secondaryActionChecked, true, "secondaryAction callback is passed the correct checkbox value");
}
},
// Test checkbox preserving its state through re-opening the doorhanger
{ id: "checkbox_reopen",
run() {
this.notifyObj = new BasicNotification(this.id);
this.notifyObj.options.checkbox = {
label: "This is a checkbox",
checkedState: {
disableMainAction: true,
warningLabel: "Testing disable",
},
};
gNotification = showNotification(this.notifyObj);
},
*onShown(popup) {
checkPopup(popup, this.notifyObj);
let notification = popup.childNodes[0];
let checkbox = notification.checkbox;
checkCheckbox(checkbox, "This is a checkbox");
yield promiseElementVisible(checkbox);
EventUtils.synthesizeMouseAtCenter(checkbox, {});
dismissNotification(popup);
},
onHidden(popup) {
let icon = document.getElementById("default-notification-icon");
EventUtils.synthesizeMouseAtCenter(icon, {});
let notification = popup.childNodes[0];
let checkbox = notification.checkbox;
checkCheckbox(checkbox, "This is a checkbox", true);
checkMainAction(notification, true);
gNotification.remove();
}
},
];
// Test checkbox disabling the main action in different combinations
["checkedState", "uncheckedState"].forEach(function(state) {
[true, false].forEach(function(checked) {
tests.push(
{ id: `checkbox_disableMainAction_${state}_${checked ? "checked" : "unchecked"}`,
run() {
this.notifyObj = new BasicNotification(this.id);
this.notifyObj.options.checkbox = {
label: "This is a checkbox",
checked,
[state]: {
disableMainAction: true,
warningLabel: "Testing disable",
},
};
gNotification = showNotification(this.notifyObj);
},
*onShown(popup) {
checkPopup(popup, this.notifyObj);
let notification = popup.childNodes[0];
let checkbox = notification.checkbox;
let disabled = (state === "checkedState" && checked) ||
(state === "uncheckedState" && !checked);
checkCheckbox(checkbox, "This is a checkbox", checked);
checkMainAction(notification, disabled);
yield promiseElementVisible(checkbox);
EventUtils.synthesizeMouseAtCenter(checkbox, {});
checkCheckbox(checkbox, "This is a checkbox", !checked);
checkMainAction(notification, !disabled);
EventUtils.synthesizeMouseAtCenter(checkbox, {});
checkCheckbox(checkbox, "This is a checkbox", checked);
checkMainAction(notification, disabled);
// Unblock the main command if it's currently disabled.
if (disabled) {
EventUtils.synthesizeMouseAtCenter(checkbox, {});
}
triggerMainCommand(popup);
},
onHidden() { }
}
);
});
});