File: browser_cmd_calllog_chrome.js

package info (click to toggle)
wine-gecko-2.21 2.21%2Bdfsg2-1
  • links: PTS, VCS
  • area: main
  • in suites: jessie, jessie-kfreebsd
  • size: 646,272 kB
  • ctags: 630,086
  • sloc: cpp: 2,895,786; ansic: 1,502,970; python: 156,675; asm: 115,373; java: 111,421; sh: 63,309; xml: 62,872; makefile: 58,685; perl: 19,182; objc: 3,461; yacc: 2,051; lex: 979; pascal: 929; exp: 449; php: 244; lisp: 228; awk: 211; sed: 26; csh: 21; ada: 16; ruby: 3
file content (113 lines) | stat: -rw-r--r-- 2,967 bytes parent folder | download
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
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
/* Any copyright is dedicated to the Public Domain.
* http://creativecommons.org/publicdomain/zero/1.0/ */

// Tests that the calllog commands works as they should

let imported = {};
Components.utils.import("resource:///modules/HUDService.jsm", imported);

const TEST_URI = "data:text/html;charset=utf-8,cmd-calllog-chrome";

function test() {
  DeveloperToolbarTest.test(TEST_URI, function CLCTest(browser, tab) {
    testCallLogStatus();
    testCallLogExec();
  });
}

function testCallLogStatus() {
  DeveloperToolbarTest.checkInputStatus({
    typed: "calllog",
    status: "ERROR",
    emptyParameters: [ " " ]
  });

  DeveloperToolbarTest.checkInputStatus({
    typed: "calllog chromestart content-variable window",
    status: "VALID",
    emptyParameters: [ " " ]
  });

  DeveloperToolbarTest.checkInputStatus({
    typed: "calllog chromestop",
    status: "VALID",
    emptyParameters: [ " " ]
  });

  DeveloperToolbarTest.checkInputStatus({
    typed: "calllog chromestart chrome-variable window",
    status: "VALID",
    emptyParameters: [ " " ]
  });

  DeveloperToolbarTest.checkInputStatus({
    typed: "calllog chromestop",
    status: "VALID",
    emptyParameters: [ " " ]
  });

  DeveloperToolbarTest.checkInputStatus({
    typed: "calllog chromestart javascript \"({a1: function() {this.a2()}," +
           "a2: function() {}});\"",
    status: "VALID",
    emptyParameters: [ " " ]
  });

  DeveloperToolbarTest.checkInputStatus({
    typed: "calllog chromestop",
    status: "VALID",
    emptyParameters: [ " " ]
  });
}

function testCallLogExec() {
  DeveloperToolbarTest.exec({
    typed: "calllog chromestop",
    args: { },
    outputMatch: /No call logging/,
  });

  function onWebConsoleOpen(aSubject) {
    Services.obs.removeObserver(onWebConsoleOpen, "web-console-created");

    aSubject.QueryInterface(Ci.nsISupportsString);
    let hud = imported.HUDService.getHudReferenceById(aSubject.data);
    ok(hud.hudId in imported.HUDService.hudReferences, "console open");

    DeveloperToolbarTest.exec({
      typed: "calllog chromestop",
      args: { },
      outputMatch: /Stopped call logging/,
    });

    DeveloperToolbarTest.exec({
      typed: "calllog chromestart javascript XXX",
      outputMatch: /following exception/,
    });

    DeveloperToolbarTest.exec({
      typed: "console clear",
      args: {},
      blankOutput: true,
    });

    let labels = hud.jsterm.outputNode.querySelectorAll(".webconsole-msg-output");
    is(labels.length, 0, "no output in console");

    DeveloperToolbarTest.exec({
      typed: "console close",
      args: {},
      blankOutput: true,
      completed: false,
    });

    executeSoon(finish);
  }
  Services.obs.addObserver(onWebConsoleOpen, "web-console-created", false);

  DeveloperToolbarTest.exec({
    typed: "calllog chromestart javascript \"({a1: function() {this.a2()},a2: function() {}});\"",
    outputMatch: /Call logging started/,
    completed: false,
  });
}