summaryrefslogtreecommitdiffstats
path: root/devtools/server/tests/unit/test_blackboxing-05.js
diff options
context:
space:
mode:
authorMatt A. Tobin <mattatobin@localhost.localdomain>2018-02-02 04:16:08 -0500
committerMatt A. Tobin <mattatobin@localhost.localdomain>2018-02-02 04:16:08 -0500
commit5f8de423f190bbb79a62f804151bc24824fa32d8 (patch)
tree10027f336435511475e392454359edea8e25895d /devtools/server/tests/unit/test_blackboxing-05.js
parent49ee0794b5d912db1f95dce6eb52d781dc210db5 (diff)
downloadUXP-5f8de423f190bbb79a62f804151bc24824fa32d8.tar
UXP-5f8de423f190bbb79a62f804151bc24824fa32d8.tar.gz
UXP-5f8de423f190bbb79a62f804151bc24824fa32d8.tar.lz
UXP-5f8de423f190bbb79a62f804151bc24824fa32d8.tar.xz
UXP-5f8de423f190bbb79a62f804151bc24824fa32d8.zip
Add m-esr52 at 52.6.0
Diffstat (limited to 'devtools/server/tests/unit/test_blackboxing-05.js')
-rw-r--r--devtools/server/tests/unit/test_blackboxing-05.js84
1 files changed, 84 insertions, 0 deletions
diff --git a/devtools/server/tests/unit/test_blackboxing-05.js b/devtools/server/tests/unit/test_blackboxing-05.js
new file mode 100644
index 000000000..fa8142e87
--- /dev/null
+++ b/devtools/server/tests/unit/test_blackboxing-05.js
@@ -0,0 +1,84 @@
+/* Any copyright is dedicated to the Public Domain.
+ http://creativecommons.org/publicdomain/zero/1.0/ */
+
+/**
+ * Test exceptions inside black boxed sources.
+ */
+
+var gDebuggee;
+var gClient;
+var gThreadClient;
+
+function run_test()
+{
+ initTestDebuggerServer();
+ gDebuggee = addTestGlobal("test-black-box");
+ gClient = new DebuggerClient(DebuggerServer.connectPipe());
+ gClient.connect().then(function () {
+ attachTestTabAndResume(gClient, "test-black-box", function (aResponse, aTabClient, aThreadClient) {
+ gThreadClient = aThreadClient;
+ // XXX: We have to do an executeSoon so that the error isn't caught and
+ // reported by DebuggerClient.requester (because we are using the local
+ // transport and share a stack) which causes the test to fail.
+ Services.tm.mainThread.dispatch({
+ run: test_black_box
+ }, Ci.nsIThread.DISPATCH_NORMAL);
+ });
+ });
+ do_test_pending();
+}
+
+const BLACK_BOXED_URL = "http://example.com/blackboxme.js";
+const SOURCE_URL = "http://example.com/source.js";
+
+function test_black_box()
+{
+ gClient.addOneTimeListener("paused", test_black_box_exception);
+
+ Components.utils.evalInSandbox(
+ "" + function doStuff(k) { // line 1
+ throw new Error("wu tang clan ain't nuthin' ta fuck wit"); // line 2
+ k(100); // line 3
+ }, // line 4
+ gDebuggee,
+ "1.8",
+ BLACK_BOXED_URL,
+ 1
+ );
+
+ Components.utils.evalInSandbox(
+ "" + function runTest() { // line 1
+ doStuff( // line 2
+ function (n) { // line 3
+ debugger; // line 4
+ } // line 5
+ ); // line 6
+ } // line 7
+ + "\ndebugger;\n" // line 8
+ + "try { runTest() } catch (ex) { }", // line 9
+ gDebuggee,
+ "1.8",
+ SOURCE_URL,
+ 1
+ );
+}
+
+function test_black_box_exception() {
+ gThreadClient.getSources(function ({error, sources}) {
+ do_check_true(!error, "Should not get an error: " + error);
+ let sourceClient = gThreadClient.source(sources.filter(s => s.url == BLACK_BOXED_URL)[0]);
+
+ sourceClient.blackBox(function ({error}) {
+ do_check_true(!error, "Should not get an error: " + error);
+ gThreadClient.pauseOnExceptions(true);
+
+ gClient.addOneTimeListener("paused", function (aEvent, aPacket) {
+ do_check_eq(aPacket.frame.where.source.url, SOURCE_URL,
+ "We shouldn't pause while in the black boxed source.");
+ finishClient(gClient);
+ });
+
+ gThreadClient.resume();
+ });
+ });
+}