11cb0ef41Sopenharmony_ci'use strict'; 21cb0ef41Sopenharmony_ci 31cb0ef41Sopenharmony_ci// Tests that --heap-prof outputs heap profile when event loop is drained. 41cb0ef41Sopenharmony_ci 51cb0ef41Sopenharmony_ciconst common = require('../common'); 61cb0ef41Sopenharmony_ci 71cb0ef41Sopenharmony_ciconst fixtures = require('../common/fixtures'); 81cb0ef41Sopenharmony_cicommon.skipIfInspectorDisabled(); 91cb0ef41Sopenharmony_ci 101cb0ef41Sopenharmony_ciconst assert = require('assert'); 111cb0ef41Sopenharmony_ciconst { spawnSync } = require('child_process'); 121cb0ef41Sopenharmony_ci 131cb0ef41Sopenharmony_ciconst tmpdir = require('../common/tmpdir'); 141cb0ef41Sopenharmony_ci 151cb0ef41Sopenharmony_ciconst { 161cb0ef41Sopenharmony_ci getHeapProfiles, 171cb0ef41Sopenharmony_ci verifyFrames, 181cb0ef41Sopenharmony_ci kHeapProfInterval, 191cb0ef41Sopenharmony_ci env, 201cb0ef41Sopenharmony_ci} = require('../common/prof'); 211cb0ef41Sopenharmony_ci 221cb0ef41Sopenharmony_ci{ 231cb0ef41Sopenharmony_ci tmpdir.refresh(); 241cb0ef41Sopenharmony_ci const output = spawnSync(process.execPath, [ 251cb0ef41Sopenharmony_ci '--heap-prof', 261cb0ef41Sopenharmony_ci '--heap-prof-interval', 271cb0ef41Sopenharmony_ci kHeapProfInterval, 281cb0ef41Sopenharmony_ci fixtures.path('workload', 'allocation.js'), 291cb0ef41Sopenharmony_ci ], { 301cb0ef41Sopenharmony_ci cwd: tmpdir.path, 311cb0ef41Sopenharmony_ci env 321cb0ef41Sopenharmony_ci }); 331cb0ef41Sopenharmony_ci if (output.status !== 0) { 341cb0ef41Sopenharmony_ci console.log(output.stderr.toString()); 351cb0ef41Sopenharmony_ci console.log(output); 361cb0ef41Sopenharmony_ci } 371cb0ef41Sopenharmony_ci assert.strictEqual(output.status, 0); 381cb0ef41Sopenharmony_ci const profiles = getHeapProfiles(tmpdir.path); 391cb0ef41Sopenharmony_ci assert.strictEqual(profiles.length, 1); 401cb0ef41Sopenharmony_ci verifyFrames(output, profiles[0], 'runAllocation'); 411cb0ef41Sopenharmony_ci} 42