File: browser_webconsole_bug_658368_time_methods.js

package info (click to toggle)
iceweasel 31.6.0esr-1
  • links: PTS, VCS
  • area: main
  • in suites: jessie-kfreebsd
  • size: 1,368,576 kB
  • sloc: cpp: 3,692,968; ansic: 1,797,194; python: 193,401; java: 180,622; asm: 133,557; xml: 89,288; sh: 71,748; perl: 22,087; makefile: 21,687; objc: 4,014; yacc: 1,995; pascal: 1,292; lex: 950; exp: 449; lisp: 228; awk: 211; php: 113; sed: 43; csh: 31; ada: 16; ruby: 3
file content (87 lines) | stat: -rw-r--r-- 2,571 bytes parent folder | download | duplicates (5)
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
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
/* vim:set ts=2 sw=2 sts=2 et: */
/*
 * Any copyright is dedicated to the Public Domain.
 * http://creativecommons.org/publicdomain/zero/1.0/
 */

// Tests that the Console API implements the time() and timeEnd() methods.

function test() {
  addTab("http://example.com/browser/browser/devtools/webconsole/" +
         "test/test-bug-658368-time-methods.html");
  browser.addEventListener("load", function onLoad() {
    browser.removeEventListener("load", onLoad, true);
    Task.spawn(runner);
  }, true);

  function* runner() {
    let hud1 = yield openConsole();

    yield waitForMessages({
      webconsole: hud1,
      messages: [{
        name: "aTimer started",
        consoleTime: "aTimer",
      }, {
        name: "aTimer end",
        consoleTimeEnd: "aTimer",
      }],
    });

    let deferred = promise.defer();

    // The next test makes sure that timers with the same name but in separate
    // tabs, do not contain the same value.
    addTab("data:text/html;charset=utf-8,<script>" +
           "console.timeEnd('bTimer');</script>");
    browser.addEventListener("load", function onLoad() {
      browser.removeEventListener("load", onLoad, true);
      openConsole().then((hud) => {
        deferred.resolve(hud);
      });
    }, true);

    let hud2 = yield deferred.promise;

    testLogEntry(hud2.outputNode, "bTimer: timer started",
                 "bTimer was not started", false, true);

    // The next test makes sure that timers with the same name but in separate
    // pages, do not contain the same value.
    content.location = "data:text/html;charset=utf-8,<script>" +
                       "console.time('bTimer');</script>";

    yield waitForMessages({
      webconsole: hud2,
      messages: [{
        name: "bTimer started",
        consoleTime: "bTimer",
      }],
    });

    hud2.jsterm.clearOutput();

    deferred = promise.defer();

    // Now the following console.timeEnd() call shouldn't display anything,
    // if the timers in different pages are not related.
    browser.addEventListener("load", function onLoad() {
      browser.removeEventListener("load", onLoad, true);
      deferred.resolve(null);
    }, true);

    content.location = "data:text/html;charset=utf-8," +
                       "<script>console.timeEnd('bTimer');</script>";

    yield deferred.promise;

    testLogEntry(hud2.outputNode, "bTimer: timer started",
                 "bTimer was not started", false, true);

    yield closeConsole(gBrowser.selectedTab);

    gBrowser.removeCurrentTab();

    executeSoon(finishTest);
  }
}