summaryrefslogtreecommitdiffstats
path: root/js/src/jit-test/tests/debug/onNewScript-wasm-02.js
blob: 3586fe4c2ea8ddf21fb553c73590ff0c387ff537 (plain)
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
// |jit-test| skip-if: !wasmDebuggingEnabled()
// Draining the job queue from an onNewScript hook reporting a streamed wasm
// module should not deadlock.

ignoreUnhandledRejections();

try {
    WebAssembly.compileStreaming();
    // Avoid mixing the test's jobs with the debuggee's, so that
    // automated checks can make sure AutoSaveJobQueue only
    // suspends debuggee work.
    drainJobQueue();
} catch (err) {
    assertEq(String(err).indexOf("not supported with --no-threads") !== -1, true);
    quit();
}

var g = newGlobal({newCompartment: true});

var source = new g.Uint8Array(wasmTextToBinary('(module (func unreachable))'));
g.source = source;

var dbg = new Debugger(g);
dbg.allowWasmBinarySource = true;
dbg.onNewScript = function (s, g) {
  drainJobQueue();
};

// For the old code to deadlock, OffThreadPromiseRuntimeState::internalDrain
// needs to get two Dispatchables at once when it swaps queues. A call to
// instantiateStreaming enqueues a job that will kick off a helper thread, so to
// make sure that two helper threads have had time to complete and enqueue their
// Dispatchables, we put a delay in the job queue after the helper thread
// launches.
g.eval(`
  WebAssembly.instantiateStreaming(source);
  WebAssembly.instantiateStreaming(source);
  Promise.resolve().then(() => sleep(0.1));
`);

drainJobQueue();