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