"use strict"; // This test checks whether browser.theme.onUpdated works correctly with different // types of dynamic theme updates. // PNG image data for a simple red dot. const BACKGROUND_1 = ""; // PNG image data for the Mozilla dino head. const BACKGROUND_2 = ""; add_task(async function test_on_updated() { let extension = ExtensionTestUtils.loadExtension({ async background() { const ACCENT_COLOR_1 = "#a14040"; const TEXT_COLOR_1 = "#fac96e"; const ACCENT_COLOR_2 = "#03fe03"; const TEXT_COLOR_2 = "#0ef325"; const theme1 = { images: { theme_frame: "image1.png", }, colors: { frame: ACCENT_COLOR_1, tab_background_text: TEXT_COLOR_1, }, }; const theme2 = { images: { theme_frame: "image2.png", }, colors: { frame: ACCENT_COLOR_2, tab_background_text: TEXT_COLOR_2, }, }; function testTheme1(returnedTheme) { browser.test.assertTrue( returnedTheme.images.theme_frame.includes("image1.png"), "Theme 1 theme_frame image should be applied" ); browser.test.assertEq( ACCENT_COLOR_1, returnedTheme.colors.frame, "Theme 1 frame color should be applied" ); browser.test.assertEq( TEXT_COLOR_1, returnedTheme.colors.tab_background_text, "Theme 1 tab_background_text color should be applied" ); } function testTheme2(returnedTheme) { browser.test.assertTrue( returnedTheme.images.theme_frame.includes("image2.png"), "Theme 2 theme_frame image should be applied" ); browser.test.assertEq( ACCENT_COLOR_2, returnedTheme.colors.frame, "Theme 2 frame color should be applied" ); browser.test.assertEq( TEXT_COLOR_2, returnedTheme.colors.tab_background_text, "Theme 2 tab_background_text color should be applied" ); } const firstWin = await browser.windows.getCurrent(); const secondWin = await browser.windows.create(); const onceThemeUpdated = () => new Promise(resolve => { const listener = updateInfo => { browser.theme.onUpdated.removeListener(listener); resolve(updateInfo); }; browser.theme.onUpdated.addListener(listener); }); browser.test.log("Testing update with no windowId parameter"); let updateInfo1 = onceThemeUpdated(); await browser.theme.update(theme1); updateInfo1 = await updateInfo1; testTheme1(updateInfo1.theme); browser.test.assertTrue( !updateInfo1.windowId, "No window id on first update" ); browser.test.log("Testing update with windowId parameter"); let updateInfo2 = onceThemeUpdated(); await browser.theme.update(secondWin.id, theme2); updateInfo2 = await updateInfo2; testTheme2(updateInfo2.theme); browser.test.assertEq( secondWin.id, updateInfo2.windowId, "window id on second update" ); browser.test.log("Testing reset with windowId parameter"); let updateInfo3 = onceThemeUpdated(); await browser.theme.reset(firstWin.id); updateInfo3 = await updateInfo3; browser.test.assertEq( 0, Object.keys(updateInfo3.theme).length, "Empty theme given on reset" ); browser.test.assertEq( firstWin.id, updateInfo3.windowId, "window id on third update" ); browser.test.log("Testing reset with no windowId parameter"); let updateInfo4 = onceThemeUpdated(); await browser.theme.reset(); updateInfo4 = await updateInfo4; browser.test.assertEq( 0, Object.keys(updateInfo4.theme).length, "Empty theme given on reset" ); browser.test.assertTrue( !updateInfo4.windowId, "no window id on fourth update" ); browser.test.log("Cleaning up test"); await browser.windows.remove(secondWin.id); browser.test.notifyPass("onUpdated"); }, manifest: { permissions: ["theme"], }, files: { "image1.png": BACKGROUND_1, "image2.png": BACKGROUND_2, }, }); await extension.startup(); await extension.awaitFinish("onUpdated"); await extension.unload(); });