summaryrefslogtreecommitdiffstats
path: root/devtools/server/tests/unit/test_pause_exceptions-02.js
diff options
context:
space:
mode:
Diffstat (limited to 'devtools/server/tests/unit/test_pause_exceptions-02.js')
-rw-r--r--devtools/server/tests/unit/test_pause_exceptions-02.js47
1 files changed, 47 insertions, 0 deletions
diff --git a/devtools/server/tests/unit/test_pause_exceptions-02.js b/devtools/server/tests/unit/test_pause_exceptions-02.js
new file mode 100644
index 000000000..fa9b419f0
--- /dev/null
+++ b/devtools/server/tests/unit/test_pause_exceptions-02.js
@@ -0,0 +1,47 @@
+/* Any copyright is dedicated to the Public Domain.
+ http://creativecommons.org/publicdomain/zero/1.0/ */
+
+/**
+ * Test that setting pauseOnExceptions to true when the debugger isn't in a
+ * paused state will cause the debuggee to pause when an exceptions is thrown.
+ */
+
+var gDebuggee;
+var gClient;
+var gThreadClient;
+
+function run_test()
+{
+ initTestDebuggerServer();
+ gDebuggee = addTestGlobal("test-stack");
+ gClient = new DebuggerClient(DebuggerServer.connectPipe());
+ gClient.connect().then(function () {
+ attachTestTabAndResume(gClient, "test-stack", function (aResponse, aTabClient, aThreadClient) {
+ gThreadClient = aThreadClient;
+ test_pause_frame();
+ });
+ });
+ do_test_pending();
+}
+
+function test_pause_frame()
+{
+ gThreadClient.pauseOnExceptions(true, false, function () {
+ gThreadClient.addOneTimeListener("paused", function (aEvent, aPacket) {
+ do_check_eq(aPacket.why.type, "exception");
+ do_check_eq(aPacket.why.exception, 42);
+ gThreadClient.resume(function () {
+ finishClient(gClient);
+ });
+ });
+
+ gDebuggee.eval("(" + function () {
+ function stopMe() {
+ throw 42;
+ }
+ try {
+ stopMe();
+ } catch (e) {}
+ } + ")()");
+ });
+}