forked from mirrors/gecko-dev
82 lines
2.2 KiB
JavaScript
82 lines
2.2 KiB
JavaScript
"use strict";
|
|
|
|
function openIdentityPopup() {
|
|
let promise = BrowserTestUtils.waitForEvent(
|
|
window,
|
|
"popupshown",
|
|
true,
|
|
event => event.target == gIdentityHandler._identityPopup
|
|
);
|
|
gIdentityHandler._identityIconBox.click();
|
|
return promise;
|
|
}
|
|
|
|
function closeIdentityPopup() {
|
|
let promise = BrowserTestUtils.waitForEvent(
|
|
gIdentityHandler._identityPopup,
|
|
"popuphidden"
|
|
);
|
|
gIdentityHandler._identityPopup.hidePopup();
|
|
return promise;
|
|
}
|
|
|
|
// This test checks applied WebExtension themes that attempt to change
|
|
// popup properties
|
|
|
|
add_task(async function test_popup_styling(browser, accDoc) {
|
|
const POPUP_BACKGROUND_COLOR = "#FF0000";
|
|
const POPUP_TEXT_COLOR = "#008000";
|
|
const POPUP_BORDER_COLOR = "#0000FF";
|
|
|
|
let extension = ExtensionTestUtils.loadExtension({
|
|
manifest: {
|
|
theme: {
|
|
images: {
|
|
theme_frame: "image1.png",
|
|
},
|
|
colors: {
|
|
frame: ACCENT_COLOR,
|
|
tab_background_text: TEXT_COLOR,
|
|
popup: POPUP_BACKGROUND_COLOR,
|
|
popup_text: POPUP_TEXT_COLOR,
|
|
popup_border: POPUP_BORDER_COLOR,
|
|
},
|
|
},
|
|
},
|
|
files: {
|
|
"image1.png": BACKGROUND,
|
|
},
|
|
});
|
|
|
|
await BrowserTestUtils.withNewTab(
|
|
{ gBrowser, url: "https://example.com" },
|
|
async function(browser) {
|
|
await extension.startup();
|
|
|
|
// Open the information arrow panel
|
|
await openIdentityPopup();
|
|
|
|
let arrowContent = gIdentityHandler._identityPopup.panelContent;
|
|
let arrowContentComputedStyle = window.getComputedStyle(arrowContent);
|
|
// Ensure popup background color was set properly
|
|
Assert.equal(
|
|
arrowContentComputedStyle.getPropertyValue("background-color"),
|
|
`rgb(${hexToRGB(POPUP_BACKGROUND_COLOR).join(", ")})`,
|
|
"Popup background color should have been themed"
|
|
);
|
|
|
|
// Ensure popup text color was set properly
|
|
Assert.equal(
|
|
arrowContentComputedStyle.getPropertyValue("color"),
|
|
`rgb(${hexToRGB(POPUP_TEXT_COLOR).join(", ")})`,
|
|
"Popup text color should have been themed"
|
|
);
|
|
|
|
// Ensure popup border color was set properly
|
|
testBorderColor(arrowContent, POPUP_BORDER_COLOR);
|
|
|
|
await closeIdentityPopup();
|
|
await extension.unload();
|
|
}
|
|
);
|
|
});
|