%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
// Flags: --expose-gc 'use strict'; const common = require('../common'); const assert = require('assert'); const async_hooks = require('async_hooks'); const v8 = require('v8'); // Regression test for https://github.com/nodejs/node/issues/28786 // Make sure that creating a heap snapshot inside an async_hooks hook // works for Promises. const createSnapshot = common.mustCall(() => { v8.getHeapSnapshot().resume(); }, 8); // 2 × init + 2 × resolve + 1 × (after + before) + 2 × destroy = 8 calls const promiseIds = []; async_hooks.createHook({ init(id, type) { if (type === 'PROMISE') { createSnapshot(); promiseIds.push(id); } }, before(id) { if (promiseIds.includes(id)) createSnapshot(); }, after(id) { if (promiseIds.includes(id)) createSnapshot(); }, promiseResolve(id) { assert(promiseIds.includes(id)); createSnapshot(); }, destroy(id) { if (promiseIds.includes(id)) createSnapshot(); } }).enable(); Promise.resolve().then(() => {}); setImmediate(global.gc);