%PDF- <> %âãÏÓ endobj 2 0 obj <> endobj 3 0 obj <>/ExtGState<>/ProcSet[/PDF/Text/ImageB/ImageC/ImageI] >>/Annots[ 28 0 R 29 0 R] /MediaBox[ 0 0 595.5 842.25] /Contents 4 0 R/Group<>/Tabs/S>> endobj ºaâÚÎΞ-ÌE1ÍØÄ÷{òò2ÿ ÛÖ^ÔÀá TÎ{¦?§®¥kuµùÕ5sLOšuY>endobj 2 0 obj<>endobj 2 0 obj<>endobj 2 0 obj<>endobj 2 0 obj<> endobj 2 0 obj<>endobj 2 0 obj<>es 3 0 R>> endobj 2 0 obj<> ox[ 0.000000 0.000000 609.600000 935.600000]/Fi endobj 3 0 obj<> endobj 7 1 obj<>/ProcSet[/PDF/Text/ImageB/ImageC/ImageI]>>/Subtype/Form>> stream
'use strict'; const common = require('../common'); common.skipIfInspectorDisabled(); common.skipIfWorker(); const assert = require('assert'); const { Worker } = require('worker_threads'); const { Session } = require('inspector'); const session = new Session(); let done = false; function onAttachToWorker({ params: { sessionId } }) { let id = 1; function postToWorkerInspector(method, params) { session.post('NodeWorker.sendMessageToWorker', { sessionId, message: JSON.stringify({ id: id++, method, params }) }, () => console.log(`Message ${method} received the response`)); } // Wait for the notification function onMessageReceived({ params: { message } }) { if (!message || JSON.parse(message).method !== 'NodeRuntime.waitingForDisconnect') { session.once('NodeWorker.receivedMessageFromWorker', onMessageReceived); return; } // Force a call to node::inspector::Agent::ToggleAsyncHook by changing the // async call stack depth postToWorkerInspector('Debugger.setAsyncCallStackDepth', { maxDepth: 1 }); // This is were the original crash happened session.post('NodeWorker.detach', { sessionId }, () => { done = true; }); } onMessageReceived({ params: { message: null } }); // Enable the debugger, otherwise setAsyncCallStackDepth does nothing postToWorkerInspector('Debugger.enable'); // Start waiting for disconnect notification postToWorkerInspector('NodeRuntime.notifyWhenWaitingForDisconnect', { enabled: true }); // start worker postToWorkerInspector('Runtime.runIfWaitingForDebugger'); } session.connect(); session.on('NodeWorker.attachedToWorker', common.mustCall(onAttachToWorker)); session.post('NodeWorker.enable', { waitForDebuggerOnStart: true }, () => { new Worker('console.log("Worker is done")', { eval: true }) .once('exit', () => { setTimeout(() => { assert.strictEqual(done, true); console.log('Test is done'); }, 0); }); });