mirror of
https://github.com/classilla/tenfourfox.git
synced 2024-06-29 16:29:39 +00:00
122 lines
3.5 KiB
JavaScript
122 lines
3.5 KiB
JavaScript
/*
|
|
* Any copyright is dedicated to the Public Domain.
|
|
* http://creativecommons.org/publicdomain/zero/1.0/
|
|
*/
|
|
|
|
// Test that makes sure web console eval works while the js debugger paused the
|
|
// page, and while the inspector is active. See bug 886137.
|
|
|
|
"use strict";
|
|
|
|
const TEST_URI = "http://example.com/browser/devtools/client/webconsole/" +
|
|
"test/test-eval-in-stackframe.html";
|
|
|
|
var gWebConsole, gJSTerm, gDebuggerWin, gThread, gDebuggerController,
|
|
gStackframes, gVariablesView;
|
|
|
|
function test() {
|
|
loadTab(TEST_URI).then(() => {
|
|
openConsole().then(consoleOpened);
|
|
}, true);
|
|
}
|
|
|
|
function consoleOpened(hud) {
|
|
gWebConsole = hud;
|
|
gJSTerm = hud.jsterm;
|
|
|
|
info("openDebugger");
|
|
openDebugger().then(debuggerOpened);
|
|
}
|
|
|
|
function debuggerOpened(result) {
|
|
info("debugger opened");
|
|
gDebuggerWin = result.panelWin;
|
|
gDebuggerController = gDebuggerWin.DebuggerController;
|
|
gThread = gDebuggerController.activeThread;
|
|
gStackframes = gDebuggerController.StackFrames;
|
|
|
|
openInspector().then(inspectorOpened);
|
|
}
|
|
|
|
function inspectorOpened() {
|
|
info("inspector opened");
|
|
gThread.addOneTimeListener("framesadded", onFramesAdded);
|
|
|
|
info("firstCall()");
|
|
content.wrappedJSObject.firstCall();
|
|
}
|
|
|
|
function onFramesAdded() {
|
|
info("onFramesAdded");
|
|
|
|
openConsole().then(() => gJSTerm.execute("fooObj").then(onExecuteFooObj));
|
|
}
|
|
|
|
function onExecuteFooObj(msg) {
|
|
ok(msg, "output message found");
|
|
ok(msg.textContent.includes('{ testProp2: "testValue2" }'),
|
|
"message text check");
|
|
|
|
let anchor = msg.querySelector("a");
|
|
ok(anchor, "object link found");
|
|
|
|
gJSTerm.once("variablesview-fetched", onFooObjFetch);
|
|
|
|
EventUtils.synthesizeMouse(anchor, 2, 2, {}, gWebConsole.iframeWindow);
|
|
}
|
|
|
|
function onFooObjFetch(aEvent, aVar) {
|
|
gVariablesView = aVar._variablesView;
|
|
ok(gVariablesView, "variables view object");
|
|
|
|
findVariableViewProperties(aVar, [
|
|
{ name: "testProp2", value: "testValue2" },
|
|
{ name: "testProp", value: "testValue", dontMatch: true },
|
|
], { webconsole: gWebConsole }).then(onTestPropFound);
|
|
}
|
|
|
|
function onTestPropFound(aResults) {
|
|
let prop = aResults[0].matchedProp;
|
|
ok(prop, "matched the |testProp2| property in the variables view");
|
|
|
|
// Check that property value updates work and that jsterm functions can be
|
|
// used.
|
|
updateVariablesViewProperty({
|
|
property: prop,
|
|
field: "value",
|
|
string: "document.title + foo2 + $('p')",
|
|
webconsole: gWebConsole
|
|
}).then(onFooObjFetchAfterUpdate);
|
|
}
|
|
|
|
function onFooObjFetchAfterUpdate(aVar) {
|
|
info("onFooObjFetchAfterUpdate");
|
|
let para = content.wrappedJSObject.document.querySelector("p");
|
|
let expectedValue = content.document.title + "foo2SecondCall" + para;
|
|
|
|
findVariableViewProperties(aVar, [
|
|
{ name: "testProp2", value: expectedValue },
|
|
], { webconsole: gWebConsole }).then(onUpdatedTestPropFound);
|
|
}
|
|
|
|
function onUpdatedTestPropFound(aResults) {
|
|
let prop = aResults[0].matchedProp;
|
|
ok(prop, "matched the updated |testProp2| property value");
|
|
|
|
// Check that testProp2 was updated.
|
|
gJSTerm.execute("fooObj.testProp2").then(onExecuteFooObjTestProp2);
|
|
}
|
|
|
|
function onExecuteFooObjTestProp2() {
|
|
let para = content.wrappedJSObject.document.querySelector("p");
|
|
let expected = content.document.title + "foo2SecondCall" + para;
|
|
|
|
isnot(gWebConsole.outputNode.textContent.indexOf(expected), -1,
|
|
"fooObj.testProp2 is correct");
|
|
|
|
gWebConsole = gJSTerm = gDebuggerWin = gThread = gDebuggerController =
|
|
gStackframes = gVariablesView = null;
|
|
|
|
finishTest();
|
|
}
|