// |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();
Messung V0.5
¤ Dauer der Verarbeitung: 0.11 Sekunden
(vorverarbeitet)
¤
Die Informationen auf dieser Webseite wurden
nach bestem Wissen sorgfältig zusammengestellt. Es wird jedoch weder Vollständigkeit, noch Richtigkeit,
noch Qualität der bereit gestellten Informationen zugesichert.
Bemerkung:
Die farbliche Syntaxdarstellung und die Messung sind noch experimentell.