summaryrefslogtreecommitdiffstats
path: root/browser/base/content/test/alerts/head.js
blob: 21257de31d8db2640178964278915ad6abe97a5a (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
59
60
61
62
63
64
65
66
67
68
69
70
71
function promiseAlertWindow() {
  return new Promise(function(resolve) {
    let listener = {
      onOpenWindow(window) {
        let alertWindow = window.QueryInterface(Ci.nsIInterfaceRequestor).getInterface(Ci.nsIDOMWindow);
        alertWindow.addEventListener("load", function onLoad() {
          alertWindow.removeEventListener("load", onLoad);
          let windowType = alertWindow.document.documentElement.getAttribute("windowtype");
          if (windowType != "alert:alert") {
            return;
          }
          Services.wm.removeListener(listener);
          resolve(alertWindow);
        });
      },
    };
    Services.wm.addListener(listener);
  });
}

/**
 * Similar to `BrowserTestUtils.closeWindow`, but
 * doesn't call `window.close()`.
 */
function promiseWindowClosed(window) {
  return new Promise(function(resolve) {
    Services.ww.registerNotification(function observer(subject, topic, data) {
      if (topic == "domwindowclosed" && subject == window) {
        Services.ww.unregisterNotification(observer);
        resolve();
      }
    });
  });
}

/**
 * These two functions work with file_dom_notifications.html to open the
 * notification and close it.
 *
 * |fn| can be showNotification1 or showNotification2.
 * if |timeout| is passed, then the promise returned from this function is
 * rejected after the requested number of miliseconds.
 */
function openNotification(aBrowser, fn, timeout) {
  return ContentTask.spawn(aBrowser, { fn, timeout }, function* ({ fn, timeout }) {
    let win = content.wrappedJSObject;
    let notification = win[fn]();
    win._notification = notification;
    yield new Promise((resolve, reject) => {
      function listener() {
        notification.removeEventListener("show", listener);
        resolve();
      }

      notification.addEventListener("show", listener);

      if (timeout) {
        content.setTimeout(() => {
          notification.removeEventListener("show", listener);
          reject("timed out");
        }, timeout);
      }
    });
  });
}

function closeNotification(aBrowser) {
  return ContentTask.spawn(aBrowser, null, function() {
    content.wrappedJSObject._notification.close();
  });
}