2010-10-20 10:39:44 -07:00
|
|
|
/* vim:set ts=2 sw=2 sts=2 et: */
|
2012-05-21 04:12:37 -07:00
|
|
|
/* 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/. */
|
2010-10-20 10:39:44 -07:00
|
|
|
|
2012-04-15 13:10:00 -07:00
|
|
|
const TEST_URI = "http://example.com/browser/browser/devtools/webconsole/test/test-console.html";
|
2010-10-20 10:39:44 -07:00
|
|
|
|
2012-05-25 06:44:17 -07:00
|
|
|
let jsterm;
|
2010-10-20 10:39:44 -07:00
|
|
|
|
|
|
|
function test() {
|
|
|
|
addTab(TEST_URI);
|
2012-05-10 08:01:37 -07:00
|
|
|
browser.addEventListener("load", function onLoad() {
|
|
|
|
browser.removeEventListener("load", onLoad, true);
|
2012-05-25 06:44:17 -07:00
|
|
|
openConsole(null, testJSTerm);
|
2012-05-10 08:01:37 -07:00
|
|
|
}, true);
|
2010-10-20 10:39:44 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
function checkResult(msg, desc, lines) {
|
2012-05-25 06:44:17 -07:00
|
|
|
let labels = jsterm.outputNode.querySelectorAll(".webconsole-msg-output");
|
|
|
|
is(labels.length, lines, "correct number of results shown for " + desc);
|
|
|
|
is(labels[lines-1].textContent.trim(), msg, "correct message shown for " +
|
|
|
|
desc);
|
2010-10-20 10:39:44 -07:00
|
|
|
}
|
|
|
|
|
2012-05-10 08:01:37 -07:00
|
|
|
function testJSTerm(hud)
|
2010-10-20 10:39:44 -07:00
|
|
|
{
|
2012-05-10 08:01:37 -07:00
|
|
|
jsterm = hud.jsterm;
|
2010-10-20 10:39:44 -07:00
|
|
|
|
|
|
|
jsterm.clearOutput();
|
|
|
|
jsterm.execute("'id=' + $('header').getAttribute('id')");
|
2010-12-14 10:51:16 -08:00
|
|
|
checkResult('"id=header"', "$() worked", 1);
|
2010-10-20 10:39:44 -07:00
|
|
|
|
|
|
|
jsterm.clearOutput();
|
|
|
|
jsterm.execute("headerQuery = $$('h1')");
|
|
|
|
jsterm.execute("'length=' + headerQuery.length");
|
2010-12-14 10:51:16 -08:00
|
|
|
checkResult('"length=1"', "$$() worked", 2);
|
2010-10-20 10:39:44 -07:00
|
|
|
|
|
|
|
jsterm.clearOutput();
|
|
|
|
jsterm.execute("xpathQuery = $x('.//*', document.body);");
|
|
|
|
jsterm.execute("'headerFound=' + (xpathQuery[0] == headerQuery[0])");
|
2010-12-14 10:51:16 -08:00
|
|
|
checkResult('"headerFound=true"', "$x() worked", 2);
|
2010-10-20 10:39:44 -07:00
|
|
|
|
|
|
|
// no jsterm.clearOutput() here as we clear the output using the clear() fn.
|
|
|
|
jsterm.execute("clear()");
|
2012-05-25 06:44:17 -07:00
|
|
|
let group = jsterm.outputNode.querySelector(".hud-group");
|
|
|
|
ok(!group, "clear() worked");
|
2010-10-20 10:39:44 -07:00
|
|
|
|
|
|
|
jsterm.clearOutput();
|
|
|
|
jsterm.execute("'keysResult=' + (keys({b:1})[0] == 'b')");
|
2010-12-14 10:51:16 -08:00
|
|
|
checkResult('"keysResult=true"', "keys() worked", 1);
|
2010-10-20 10:39:44 -07:00
|
|
|
|
|
|
|
jsterm.clearOutput();
|
|
|
|
jsterm.execute("'valuesResult=' + (values({b:1})[0] == 1)");
|
2010-12-14 10:51:16 -08:00
|
|
|
checkResult('"valuesResult=true"', "values() worked", 1);
|
2010-10-20 10:39:44 -07:00
|
|
|
|
2010-11-02 05:58:37 -07:00
|
|
|
jsterm.clearOutput();
|
|
|
|
jsterm.execute("help()");
|
2010-12-23 07:59:19 -08:00
|
|
|
let output = jsterm.outputNode.querySelector(".webconsole-msg-output");
|
2012-05-25 06:44:17 -07:00
|
|
|
ok(!group, "help() worked");
|
2010-11-02 05:58:37 -07:00
|
|
|
|
|
|
|
jsterm.execute("help");
|
2010-12-23 07:59:19 -08:00
|
|
|
output = jsterm.outputNode.querySelector(".webconsole-msg-output");
|
2010-12-14 10:51:16 -08:00
|
|
|
ok(!output, "help worked");
|
2010-11-02 05:58:37 -07:00
|
|
|
|
|
|
|
jsterm.execute("?");
|
2010-12-23 07:59:19 -08:00
|
|
|
output = jsterm.outputNode.querySelector(".webconsole-msg-output");
|
2010-12-14 10:51:16 -08:00
|
|
|
ok(!output, "? worked");
|
2010-11-02 05:58:37 -07:00
|
|
|
|
2010-10-20 10:39:44 -07:00
|
|
|
jsterm.clearOutput();
|
|
|
|
jsterm.execute("pprint({b:2, a:1})");
|
2012-05-25 06:44:17 -07:00
|
|
|
// Doesn't conform to checkResult format
|
|
|
|
let label = jsterm.outputNode.querySelector(".webconsole-msg-output");
|
|
|
|
is(label.textContent.trim(), "a: 1\n b: 2", "pprint() worked");
|
2010-10-20 10:39:44 -07:00
|
|
|
|
2010-10-28 09:01:36 -07:00
|
|
|
// check instanceof correctness, bug 599940
|
|
|
|
jsterm.clearOutput();
|
|
|
|
jsterm.execute("[] instanceof Array");
|
|
|
|
checkResult("true", "[] instanceof Array == true", 1);
|
|
|
|
|
|
|
|
jsterm.clearOutput();
|
|
|
|
jsterm.execute("({}) instanceof Object");
|
|
|
|
checkResult("true", "({}) instanceof Object == true", 1);
|
|
|
|
|
|
|
|
// check for occurrences of Object XRayWrapper, bug 604430
|
|
|
|
jsterm.clearOutput();
|
|
|
|
jsterm.execute("document");
|
2012-05-25 06:44:17 -07:00
|
|
|
let label = jsterm.outputNode.querySelector(".webconsole-msg-output");
|
|
|
|
is(label.textContent.trim().search(/\[object XrayWrapper/), -1,
|
|
|
|
"check for non-existence of [object XrayWrapper ");
|
2010-10-28 09:01:36 -07:00
|
|
|
|
2010-11-10 08:10:25 -08:00
|
|
|
// check that pprint(window) and keys(window) don't throw, bug 608358
|
|
|
|
jsterm.clearOutput();
|
|
|
|
jsterm.execute("pprint(window)");
|
2012-05-25 06:44:17 -07:00
|
|
|
let labels = jsterm.outputNode.querySelectorAll(".webconsole-msg-output");
|
|
|
|
is(labels.length, 1, "one line of output for pprint(window)");
|
2010-11-10 08:10:25 -08:00
|
|
|
|
|
|
|
jsterm.clearOutput();
|
|
|
|
jsterm.execute("keys(window)");
|
2012-05-25 06:44:17 -07:00
|
|
|
labels = jsterm.outputNode.querySelectorAll(".webconsole-msg-output");
|
|
|
|
is(labels.length, 1, "one line of output for keys(window)");
|
2010-11-10 08:10:25 -08:00
|
|
|
|
2010-12-02 02:50:28 -08:00
|
|
|
jsterm.clearOutput();
|
|
|
|
jsterm.execute("pprint('hi')");
|
2012-05-25 06:44:17 -07:00
|
|
|
// Doesn't conform to checkResult format, bug 614561
|
|
|
|
let label = jsterm.outputNode.querySelector(".webconsole-msg-output");
|
|
|
|
is(label.textContent.trim(), '0: "h"\n 1: "i"', 'pprint("hi") worked');
|
2010-12-02 02:50:28 -08:00
|
|
|
|
2011-01-04 09:31:48 -08:00
|
|
|
// check that pprint(function) shows function source, bug 618344
|
|
|
|
jsterm.clearOutput();
|
|
|
|
jsterm.execute("pprint(print)");
|
2012-05-25 06:44:17 -07:00
|
|
|
label = jsterm.outputNode.querySelector(".webconsole-msg-output");
|
|
|
|
isnot(label.textContent.indexOf("SEVERITY_LOG"), -1,
|
|
|
|
"pprint(function) shows function source");
|
2011-01-04 09:31:48 -08:00
|
|
|
|
2011-04-21 09:22:13 -07:00
|
|
|
// check that an evaluated null produces "null", bug 650780
|
|
|
|
jsterm.clearOutput();
|
|
|
|
jsterm.execute("null");
|
|
|
|
checkResult("null", "null is null", 1);
|
|
|
|
|
2012-05-25 06:44:17 -07:00
|
|
|
jsterm = null;
|
2012-05-10 08:01:37 -07:00
|
|
|
executeSoon(finishTest);
|
2010-10-20 10:39:44 -07:00
|
|
|
}
|