summaryrefslogtreecommitdiffstats
path: root/dom/tests/browser/browser_bug1004814.js
blob: 789709a8d7d8b3d5215c29a7c0a01d57d0d103d7 (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
/* vim:set ts=2 sw=2 sts=2 et: */
/* This Source Code Form is subject to the terms of the Mozilla Public
 * License, v. 2.0. If a copy of the MPL was not distributed with this
 * file, You can obtain one at http://mozilla.org/MPL/2.0/. */

add_task(async function () {
  const TEST_URI =
    "http://example.com/browser/dom/tests/browser/test_bug1004814.html";

  await BrowserTestUtils.withNewTab(TEST_URI, async aBrowser => {
    let duration = await SpecialPowers.spawn(aBrowser, [], function (opts) {
      const ConsoleAPIStorage = Cc[
        "@mozilla.org/consoleAPI-storage;1"
      ].getService(Ci.nsIConsoleAPIStorage);

      return new Promise(resolve => {
        function observe(aSubject) {
          var obj = aSubject.wrappedJSObject;
          if (
            obj.arguments.length != 1 ||
            obj.arguments[0] != "bug1004814" ||
            obj.level != "timeEnd"
          ) {
            return;
          }

          ConsoleAPIStorage.removeLogEventListener(observe);
          resolve(obj.timer.duration);
        }

        ConsoleAPIStorage.addLogEventListener(
          observe,
          Cc["@mozilla.org/systemprincipal;1"].createInstance(Ci.nsIPrincipal)
        );

        var w = new content.Worker("worker_bug1004814.js");
        w.postMessage(true);
      });
    });

    Assert.greater(
      duration,
      0,
      "ConsoleEvent.timer.duration > 0: " + duration + " ~ 200ms"
    );
  });
});