diff -r 000000000000 -r 6474c204b198 browser/devtools/debugger/test/browser_dbg_search-global-02.js --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/browser/devtools/debugger/test/browser_dbg_search-global-02.js Wed Dec 31 06:09:35 2014 +0100 @@ -0,0 +1,218 @@ +/* Any copyright is dedicated to the Public Domain. + http://creativecommons.org/publicdomain/zero/1.0/ */ + +/** + * Tests if the global search results switch back and forth, and wrap around + * when switching between them. + */ + +const TAB_URL = EXAMPLE_URL + "doc_script-switching-01.html"; + +let gTab, gDebuggee, gPanel, gDebugger; +let gEditor, gSources, gSearchView, gSearchBox; + +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; + gSearchView = gDebugger.DebuggerView.GlobalSearch; + gSearchBox = gDebugger.DebuggerView.Filtering._searchbox; + + waitForSourceAndCaretAndScopes(gPanel, "-02.js", 1) + .then(firstSearch) + .then(doFirstJump) + .then(doSecondJump) + .then(doWrapAroundJump) + .then(doBackwardsWrapAroundJump) + .then(testSearchTokenEmpty) + .then(() => resumeDebuggerThenCloseAndFinish(gPanel)) + .then(null, aError => { + ok(false, "Got an error: " + aError.message + "\n" + aError.stack); + }); + + gDebuggee.firstCall(); + }); +} + +function firstSearch() { + let deferred = promise.defer(); + + is(gSearchView.itemCount, 0, + "The global search pane shouldn't have any entries yet."); + is(gSearchView.widget._parent.hidden, true, + "The global search pane shouldn't be visible yet."); + is(gSearchView._splitter.hidden, true, + "The global search pane splitter shouldn't be visible yet."); + + gDebugger.once(gDebugger.EVENTS.GLOBAL_SEARCH_MATCH_FOUND, () => { + // Some operations are synchronously dispatched on the main thread, + // to avoid blocking UI, thus giving the impression of faster searching. + executeSoon(() => { + info("Current source url:\n" + gSources.selectedValue); + info("Debugger editor text:\n" + gEditor.getText()); + + ok(isCaretPos(gPanel, 1), + "The editor shouldn't have jumped to a matching line yet."); + ok(gSources.selectedValue.contains("-02.js"), + "The current source shouldn't have changed after a global search."); + is(gSources.visibleItems.length, 2, + "Not all the sources are shown after the global search."); + + deferred.resolve(); + }); + }); + + setText(gSearchBox, "!eval"); + + return deferred.promise; +} + +function doFirstJump() { + let deferred = promise.defer(); + + waitForSourceAndCaret(gPanel, "-01.js", 1).then(() => { + info("Current source url:\n" + gSources.selectedValue); + info("Debugger editor text:\n" + gEditor.getText()); + + ok(gSources.selectedValue.contains("-01.js"), + "The currently shown source is incorrect (1)."); + is(gSources.visibleItems.length, 2, + "Not all the sources are shown after the global search (1)."); + + // The editor's selected text takes a tick to update. + executeSoon(() => { + ok(isCaretPos(gPanel, 5, 7), + "The editor didn't jump to the correct line (1)."); + is(gEditor.getSelection(), "eval", + "The editor didn't select the correct text (1)."); + + deferred.resolve(); + }); + }); + + EventUtils.sendKey("DOWN", gDebugger); + + return deferred.promise; +} + +function doSecondJump() { + let deferred = promise.defer(); + + waitForSourceAndCaret(gPanel, "-02.js", 1).then(() => { + info("Current source url:\n" + gSources.selectedValue); + info("Debugger editor text:\n" + gEditor.getText()); + + ok(gSources.selectedValue.contains("-02.js"), + "The currently shown source is incorrect (2)."); + is(gSources.visibleItems.length, 2, + "Not all the sources are shown after the global search (2)."); + + // The editor's selected text takes a tick to update. + executeSoon(() => { + ok(isCaretPos(gPanel, 6, 7), + "The editor didn't jump to the correct line (2)."); + is(gEditor.getSelection(), "eval", + "The editor didn't select the correct text (2)."); + + deferred.resolve(); + }); + }); + + EventUtils.sendKey("DOWN", gDebugger); + + return deferred.promise; +} + +function doWrapAroundJump() { + let deferred = promise.defer(); + + waitForSourceAndCaret(gPanel, "-01.js", 1).then(() => { + info("Current source url:\n" + gSources.selectedValue); + info("Debugger editor text:\n" + gEditor.getText()); + + ok(gSources.selectedValue.contains("-01.js"), + "The currently shown source is incorrect (3)."); + is(gSources.visibleItems.length, 2, + "Not all the sources are shown after the global search (3)."); + + // The editor's selected text takes a tick to update. + executeSoon(() => { + ok(isCaretPos(gPanel, 5, 7), + "The editor didn't jump to the correct line (3)."); + is(gEditor.getSelection(), "eval", + "The editor didn't select the correct text (3)."); + + deferred.resolve(); + }); + }); + + EventUtils.sendKey("DOWN", gDebugger); + + return deferred.promise; +} + +function doBackwardsWrapAroundJump() { + let deferred = promise.defer(); + + waitForSourceAndCaret(gPanel, "-02.js", 1).then(() => { + info("Current source url:\n" + gSources.selectedValue); + info("Debugger editor text:\n" + gEditor.getText()); + + ok(gSources.selectedValue.contains("-02.js"), + "The currently shown source is incorrect (4)."); + is(gSources.visibleItems.length, 2, + "Not all the sources are shown after the global search (4)."); + + // The editor's selected text takes a tick to update. + executeSoon(() => { + ok(isCaretPos(gPanel, 6, 7), + "The editor didn't jump to the correct line (4)."); + is(gEditor.getSelection(), "eval", + "The editor didn't select the correct text (4)."); + + deferred.resolve(); + }); + }); + + EventUtils.sendKey("UP", gDebugger); + + return deferred.promise; +} + +function testSearchTokenEmpty() { + backspaceText(gSearchBox, 4); + + info("Current source url:\n" + gSources.selectedValue); + info("Debugger editor text:\n" + gEditor.getText()); + + ok(gSources.selectedValue.contains("-02.js"), + "The currently shown source is incorrect (4)."); + is(gSources.visibleItems.length, 2, + "Not all the sources are shown after the global search (4)."); + ok(isCaretPos(gPanel, 6, 7), + "The editor didn't remain at the correct line (4)."); + is(gEditor.getSelection(), "", + "The editor shouldn't keep the previous text selected (4)."); + + is(gSearchView.itemCount, 0, + "The global search pane shouldn't have any child nodes after clearing."); + is(gSearchView.widget._parent.hidden, true, + "The global search pane shouldn't be visible after clearing."); + is(gSearchView._splitter.hidden, true, + "The global search pane splitter shouldn't be visible after clearing."); +} + +registerCleanupFunction(function() { + gTab = null; + gDebuggee = null; + gPanel = null; + gDebugger = null; + gEditor = null; + gSources = null; + gSearchView = null; + gSearchBox = null; +});