mirror of
https://github.com/mozilla/gecko-dev.git
synced 2024-11-14 15:37:55 +00:00
169 lines
5.0 KiB
JavaScript
169 lines
5.0 KiB
JavaScript
/* Any copyright is dedicated to the Public Domain.
|
|
http://creativecommons.org/publicdomain/zero/1.0/ */
|
|
|
|
/**
|
|
* Test that switching between stack frames properly sets the current debugger
|
|
* location in the source editor.
|
|
*/
|
|
|
|
const TAB_URL = EXAMPLE_URL + "doc_script-switching-01.html";
|
|
|
|
let gTab, gDebuggee, gPanel, gDebugger;
|
|
let gEditor, gSources, gFrames, gClassicFrames;
|
|
|
|
function test() {
|
|
initDebugger(TAB_URL).then(([aTab, aDebuggee, aPanel]) => {
|
|
gTab = aTab;
|
|
gDebuggee = aDebuggee;
|
|
gPanel = aPanel;
|
|
gDebugger = gPanel.panelWin;
|
|
gEditor = gDebugger.DebuggerView.editor;
|
|
gSources = gDebugger.DebuggerView.Sources;
|
|
gFrames = gDebugger.DebuggerView.StackFrames;
|
|
gClassicFrames = gDebugger.DebuggerView.StackFramesClassicList;
|
|
|
|
waitForSourceAndCaretAndScopes(gPanel, "-02.js", 6)
|
|
.then(initialChecks)
|
|
.then(testNewestTwoFrames)
|
|
.then(testOldestTwoFrames)
|
|
.then(testAfterResume)
|
|
.then(() => closeDebuggerAndFinish(gPanel))
|
|
.then(null, aError => {
|
|
ok(false, "Got an error: " + aError.message + "\n" + aError.stack);
|
|
});
|
|
|
|
gDebuggee.firstCall();
|
|
});
|
|
}
|
|
|
|
function initialChecks() {
|
|
is(gDebugger.gThreadClient.state, "paused",
|
|
"Should only be getting stack frames while paused.");
|
|
is(gFrames.itemCount, 4,
|
|
"Should have four frames.");
|
|
is(gClassicFrames.itemCount, 4,
|
|
"Should also have four frames in the mirrored view.");
|
|
}
|
|
|
|
function testNewestTwoFrames() {
|
|
let deferred = promise.defer();
|
|
|
|
is(gFrames.selectedIndex, 3,
|
|
"Newest frame should be selected by default.");
|
|
is(gClassicFrames.selectedIndex, 0,
|
|
"Newest frame should be selected in the mirrored view as well.");
|
|
is(gSources.selectedIndex, 1,
|
|
"The second source is selected in the widget.");
|
|
ok(isCaretPos(gPanel, 6),
|
|
"Editor caret location is correct.");
|
|
|
|
// The editor's debug location takes a tick to update.
|
|
executeSoon(() => {
|
|
is(gEditor.getDebugLocation(), 5,
|
|
"Editor debug location is correct.");
|
|
|
|
EventUtils.sendMouseEvent({ type: "mousedown" },
|
|
gFrames.getItemAtIndex(2).target,
|
|
gDebugger);
|
|
|
|
is(gFrames.selectedIndex, 2,
|
|
"Third frame should be selected after click.");
|
|
is(gClassicFrames.selectedIndex, 1,
|
|
"Third frame should be selected in the mirrored view as well.");
|
|
is(gSources.selectedIndex, 1,
|
|
"The second source is still selected in the widget.");
|
|
ok(isCaretPos(gPanel, 6),
|
|
"Editor caret location is correct.");
|
|
|
|
// The editor's debug location takes a tick to update.
|
|
executeSoon(() => {
|
|
is(gEditor.getDebugLocation(), 5,
|
|
"Editor debug location is correct.");
|
|
|
|
deferred.resolve();
|
|
});
|
|
});
|
|
|
|
return deferred.promise;
|
|
}
|
|
|
|
function testOldestTwoFrames() {
|
|
let deferred = promise.defer();
|
|
|
|
waitForSourceAndCaret(gPanel, "-01.js", 5).then(waitForTick).then(() => {
|
|
is(gFrames.selectedIndex, 1,
|
|
"Second frame should be selected after click.");
|
|
is(gClassicFrames.selectedIndex, 2,
|
|
"Second frame should be selected in the mirrored view as well.");
|
|
is(gSources.selectedIndex, 0,
|
|
"The first source is now selected in the widget.");
|
|
ok(isCaretPos(gPanel, 5),
|
|
"Editor caret location is correct.");
|
|
|
|
// The editor's debug location takes a tick to update.
|
|
executeSoon(() => {
|
|
is(gEditor.getDebugLocation(), 4,
|
|
"Editor debug location is correct.");
|
|
|
|
EventUtils.sendMouseEvent({ type: "mousedown" },
|
|
gFrames.getItemAtIndex(0).target,
|
|
gDebugger);
|
|
|
|
is(gFrames.selectedIndex, 0,
|
|
"Oldest frame should be selected after click.");
|
|
is(gClassicFrames.selectedIndex, 3,
|
|
"Oldest frame should be selected in the mirrored view as well.");
|
|
is(gSources.selectedIndex, 0,
|
|
"The first source is still selected in the widget.");
|
|
ok(isCaretPos(gPanel, 5),
|
|
"Editor caret location is correct.");
|
|
|
|
// The editor's debug location takes a tick to update.
|
|
executeSoon(() => {
|
|
is(gEditor.getDebugLocation(), 4,
|
|
"Editor debug location is correct.");
|
|
|
|
deferred.resolve();
|
|
});
|
|
});
|
|
});
|
|
|
|
EventUtils.sendMouseEvent({ type: "mousedown" },
|
|
gDebugger.document.querySelector("#stackframe-2"),
|
|
gDebugger);
|
|
|
|
return deferred.promise;
|
|
}
|
|
|
|
function testAfterResume() {
|
|
let deferred = promise.defer();
|
|
|
|
gDebugger.once(gDebugger.EVENTS.AFTER_FRAMES_CLEARED, () => {
|
|
is(gFrames.itemCount, 0,
|
|
"Should have no frames after resume.");
|
|
is(gClassicFrames.itemCount, 0,
|
|
"Should have no frames in the mirrored view as well.");
|
|
ok(isCaretPos(gPanel, 5),
|
|
"Editor caret location is correct after resume.");
|
|
is(gEditor.getDebugLocation(), null,
|
|
"Editor debug location is correct after resume.");
|
|
|
|
deferred.resolve();
|
|
}, true);
|
|
|
|
gDebugger.gThreadClient.resume();
|
|
|
|
return deferred.promise;
|
|
}
|
|
|
|
registerCleanupFunction(function() {
|
|
gTab = null;
|
|
gDebuggee = null;
|
|
gPanel = null;
|
|
gDebugger = null;
|
|
gEditor = null;
|
|
gFrames = null;
|
|
gClassicFrames = null;
|
|
});
|
|
|