diff options
author | Matt A. Tobin <email@mattatobin.com> | 2016-10-16 19:34:53 -0400 |
---|---|---|
committer | Matt A. Tobin <email@mattatobin.com> | 2016-10-16 19:34:53 -0400 |
commit | 81805ce3f63e2e4a799bd54f174083c58a9b5640 (patch) | |
tree | 6e13374b213ac9b2ae74c25d8aac875faf71fdd0 /toolkit/devtools/debugger/test/browser_dbg_cmd-blackbox.js | |
parent | 28c8da71bf521bb3ee76f27b8a241919e24b7cd5 (diff) | |
download | palemoon-gre-81805ce3f63e2e4a799bd54f174083c58a9b5640.tar.gz |
Move Mozilla DevTools to Platform - Part 3: Merge the browser/devtools and toolkit/devtools adjusting for directory collisions
Diffstat (limited to 'toolkit/devtools/debugger/test/browser_dbg_cmd-blackbox.js')
-rw-r--r-- | toolkit/devtools/debugger/test/browser_dbg_cmd-blackbox.js | 114 |
1 files changed, 114 insertions, 0 deletions
diff --git a/toolkit/devtools/debugger/test/browser_dbg_cmd-blackbox.js b/toolkit/devtools/debugger/test/browser_dbg_cmd-blackbox.js new file mode 100644 index 000000000..797efc1a4 --- /dev/null +++ b/toolkit/devtools/debugger/test/browser_dbg_cmd-blackbox.js @@ -0,0 +1,114 @@ +/* Any copyright is dedicated to the Public Domain. + http://creativecommons.org/publicdomain/zero/1.0/ */ + +/** + * Tests that the 'dbg blackbox' and 'dbg unblackbox' commands work as + * they should. + */ + +const TEST_URL = EXAMPLE_URL + "doc_blackboxing.html"; +const BLACKBOXME_URL = EXAMPLE_URL + "code_blackboxing_blackboxme.js"; +const BLACKBOXONE_URL = EXAMPLE_URL + "code_blackboxing_one.js"; +const BLACKBOXTWO_URL = EXAMPLE_URL + "code_blackboxing_two.js"; +const BLACKBOXTHREE_URL = EXAMPLE_URL + "code_blackboxing_three.js"; + +function test() { + return Task.spawn(spawnTest).then(finish, helpers.handleError); +} + +function spawnTest() { + let options = yield helpers.openTab(TEST_URL); + yield helpers.openToolbar(options); + + let toolbox = yield gDevTools.showToolbox(options.target, "jsdebugger"); + let panel = toolbox.getCurrentPanel(); + + yield waitForDebuggerEvents(panel, panel.panelWin.EVENTS.SOURCE_SHOWN); + + function cmd(aTyped, aEventRepeat = 1, aOutput = "") { + return promise.all([ + waitForThreadEvents(panel, "blackboxchange", aEventRepeat), + helpers.audit(options, [{ setup: aTyped, output: aOutput, exec: {} }]) + ]); + } + + // test Black-Box Source + yield cmd("dbg blackbox " + BLACKBOXME_URL); + + let bbButton = yield selectSourceAndGetBlackBoxButton(panel, BLACKBOXME_URL); + ok(bbButton.checked, + "Should be able to black box a specific source."); + + // test Un-Black-Box Source + yield cmd("dbg unblackbox " + BLACKBOXME_URL); + + bbButton = yield selectSourceAndGetBlackBoxButton(panel, BLACKBOXME_URL); + ok(!bbButton.checked, + "Should be able to stop black boxing a specific source."); + + // test Black-Box Glob + yield cmd("dbg blackbox --glob *blackboxing_t*.js", 2, + [/blackboxing_three\.js/g, /blackboxing_two\.js/g]); + + bbButton = yield selectSourceAndGetBlackBoxButton(panel, BLACKBOXME_URL); + ok(!bbButton.checked, + "blackboxme should not be black boxed because it doesn't match the glob."); + bbButton = yield selectSourceAndGetBlackBoxButton(panel, BLACKBOXONE_URL); + ok(!bbButton.checked, + "blackbox_one should not be black boxed because it doesn't match the glob."); + + bbButton = yield selectSourceAndGetBlackBoxButton(panel, BLACKBOXTWO_URL); + ok(bbButton.checked, + "blackbox_two should be black boxed because it matches the glob."); + bbButton = yield selectSourceAndGetBlackBoxButton(panel, BLACKBOXTHREE_URL); + ok(bbButton.checked, + "blackbox_three should be black boxed because it matches the glob."); + + // test Un-Black-Box Glob + yield cmd("dbg unblackbox --glob *blackboxing_t*.js", 2); + + bbButton = yield selectSourceAndGetBlackBoxButton(panel, BLACKBOXTWO_URL); + ok(!bbButton.checked, + "blackbox_two should be un-black boxed because it matches the glob."); + bbButton = yield selectSourceAndGetBlackBoxButton(panel, BLACKBOXTHREE_URL); + ok(!bbButton.checked, + "blackbox_three should be un-black boxed because it matches the glob."); + + // test Black-Box Invert + yield cmd("dbg blackbox --invert --glob *blackboxing_t*.js", 3, + [/blackboxing_three\.js/g, /blackboxing_two\.js/g]); + + bbButton = yield selectSourceAndGetBlackBoxButton(panel, BLACKBOXME_URL); + ok(bbButton.checked, + "blackboxme should be black boxed because it doesn't match the glob."); + bbButton = yield selectSourceAndGetBlackBoxButton(panel, BLACKBOXONE_URL); + ok(bbButton.checked, + "blackbox_one should be black boxed because it doesn't match the glob."); + bbButton = yield selectSourceAndGetBlackBoxButton(panel, TEST_URL); + ok(bbButton.checked, + "TEST_URL should be black boxed because it doesn't match the glob."); + + bbButton = yield selectSourceAndGetBlackBoxButton(panel, BLACKBOXTWO_URL); + ok(!bbButton.checked, + "blackbox_two should not be black boxed because it matches the glob."); + bbButton = yield selectSourceAndGetBlackBoxButton(panel, BLACKBOXTHREE_URL); + ok(!bbButton.checked, + "blackbox_three should not be black boxed because it matches the glob."); + + // test Un-Black-Box Invert + yield cmd("dbg unblackbox --invert --glob *blackboxing_t*.js", 3); + + bbButton = yield selectSourceAndGetBlackBoxButton(panel, BLACKBOXME_URL); + ok(!bbButton.checked, + "blackboxme should be un-black boxed because it does not match the glob."); + bbButton = yield selectSourceAndGetBlackBoxButton(panel, BLACKBOXONE_URL); + ok(!bbButton.checked, + "blackbox_one should be un-black boxed because it does not match the glob."); + bbButton = yield selectSourceAndGetBlackBoxButton(panel, TEST_URL); + ok(!bbButton.checked, + "TEST_URL should be un-black boxed because it doesn't match the glob."); + + yield teardown(panel, { noTabRemoval: true }); + yield helpers.closeToolbar(options); + yield helpers.closeTab(options); +} |