summaryrefslogtreecommitdiffstats
path: root/browser/components/extensions/test/browser/browser_ext_sidebarAction_browser_style.js
diff options
context:
space:
mode:
Diffstat (limited to 'browser/components/extensions/test/browser/browser_ext_sidebarAction_browser_style.js')
-rw-r--r--browser/components/extensions/test/browser/browser_ext_sidebarAction_browser_style.js90
1 files changed, 90 insertions, 0 deletions
diff --git a/browser/components/extensions/test/browser/browser_ext_sidebarAction_browser_style.js b/browser/components/extensions/test/browser/browser_ext_sidebarAction_browser_style.js
new file mode 100644
index 0000000000..866d7a3b3d
--- /dev/null
+++ b/browser/components/extensions/test/browser/browser_ext_sidebarAction_browser_style.js
@@ -0,0 +1,90 @@
+/* -*- Mode: indent-tabs-mode: nil; js-indent-level: 2 -*- */
+/* vim: set sts=2 sw=2 et tw=80: */
+"use strict";
+
+async function testSidebarBrowserStyle(sidebarAction, assertMessage) {
+ function sidebarScript() {
+ browser.test.onMessage.addListener((msgName, info, assertMessage) => {
+ if (msgName !== "check-style") {
+ browser.test.notifyFail("sidebar-browser-style");
+ }
+
+ let style = window.getComputedStyle(document.getElementById("button"));
+ let buttonBackgroundColor = style.backgroundColor;
+ let browserStyleBackgroundColor = "rgb(9, 150, 248)";
+ if (!("browser_style" in info) || info.browser_style) {
+ browser.test.assertEq(
+ browserStyleBackgroundColor,
+ buttonBackgroundColor,
+ assertMessage
+ );
+ } else {
+ browser.test.assertTrue(
+ browserStyleBackgroundColor !== buttonBackgroundColor,
+ assertMessage
+ );
+ }
+
+ browser.test.notifyPass("sidebar-browser-style");
+ });
+ browser.test.sendMessage("sidebar-ready");
+ }
+
+ let extension = ExtensionTestUtils.loadExtension({
+ manifest: {
+ sidebar_action: sidebarAction,
+ },
+ useAddonManager: "temporary",
+
+ files: {
+ "panel.html": `
+ <!DOCTYPE html>
+ <html>
+ <button id="button" name="button" class="browser-style default">Default</button>
+ <script src="panel.js" type="text/javascript"></script>
+ </html>`,
+ "panel.js": sidebarScript,
+ },
+ });
+
+ let tab = await BrowserTestUtils.openNewForegroundTab(gBrowser);
+
+ await extension.startup();
+ await extension.awaitMessage("sidebar-ready");
+
+ extension.sendMessage("check-style", sidebarAction, assertMessage);
+ await extension.awaitFinish("sidebar-browser-style");
+
+ await extension.unload();
+
+ BrowserTestUtils.removeTab(tab);
+}
+
+add_task(async function test_sidebar_without_setting_browser_style() {
+ await testSidebarBrowserStyle(
+ {
+ default_panel: "panel.html",
+ },
+ "Expected correct style when browser_style is excluded"
+ );
+});
+
+add_task(async function test_sidebar_with_browser_style_set_to_true() {
+ await testSidebarBrowserStyle(
+ {
+ default_panel: "panel.html",
+ browser_style: true,
+ },
+ "Expected correct style when browser_style is set to `true`"
+ );
+});
+
+add_task(async function test_sidebar_with_browser_style_set_to_false() {
+ await testSidebarBrowserStyle(
+ {
+ default_panel: "panel.html",
+ browser_style: false,
+ },
+ "Expected no style when browser_style is set to `false`"
+ );
+});