%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'; // This tests that tracing can be enabled dynamically with the // trace_events module. const common = require('../common'); try { require('trace_events'); } catch { common.skip('missing trace events'); } const assert = require('assert'); const cp = require('child_process'); const fs = require('fs'); const path = require('path'); const enable = `require("trace_events").createTracing( { categories: ["node.async_hooks"] }).enable();`; const code = 'setTimeout(() => { for (let i = 0; i < 100000; i++) { "test" + i } }, 1)'; const tmpdir = require('../common/tmpdir'); const filename = path.join(tmpdir.path, 'node_trace.1.log'); tmpdir.refresh(); const proc = cp.spawnSync( process.execPath, ['-e', enable + code ], { cwd: tmpdir.path, env: { ...process.env, 'NODE_DEBUG_NATIVE': 'tracing', 'NODE_DEBUG': 'tracing' } }); console.log('process exit with signal:', proc.signal); console.log('process stderr:', proc.stderr.toString()); assert.strictEqual(proc.status, 0); assert(fs.existsSync(filename)); const data = fs.readFileSync(filename, 'utf-8'); const traces = JSON.parse(data).traceEvents; function filterTimeoutTraces(trace) { if (trace.pid !== proc.pid) return false; if (trace.cat !== 'node,node.async_hooks') return false; if (trace.name !== 'Timeout') return false; return true; } { const timeoutTraces = traces.filter(filterTimeoutTraces); assert.notDeepStrictEqual(timeoutTraces, []); const threads = new Set(); for (const trace of timeoutTraces) { threads.add(trace.tid); } assert.notDeepStrictEqual(timeoutTraces, []); }