Source code

Revision control

Copy as Markdown

Other Tools

Test Info: Warnings

/* 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/. */
const { FormHistory } = ChromeUtils.importESModule(
);
add_task(async function test() {
const url = `data:text/html,<input type="text" name="field1">`;
await BrowserTestUtils.withNewTab(
{ gBrowser, url },
async function (browser) {
const {
autoCompletePopup,
autoCompletePopup: { richlistbox: itemsBox },
} = browser;
const mockHistory = [
{ op: "add", fieldname: "field1", value: "value1" },
{ op: "add", fieldname: "field1", value: "value2" },
{ op: "add", fieldname: "field1", value: "value3" },
{ op: "add", fieldname: "field1", value: "value4" },
];
await FormHistory.update([{ op: "remove" }, ...mockHistory]);
await SpecialPowers.spawn(browser, [], async function () {
const input = content.document.querySelector("input");
input.focus();
});
// show popup
await BrowserTestUtils.synthesizeKey("VK_DOWN", {}, browser);
await BrowserTestUtils.waitForCondition(() => {
return autoCompletePopup.popupOpen;
});
Assert.equal(
autoCompletePopup.matchCount,
mockHistory.length,
"ensure result length"
);
Assert.equal(
autoCompletePopup.mousedOverIndex,
-1,
"mousedOverIndex should be -1"
);
// navigate to the first item
await BrowserTestUtils.synthesizeKey("VK_DOWN", {}, browser);
Assert.equal(
autoCompletePopup.selectedIndex,
0,
"selectedIndex should be 0"
);
// mouseover the second item
const listItemElems = itemsBox.querySelectorAll(
".autocomplete-richlistitem"
);
EventUtils.synthesizeMouseAtCenter(listItemElems[1], {
type: "mouseover",
});
await BrowserTestUtils.waitForCondition(() => {
return (autoCompletePopup.mousedOverIndex = 1);
});
Assert.ok(true, "mousedOverIndex changed");
Assert.equal(
autoCompletePopup.selectedIndex,
0,
"selectedIndex should not be changed by mouseover"
);
// close popup
await SpecialPowers.spawn(browser, [], async function () {
const input = content.document.querySelector("input");
input.blur();
});
}
);
});