From dca4d84349fc23c7f0aff28df6734568ef5b9ffe Mon Sep 17 00:00:00 2001 From: Joyee Cheung Date: Mon, 11 Sep 2023 17:56:01 +0200 Subject: [PATCH] test: use setImmediate() in test-heapdump-shadowrealm.js With a tight loop the GC may not have enough time to kick in. Try setImmediate() instead. PR-URL: https://github.com/nodejs/node/pull/49573 Refs: https://github.com/nodejs/node/issues/49572 Reviewed-By: Luigi Pinca Reviewed-By: Chengzhong Wu --- test/pummel/test-heapdump-shadow-realm.js | 54 ++++++++++++++--------- 1 file changed, 32 insertions(+), 22 deletions(-) diff --git a/test/pummel/test-heapdump-shadow-realm.js b/test/pummel/test-heapdump-shadow-realm.js index 76bd425e1c8674..7ec40118c5b9ca 100644 --- a/test/pummel/test-heapdump-shadow-realm.js +++ b/test/pummel/test-heapdump-shadow-realm.js @@ -4,29 +4,39 @@ require('../common'); const { validateSnapshotNodes } = require('../common/heap'); validateSnapshotNodes('Node / ShadowRealm', []); -const realm = new ShadowRealm(); -{ - // Create a bunch of un-referenced ShadowRealms to make sure the heap - // snapshot can handle it. - for (let i = 0; i < 100; i++) { - const realm = new ShadowRealm(); + +let realm; +let counter = 0; +// Create a bunch of un-referenced ShadowRealms to make sure the heap +// snapshot can handle it. +function createRealms() { + // Use setImmediate to give GC some time to kick in to avoid OOM. + if (counter++ < 100) { + realm = new ShadowRealm(); + realm.evaluate('undefined'); + setImmediate(createRealms); + } else { + validateHeap(); + // Keep the realm alive. realm.evaluate('undefined'); } } -validateSnapshotNodes('Node / Environment', [ - { - children: [ - { node_name: 'Node / shadow_realms', edge_name: 'shadow_realms' }, - ], - }, -]); -validateSnapshotNodes('Node / shadow_realms', [ - { - children: [ - { node_name: 'Node / ShadowRealm' }, - ], - }, -]); -// Keep the realm alive. -realm.evaluate('undefined'); +function validateHeap() { + validateSnapshotNodes('Node / Environment', [ + { + children: [ + { node_name: 'Node / shadow_realms', edge_name: 'shadow_realms' }, + ], + }, + ]); + validateSnapshotNodes('Node / shadow_realms', [ + { + children: [ + { node_name: 'Node / ShadowRealm' }, + ], + }, + ]); +} + +createRealms();