1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
|
/* Any copyright is dedicated to the Public Domain.
http://creativecommons.org/publicdomain/zero/1.0/ */
"use strict";
/**
* Check that pause-lifetime grips go away correctly after a resume.
*/
add_task(
threadFrontTest(async ({ threadFront, debuggee, client }) => {
const packet = await executeOnNextTickAndWaitForPause(
() => evaluateTestCode(debuggee),
threadFront
);
const args = packet.frame.arguments;
const objActor = args[0].actor;
Assert.equal(args[0].class, "Object");
Assert.ok(!!objActor);
// Make a bogus request to the grip actor. Should get
// unrecognized-packet-type (and not no-such-actor).
try {
await client.request({ to: objActor, type: "bogusRequest" });
ok(false, "bogusRequest should throw");
} catch (e) {
ok(true, "bogusRequest thrown");
Assert.equal(e.error, "unrecognizedPacketType");
}
await threadFront.resume();
// Now that we've resumed, should get no-such-actor for the
// same request.
try {
await client.request({ to: objActor, type: "bogusRequest" });
ok(false, "bogusRequest should throw");
} catch (e) {
ok(true, "bogusRequest thrown");
Assert.equal(e.error, "noSuchActor");
}
})
);
function evaluateTestCode(debuggee) {
debuggee.eval(
"(" +
function () {
// These arguments are tested.
// eslint-disable-next-line no-unused-vars
function stopMe(obj) {
debugger;
}
stopMe({ foo: "bar" });
} +
")()"
);
}
|