summaryrefslogtreecommitdiffstats
path: root/devtools/server/tests/unit/test_threadlifetime-03.js
diff options
context:
space:
mode:
Diffstat (limited to 'devtools/server/tests/unit/test_threadlifetime-03.js')
-rw-r--r--devtools/server/tests/unit/test_threadlifetime-03.js81
1 files changed, 81 insertions, 0 deletions
diff --git a/devtools/server/tests/unit/test_threadlifetime-03.js b/devtools/server/tests/unit/test_threadlifetime-03.js
new file mode 100644
index 000000000..22b707ff8
--- /dev/null
+++ b/devtools/server/tests/unit/test_threadlifetime-03.js
@@ -0,0 +1,81 @@
+/* Any copyright is dedicated to the Public Domain.
+ http://creativecommons.org/publicdomain/zero/1.0/ */
+
+/**
+ * Check that thread-lifetime grips last past a resume.
+ */
+
+var gDebuggee;
+var gClient;
+var gThreadClient;
+
+function run_test()
+{
+ initTestDebuggerServer();
+ gDebuggee = addTestGlobal("test-grips");
+ gClient = new DebuggerClient(DebuggerServer.connectPipe());
+ gClient.connect().then(function () {
+ attachTestTabAndResume(gClient, "test-grips", function (aResponse, aTabClient, aThreadClient) {
+ gThreadClient = aThreadClient;
+ test_thread_lifetime();
+ });
+ });
+ do_test_pending();
+}
+
+function test_thread_lifetime()
+{
+ // Get three thread-lifetime grips.
+ gThreadClient.addOneTimeListener("paused", function (aEvent, aPacket) {
+ let grips = [];
+
+ let handler = function (aResponse) {
+ if (aResponse.error) {
+ do_check_eq(aResponse.error, "");
+ finishClient(gClient);
+ }
+ grips.push(aResponse.from);
+ if (grips.length == 3) {
+ test_release_many(grips);
+ }
+ };
+ for (let i = 0; i < 3; i++) {
+ gClient.request({ to: aPacket.frame.arguments[i].actor, type: "threadGrip" },
+ handler);
+ }
+ });
+
+ gDebuggee.eval("(" + function () {
+ function stopMe(arg1, arg2, arg3) {
+ debugger;
+ }
+ stopMe({obj: 1}, {obj: 2}, {obj: 3});
+ } + ")()");
+}
+
+function test_release_many(grips)
+{
+ // Release the first two grips, leave the third alive.
+
+ let release = [grips[0], grips[1]];
+
+ gThreadClient.releaseMany(release, function (aResponse) {
+ // First two actors should return a noSuchActor error, because
+ // they're gone now.
+ gClient.request({ to: grips[0], type: "bogusRequest" }, function (aResponse) {
+ do_check_eq(aResponse.error, "noSuchActor");
+ gClient.request({ to: grips[1], type: "bogusRequest" }, function (aResponse) {
+ do_check_eq(aResponse.error, "noSuchActor");
+
+ // Last actor should return unrecognizedPacketType, because it's still
+ // alive.
+ gClient.request({ to: grips[2], type: "bogusRequest" }, function (aResponse) {
+ do_check_eq(aResponse.error, "unrecognizedPacketType");
+ gThreadClient.resume(function () {
+ finishClient(gClient);
+ });
+ });
+ });
+ });
+ });
+}