michael@0: /* Any copyright is dedicated to the Public Domain. michael@0: http://creativecommons.org/publicdomain/zero/1.0/ */ michael@0: michael@0: /** michael@0: * Tests basic functionality of sources filtering (file search). michael@0: */ michael@0: michael@0: const TAB_URL = EXAMPLE_URL + "doc_script-switching-01.html"; michael@0: michael@0: let gTab, gDebuggee, gPanel, gDebugger; michael@0: let gSources, gSearchView, gSearchBox; michael@0: michael@0: function test() { michael@0: // Debug test slaves are a bit slow at this test. michael@0: requestLongerTimeout(3); michael@0: michael@0: initDebugger(TAB_URL).then(([aTab, aDebuggee, aPanel]) => { michael@0: gTab = aTab; michael@0: gDebuggee = aDebuggee; michael@0: gPanel = aPanel; michael@0: gDebugger = gPanel.panelWin; michael@0: gSources = gDebugger.DebuggerView.Sources; michael@0: gSearchView = gDebugger.DebuggerView.FilteredSources; michael@0: gSearchBox = gDebugger.DebuggerView.Filtering._searchbox; michael@0: michael@0: waitForSourceShown(gPanel, "-01.js") michael@0: .then(bogusSearch) michael@0: .then(firstSearch) michael@0: .then(secondSearch) michael@0: .then(thirdSearch) michael@0: .then(fourthSearch) michael@0: .then(fifthSearch) michael@0: .then(sixthSearch) michael@0: .then(seventhSearch) michael@0: .then(() => closeDebuggerAndFinish(gPanel)) michael@0: .then(null, aError => { michael@0: ok(false, "Got an error: " + aError.message + "\n" + aError.stack); michael@0: }); michael@0: }); michael@0: } michael@0: michael@0: function bogusSearch() { michael@0: let finished = promise.all([ michael@0: ensureSourceIs(gPanel, "-01.js"), michael@0: ensureCaretAt(gPanel, 1), michael@0: waitForDebuggerEvents(gPanel, gDebugger.EVENTS.FILE_SEARCH_MATCH_NOT_FOUND) michael@0: ]); michael@0: michael@0: setText(gSearchBox, "BOGUS"); michael@0: michael@0: return finished.then(() => promise.all([ michael@0: ensureSourceIs(gPanel, "-01.js"), michael@0: ensureCaretAt(gPanel, 1), michael@0: verifyContents({ itemCount: 0, hidden: true }) michael@0: ])); michael@0: } michael@0: michael@0: function firstSearch() { michael@0: let finished = promise.all([ michael@0: ensureSourceIs(gPanel, "-01.js"), michael@0: ensureCaretAt(gPanel, 1), michael@0: once(gDebugger, "popupshown"), michael@0: waitForDebuggerEvents(gPanel, gDebugger.EVENTS.FILE_SEARCH_MATCH_FOUND), michael@0: waitForSourceShown(gPanel, "-02.js") michael@0: ]); michael@0: michael@0: setText(gSearchBox, "-02.js"); michael@0: michael@0: return finished.then(() => promise.all([ michael@0: ensureSourceIs(gPanel, "-02.js"), michael@0: ensureCaretAt(gPanel, 1), michael@0: verifyContents({ itemCount: 1, hidden: false }) michael@0: ])); michael@0: } michael@0: michael@0: function secondSearch() { michael@0: let finished = promise.all([ michael@0: once(gDebugger, "popupshown"), michael@0: waitForDebuggerEvents(gPanel, gDebugger.EVENTS.FILE_SEARCH_MATCH_FOUND), michael@0: waitForSourceShown(gPanel, "-01.js") michael@0: ]) michael@0: .then(() => { michael@0: let finished = promise.all([ michael@0: once(gDebugger, "popupshown"), michael@0: waitForDebuggerEvents(gPanel, gDebugger.EVENTS.FILE_SEARCH_MATCH_FOUND), michael@0: waitForCaretUpdated(gPanel, 5) michael@0: ]) michael@0: .then(() => promise.all([ michael@0: ensureSourceIs(gPanel, "-01.js"), michael@0: ensureCaretAt(gPanel, 5), michael@0: verifyContents({ itemCount: 1, hidden: false }) michael@0: ])); michael@0: michael@0: typeText(gSearchBox, ":5"); michael@0: return finished; michael@0: }); michael@0: michael@0: setText(gSearchBox, ".*-01\.js"); michael@0: return finished; michael@0: } michael@0: michael@0: function thirdSearch() { michael@0: let finished = promise.all([ michael@0: once(gDebugger, "popupshown"), michael@0: waitForDebuggerEvents(gPanel, gDebugger.EVENTS.FILE_SEARCH_MATCH_FOUND), michael@0: waitForSourceShown(gPanel, "-02.js") michael@0: ]) michael@0: .then(() => { michael@0: let finished = promise.all([ michael@0: once(gDebugger, "popupshown"), michael@0: waitForDebuggerEvents(gPanel, gDebugger.EVENTS.FILE_SEARCH_MATCH_FOUND), michael@0: waitForCaretUpdated(gPanel, 6, 12) michael@0: ]) michael@0: .then(() => promise.all([ michael@0: ensureSourceIs(gPanel, "-02.js"), michael@0: ensureCaretAt(gPanel, 6, 12), michael@0: verifyContents({ itemCount: 1, hidden: false }) michael@0: ])); michael@0: michael@0: typeText(gSearchBox, "#deb"); michael@0: return finished; michael@0: }); michael@0: michael@0: setText(gSearchBox, ".*-02\.js"); michael@0: return finished; michael@0: } michael@0: michael@0: function fourthSearch() { michael@0: let finished = promise.all([ michael@0: once(gDebugger, "popupshown"), michael@0: waitForDebuggerEvents(gPanel, gDebugger.EVENTS.FILE_SEARCH_MATCH_FOUND), michael@0: waitForSourceShown(gPanel, "-01.js") michael@0: ]) michael@0: .then(() => { michael@0: let finished = promise.all([ michael@0: once(gDebugger, "popupshown"), michael@0: waitForDebuggerEvents(gPanel, gDebugger.EVENTS.FILE_SEARCH_MATCH_FOUND), michael@0: waitForCaretUpdated(gPanel, 2, 9), michael@0: ]) michael@0: .then(() => promise.all([ michael@0: ensureSourceIs(gPanel, "-01.js"), michael@0: ensureCaretAt(gPanel, 2, 9), michael@0: verifyContents({ itemCount: 1, hidden: false }) michael@0: // ...because we simply searched for ":" in the current file. michael@0: ])); michael@0: michael@0: typeText(gSearchBox, "#:"); // # has precedence. michael@0: return finished; michael@0: }); michael@0: michael@0: setText(gSearchBox, ".*-01\.js"); michael@0: return finished; michael@0: } michael@0: michael@0: function fifthSearch() { michael@0: let finished = promise.all([ michael@0: once(gDebugger, "popupshown"), michael@0: waitForDebuggerEvents(gPanel, gDebugger.EVENTS.FILE_SEARCH_MATCH_FOUND), michael@0: waitForSourceShown(gPanel, "-02.js") michael@0: ]) michael@0: .then(() => { michael@0: let finished = promise.all([ michael@0: once(gDebugger, "popuphidden"), michael@0: waitForDebuggerEvents(gPanel, gDebugger.EVENTS.FILE_SEARCH_MATCH_NOT_FOUND), michael@0: waitForCaretUpdated(gPanel, 1, 3) michael@0: ]) michael@0: .then(() => promise.all([ michael@0: ensureSourceIs(gPanel, "-02.js"), michael@0: ensureCaretAt(gPanel, 1, 3), michael@0: verifyContents({ itemCount: 0, hidden: true }) michael@0: // ...because the searched label includes ":5", so nothing is found. michael@0: ])); michael@0: michael@0: typeText(gSearchBox, ":5#*"); // # has precedence. michael@0: return finished; michael@0: }); michael@0: michael@0: setText(gSearchBox, ".*-02\.js"); michael@0: return finished; michael@0: } michael@0: michael@0: function sixthSearch() { michael@0: let finished = promise.all([ michael@0: ensureSourceIs(gPanel, "-02.js"), michael@0: ensureCaretAt(gPanel, 1, 3), michael@0: once(gDebugger, "popupshown"), michael@0: waitForDebuggerEvents(gPanel, gDebugger.EVENTS.FILE_SEARCH_MATCH_FOUND), michael@0: waitForCaretUpdated(gPanel, 5) michael@0: ]); michael@0: michael@0: backspaceText(gSearchBox, 2); michael@0: michael@0: return finished.then(() => promise.all([ michael@0: ensureSourceIs(gPanel, "-02.js"), michael@0: ensureCaretAt(gPanel, 5), michael@0: verifyContents({ itemCount: 1, hidden: false }) michael@0: ])); michael@0: } michael@0: michael@0: function seventhSearch() { michael@0: let finished = promise.all([ michael@0: ensureSourceIs(gPanel, "-02.js"), michael@0: ensureCaretAt(gPanel, 5), michael@0: once(gDebugger, "popupshown"), michael@0: waitForDebuggerEvents(gPanel, gDebugger.EVENTS.FILE_SEARCH_MATCH_FOUND), michael@0: waitForSourceShown(gPanel, "-01.js"), michael@0: ]); michael@0: michael@0: backspaceText(gSearchBox, 6); michael@0: michael@0: return finished.then(() => promise.all([ michael@0: ensureSourceIs(gPanel, "-01.js"), michael@0: ensureCaretAt(gPanel, 1), michael@0: verifyContents({ itemCount: 2, hidden: false }) michael@0: ])); michael@0: } michael@0: michael@0: function verifyContents(aArgs) { michael@0: is(gSources.visibleItems.length, 2, michael@0: "The unmatched sources in the widget should not be hidden."); michael@0: is(gSearchView.itemCount, aArgs.itemCount, michael@0: "No sources should be displayed in the sources container after a bogus search."); michael@0: is(gSearchView.hidden, aArgs.hidden, michael@0: "No sources should be displayed in the sources container after a bogus search."); michael@0: } michael@0: michael@0: registerCleanupFunction(function() { michael@0: gTab = null; michael@0: gDebuggee = null; michael@0: gPanel = null; michael@0: gDebugger = null; michael@0: gSources = null; michael@0: gSearchView = null; michael@0: gSearchBox = null; michael@0: });