1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
|
"use strict";
const CC_URL =
"https://example.org/browser/browser/extensions/formautofill/test/browser/creditCard/autocomplete_creditcard_basic.html";
add_task(async function setup_storage() {
await setStorage(TEST_CREDIT_CARD_1, TEST_CREDIT_CARD_2, TEST_CREDIT_CARD_3);
});
async function reopenPopupWithResizedInput(browser, selector, newSize) {
await closePopup(browser);
/* eslint no-shadow: ["error", { "allow": ["selector", "newSize"] }] */
await SpecialPowers.spawn(
browser,
[{ selector, newSize }],
async function ({ selector, newSize }) {
const input = content.document.querySelector(selector);
input.style.boxSizing = "border-box";
input.style.width = newSize + "px";
}
);
await openPopupOn(browser, selector);
}
add_task(async function test_credit_card_dropdown() {
await BrowserTestUtils.withNewTab(
{ gBrowser, url: CC_URL },
async function (browser) {
const focusInput = "#cc-number";
await openPopupOn(browser, focusInput);
const firstItem = getDisplayedPopupItems(browser)[0];
isnot(firstItem.getAttribute("ac-image"), "", "Should show icon");
ok(
firstItem.getAttribute("aria-label").startsWith("Visa "),
"aria-label should start with Visa"
);
// The breakpoint of two-lines layout is 185px
await reopenPopupWithResizedInput(browser, focusInput, 175);
is(
firstItem._itemBox.getAttribute("size"),
"small",
"Show two-lines layout"
);
await reopenPopupWithResizedInput(browser, focusInput, 195);
is(
firstItem._itemBox.hasAttribute("size"),
false,
"Show one-line layout"
);
await closePopup(browser);
}
);
});
|