diff options
author | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-19 01:47:29 +0000 |
---|---|---|
committer | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-19 01:47:29 +0000 |
commit | 0ebf5bdf043a27fd3dfb7f92e0cb63d88954c44d (patch) | |
tree | a31f07c9bcca9d56ce61e9a1ffd30ef350d513aa /widget/tests/taskbar_previews.xhtml | |
parent | Initial commit. (diff) | |
download | firefox-esr-upstream/115.8.0esr.tar.xz firefox-esr-upstream/115.8.0esr.zip |
Adding upstream version 115.8.0esr.upstream/115.8.0esr
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'widget/tests/taskbar_previews.xhtml')
-rw-r--r-- | widget/tests/taskbar_previews.xhtml | 116 |
1 files changed, 116 insertions, 0 deletions
diff --git a/widget/tests/taskbar_previews.xhtml b/widget/tests/taskbar_previews.xhtml new file mode 100644 index 0000000000..b220d5662b --- /dev/null +++ b/widget/tests/taskbar_previews.xhtml @@ -0,0 +1,116 @@ +<?xml version="1.0"?> +<?xml-stylesheet href="chrome://global/skin" type="text/css"?> +<?xml-stylesheet href="chrome://mochikit/content/tests/SimpleTest/test.css" + type="text/css"?> +<window title="Taskbar Previews Test" + xmlns:html="http://www.w3.org/1999/xhtml" + xmlns="http://www.mozilla.org/keymaster/gatekeeper/there.is.only.xul" + onload="loaded();"> + + <title>Previews - yeah!</title> + <script src="chrome://mochikit/content/tests/SimpleTest/SimpleTest.js" /> + <script class="testbody" type="application/javascript"> + <![CDATA[ + let taskbar = Cc["@mozilla.org/windows-taskbar;1"].getService(Ci.nsIWinTaskbar); + + function IsWin7OrHigher() { + try { + var ver = parseFloat(Services.sysinfo.getProperty("version")); + if (ver >= 6.1) + return true; + } catch (ex) { } + return false; + } + isnot(taskbar, null, "Taskbar service is defined"); + is(taskbar.available, IsWin7OrHigher(), "Expected availability of taskbar"); + + SimpleTest.waitForExplicitFinish(); + + function stdPreviewSuite(p) { + p.visible = !p.visible; + p.visible = !p.visible; + p.visible = true; + p.invalidate(); + p.visible = false; + } + + function loaded() + { + if (!taskbar.available) + SimpleTest.finish(); + let controller = { + width: 400, + height: 400, + thumbnailAspectRatio: 1.0, + get wrappedJSObject() { return this; } + } + // HACK from mconnor: + let win = Services.wm.getMostRecentWindow("navigator:browser"); + let docShell = win.gBrowser.docShell; + + let winPreview = taskbar.getTaskbarWindowPreview(docShell); + isnot(winPreview, null, "Window preview is not null"); + winPreview.controller = controller; + let button = winPreview.getButton(0); + isnot(button, null, "Could get button at valid index"); + try { + winPreview.getButton(-1); + ok(false, "Got button at negative index"); + } catch (ex) {} + try { + winPreview.getButton(Ci.nsITaskbarWindowPreview.NUM_TOOLBAR_BUTTONS); + ok(false, "Got button at index that is too large"); + } catch (ex) {} + button.image = null; + stdPreviewSuite(winPreview); + // Let's not perma-hide this window from the taskbar + winPreview.visible = true; + + let tabP = taskbar.createTaskbarTabPreview(docShell, controller); + isnot(tabP, null, "Tab preview is not null"); + is(tabP.controller.wrappedJSObject, controller, "Controllers match"); + is(tabP.icon, null, "Default icon is null (windows default)"); + tabP.icon = null; + tabP.move(null); + try { + tabP.move(tabP); + ok(false, "Moved a preview next to itself!"); + } catch (ex) {} + stdPreviewSuite(tabP); + + let tabP2 = taskbar.createTaskbarTabPreview(docShell, controller); + tabP.visible = true; + tabP2.visible = true; + + isnot(tabP2, null, "2nd Tab preview is not null"); + isnot(tabP,tabP2, "Tab previews are different"); + tabP.active = true; + ok(tabP.active && !tabP2.active, "Only one tab is active (part 1)"); + tabP2.active = true; + ok(!tabP.active && tabP2.active, "Only one tab is active (part 2)"); + tabP.active = true; + ok(tabP.active && !tabP2.active, "Only one tab is active (part 3)"); + tabP.active = false; + ok(!tabP.active && !tabP2.active, "Neither tab is active"); + is(winPreview.active, false, "Window preview is not active"); + tabP.active = true; + winPreview.active = true; + ok(winPreview.active && !tabP.active, "Tab preview takes activation from window"); + tabP.active = true; + ok(tabP.active && !winPreview.active, "Tab preview takes activation from window"); + + tabP.visible = false; + tabP2.visible = false; + + SimpleTest.finish(); + } + ]]> + </script> + + <body xmlns="http://www.w3.org/1999/xhtml"> + <p id="display"></p> + <div id="content" style="display: none"></div> + <pre id="test"></pre> + </body> + +</window> |