summaryrefslogtreecommitdiffstats
path: root/browser/base/content/test/statuspanel/head.js
blob: 23df2e62715f39bc1cb6d76478a22def8b071dbb (plain)
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
58
/* Any copyright is dedicated to the Public Domain.
 * http://creativecommons.org/publicdomain/zero/1.0/ */

/**
 * Returns a Promise that resolves when a StatusPanel for a
 * window has finished being shown. Also asserts that the
 * text content of the StatusPanel matches a value.
 *
 * @param win (browser window)
 *        The window that the StatusPanel belongs to.
 * @param value (string)
 *        The value that the StatusPanel should show.
 * @returns Promise
 */
async function promiseStatusPanelShown(win, value) {
  let panel = win.StatusPanel.panel;
  info("Waiting to show panel");
  await BrowserTestUtils.waitForEvent(panel, "transitionend", e => {
    return (
      e.propertyName === "opacity" &&
      win.getComputedStyle(e.target).opacity == "1"
    );
  });

  Assert.equal(win.StatusPanel._labelElement.value, value);
}

/**
 * Returns a Promise that resolves when a StatusPanel for a
 * window has finished being hidden.
 *
 * @param win (browser window)
 *        The window that the StatusPanel belongs to.
 */
async function promiseStatusPanelHidden(win) {
  let panel = win.StatusPanel.panel;
  info("Waiting to hide panel");
  await new Promise(resolve => {
    let l = e => {
      if (
        e.propertyName === "opacity" &&
        win.getComputedStyle(e.target).opacity == "0"
      ) {
        info("Panel hid after " + e.type + " event");
        panel.removeEventListener("transitionend", l);
        panel.removeEventListener("transitioncancel", l);
        is(
          getComputedStyle(panel).display,
          "none",
          "Should be hidden for good"
        );
        resolve();
      }
    };
    panel.addEventListener("transitionend", l);
    panel.addEventListener("transitioncancel", l);
  });
}