gecko-dev/browser/devtools/debugger/test/browser_dbg_scripts-switching-02.js
Victor Porof e43b89cd7e Bug 876277 - Cleanup debugger location changes, sources switching and sources cache tests, r=past
--HG--
rename : browser/devtools/debugger/test/browser_dbg_update-editor-mode.js => browser/devtools/debugger/test/browser_dbg_editor-mode.js
rename : browser/devtools/debugger/test/browser_dbg_location-changes.js => browser/devtools/debugger/test/browser_dbg_location-changes-01-simple.js
rename : browser/devtools/debugger/test/browser_dbg_location-changes-blank.js => browser/devtools/debugger/test/browser_dbg_location-changes-02-blank.js
rename : browser/devtools/debugger/test/browser_dbg_location-changes-new.js => browser/devtools/debugger/test/browser_dbg_location-changes-03-new.js
rename : browser/devtools/debugger/test/browser_dbg_location-changes-bp.js => browser/devtools/debugger/test/browser_dbg_location-changes-04-breakpoint.js
rename : browser/devtools/debugger/test/browser_dbg_scripts-switching.js => browser/devtools/debugger/test/browser_dbg_scripts-switching-01.js
rename : browser/devtools/debugger/test/browser_dbg_propertyview-01.js => browser/devtools/debugger/test/browser_dbg_sources-labels.js
rename : browser/devtools/debugger/test/browser_dbg_scripts-sorting.js => browser/devtools/debugger/test/browser_dbg_sources-sorting.js
2013-09-13 16:23:18 +03:00

187 lines
5.6 KiB
JavaScript

/* Any copyright is dedicated to the Public Domain.
http://creativecommons.org/publicdomain/zero/1.0/ */
/**
* Make sure that switching the displayed source in the UI works as advertised.
*/
const TAB_URL = EXAMPLE_URL + "doc_script-switching-02.html";
let gTab, gDebuggee, gPanel, gDebugger;
let gEditor, gSources;
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;
waitForSourceAndCaretAndScopes(gPanel, "-02.js", 6)
.then(testSourcesDisplay)
.then(testSwitchPaused1)
.then(testSwitchPaused2)
.then(testSwitchRunning)
.then(() => resumeDebuggerThenCloseAndFinish(gPanel))
.then(null, aError => {
ok(false, "Got an error: " + aError.message + "\n" + aError.stack);
});
gDebuggee.firstCall();
});
}
let gLabel1 = "code_script-switching-01.js";
let gLabel2 = "code_script-switching-02.js";
let gParams = "?foo=bar,baz|lol";
function testSourcesDisplay() {
let deferred = promise.defer();
is(gSources.itemCount, 2,
"Found the expected number of sources.");
ok(gSources.containsValue(EXAMPLE_URL + gLabel1),
"First source url is incorrect.");
ok(gSources.containsValue(EXAMPLE_URL + gLabel2 + gParams),
"Second source url is incorrect.");
ok(gSources.containsLabel(gLabel1),
"First source label is incorrect.");
ok(gSources.containsLabel(gLabel2),
"Second source label is incorrect.");
ok(gSources.selectedItem,
"There should be a selected item in the sources pane.");
is(gSources.selectedLabel, gLabel2,
"The selected label is the sources pane is incorrect.");
is(gSources.selectedValue, EXAMPLE_URL + gLabel2 + gParams,
"The selected value is the sources pane is incorrect.");
is(gEditor.getText().search(/firstCall/), -1,
"The first source is not displayed.");
is(gEditor.getText().search(/debugger/), 172,
"The second source is displayed.");
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 debugger location is correct.");
waitForDebuggerEvents(gPanel, gDebugger.EVENTS.SOURCE_SHOWN).then(deferred.resolve);
gSources.selectedLabel = gLabel1;
});
return deferred.promise;
}
function testSwitchPaused1() {
let deferred = promise.defer();
ok(gSources.selectedItem,
"There should be a selected item in the sources pane.");
is(gSources.selectedLabel, gLabel1,
"The selected label is the sources pane is incorrect.");
is(gSources.selectedValue, EXAMPLE_URL + gLabel1,
"The selected value is the sources pane is incorrect.");
is(gEditor.getText().search(/firstCall/), 118,
"The first source is displayed.");
is(gEditor.getText().search(/debugger/), -1,
"The second source is not displayed.");
// The editor's debug location takes a tick to update.
executeSoon(() => {
ok(isCaretPos(gPanel, 1),
"Editor caret location is correct.");
is(gEditor.getDebugLocation(), -1,
"Editor debugger location is correct.");
waitForDebuggerEvents(gPanel, gDebugger.EVENTS.SOURCE_SHOWN).then(deferred.resolve);
gSources.selectedLabel = gLabel2;
});
return deferred.promise;
}
function testSwitchPaused2() {
let deferred = promise.defer();
ok(gSources.selectedItem,
"There should be a selected item in the sources pane.");
is(gSources.selectedLabel, gLabel2,
"The selected label is the sources pane is incorrect.");
is(gSources.selectedValue, EXAMPLE_URL + gLabel2 + gParams,
"The selected value is the sources pane is incorrect.");
is(gEditor.getText().search(/firstCall/), -1,
"The first source is not displayed.");
is(gEditor.getText().search(/debugger/), 172,
"The second source is displayed.");
// The editor's debug location takes a tick to update.
executeSoon(() => {
ok(isCaretPos(gPanel, 6),
"Editor caret location is correct.");
is(gEditor.getDebugLocation(), 5,
"Editor debugger location is correct.");
// Step out three times.
waitForThreadEvents(gPanel, "paused").then(() => {
waitForThreadEvents(gPanel, "paused").then(() => {
waitForDebuggerEvents(gPanel, gDebugger.EVENTS.SOURCE_SHOWN).then(deferred.resolve);
gDebugger.gThreadClient.stepOut();
});
gDebugger.gThreadClient.stepOut();
});
gDebugger.gThreadClient.stepOut();
});
return deferred.promise;
}
function testSwitchRunning() {
let deferred = promise.defer();
ok(gSources.selectedItem,
"There should be a selected item in the sources pane.");
is(gSources.selectedLabel, gLabel1,
"The selected label is the sources pane is incorrect.");
is(gSources.selectedValue, EXAMPLE_URL + gLabel1,
"The selected value is the sources pane is incorrect.");
is(gEditor.getText().search(/firstCall/), 118,
"The first source is displayed.");
is(gEditor.getText().search(/debugger/), -1,
"The second source is not displayed.");
// The editor's debug location takes a tick to update.
executeSoon(() => {
ok(isCaretPos(gPanel, 5),
"Editor caret location is correct.");
is(gEditor.getDebugLocation(), 4,
"Editor debugger location is correct.");
deferred.resolve();
});
return deferred.promise;
}
registerCleanupFunction(function() {
gTab = null;
gDebuggee = null;
gPanel = null;
gDebugger = null;
gEditor = null;
gSources = null;
gLabel1 = null;
gLabel2 = null;
gParams = null;
});