%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'; // Tests multiple profiles generated by --heap-prof-interval are valid. const common = require('../common'); const fixtures = require('../common/fixtures'); common.skipIfInspectorDisabled(); const assert = require('assert'); const fs = require('fs'); const path = require('path'); const { spawnSync } = require('child_process'); const tmpdir = require('../common/tmpdir'); const { getHeapProfiles, findFirstFrame, kHeapProfInterval, env } = require('../common/prof'); { tmpdir.refresh(); const output = spawnSync(process.execPath, [ '--heap-prof-interval', kHeapProfInterval, '--heap-prof-dir', 'prof', '--heap-prof', fixtures.path('workload', 'allocation-worker.js'), ], { cwd: tmpdir.path, env }); if (output.status !== 0) { console.log(output.stderr.toString()); } assert.strictEqual(output.status, 0); const dir = path.join(tmpdir.path, 'prof'); assert(fs.existsSync(dir)); const profiles = getHeapProfiles(dir); assert.strictEqual(profiles.length, 2); const profile1 = findFirstFrame(profiles[0], 'runAllocation'); const profile2 = findFirstFrame(profiles[1], 'runAllocation'); if (!profile1.frame && !profile2.frame) { // Show native debug output and the profile for debugging. console.log(output.stderr.toString()); console.log('heap path: ', profiles[0]); console.log(profile1.roots); console.log('heap path: ', profiles[1]); console.log(profile2.roots); } assert(profile1.frame || profile2.frame); }