File: browser_webconsole_expandable_timestamps.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 (57 lines) | stat: -rw-r--r-- 1,791 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
/* Any copyright is dedicated to the Public Domain.
 * http://creativecommons.org/publicdomain/zero/1.0/ */

// Test for the message timestamps option: check if the preference toggles the
// display of messages in the console output. See bug 722267.

function test()
{
  const PREF_MESSAGE_TIMESTAMP = "devtools.webconsole.timestampMessages";
  let hud;

  registerCleanupFunction(() => {
    Services.prefs.clearUserPref(PREF_MESSAGE_TIMESTAMP);
  });

  addTab("data:text/html;charset=utf-8,Web Console test for bug 722267 - " +
         "preference for toggling timestamps in messages");

  browser.addEventListener("load", function tabLoad() {
    browser.removeEventListener("load", tabLoad, true);
    openConsole(null, consoleOpened);
  }, true);

  function consoleOpened(aHud)
  {
    hud = aHud;

    info("console opened");
    let prefValue = Services.prefs.getBoolPref(PREF_MESSAGE_TIMESTAMP);
    ok(!prefValue, "messages have no timestamp by default (pref check)");
    ok(hud.outputNode.classList.contains("hideTimestamps"),
       "messages have no timestamp (class name check)");

    let toolbox = gDevTools.getToolbox(hud.target);
    toolbox.selectTool("options").then(onOptionsPanelSelected);
  }

  function onOptionsPanelSelected(panel)
  {
    info("options panel opened");

    gDevTools.once("pref-changed", onPrefChanged);

    let checkbox = panel.panelDoc.getElementById("webconsole-timestamp-messages");
    checkbox.click();
  }

  function onPrefChanged()
  {
    info("pref changed");
    let prefValue = Services.prefs.getBoolPref(PREF_MESSAGE_TIMESTAMP);
    ok(prefValue, "messages have timestamps (pref check)");
    ok(!hud.outputNode.classList.contains("hideTimestamps"),
       "messages have timestamps (class name check)");
    finishTest();
  }
}