fune/browser/components/preferences/in-content/tests/browser_containers_name_input.js
Jonathan Kingston 7b1c4b610f Bug 1403593 - Change containers preference page to use command instead of click r=jaws
MozReview-Commit-ID: 95f9yOLVof5

--HG--
extra : rebase_source : 4278476e73cb9f8f161e7b93174e4d777db33ddb
2017-11-07 16:46:11 +00:00

50 lines
1.4 KiB
JavaScript

const CONTAINERS_URL = "chrome://browser/content/preferences/containers.xul";
add_task(async function setup() {
await openPreferencesViaOpenPreferencesAPI("containers", { leaveOpen: true });
registerCleanupFunction(async function() {
await BrowserTestUtils.removeTab(gBrowser.selectedTab);
});
});
add_task(async function() {
async function openDialog() {
let doc = gBrowser.selectedBrowser.contentDocument;
let dialogPromise = promiseLoadSubDialog(CONTAINERS_URL);
let addButton = doc.getElementById("containersAdd");
addButton.doCommand();
let dialog = await dialogPromise;
return dialog.document;
}
let doc = await openDialog();
let name = doc.getElementById("name");
let btnApplyChanges = doc.getElementById("btnApplyChanges");
Assert.equal(name.value, "",
"The name textbox should initlally be empty");
Assert.ok(btnApplyChanges.disabled,
"The done button should initially be disabled");
function setName(value) {
name.value = value;
let event = new doc.defaultView.InputEvent("input", { data: value });
SpecialPowers.dispatchEvent(doc.defaultView, name, event);
}
setName("test");
Assert.ok(!btnApplyChanges.disabled,
"The done button should be enabled when the value is not empty");
setName("");
Assert.ok(btnApplyChanges.disabled,
"The done button should be disabled when the value is empty");
});