• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1'use strict';
2
3require('./');
4const fs = require('fs');
5const path = require('path');
6const assert = require('assert');
7
8function getCpuProfiles(dir) {
9  const list = fs.readdirSync(dir);
10  return list
11    .filter((file) => file.endsWith('.cpuprofile'))
12    .map((file) => path.join(dir, file));
13}
14
15function getFrames(file, suffix) {
16  const data = fs.readFileSync(file, 'utf8');
17  const profile = JSON.parse(data);
18  const frames = profile.nodes.filter((i) => {
19    const frame = i.callFrame;
20    return frame.url.endsWith(suffix);
21  });
22  return { frames, nodes: profile.nodes };
23}
24
25function verifyFrames(output, file, suffix) {
26  const { frames, nodes } = getFrames(file, suffix);
27  if (frames.length === 0) {
28    // Show native debug output and the profile for debugging.
29    console.log(output.stderr.toString());
30    console.log(nodes);
31  }
32  assert.notDeepStrictEqual(frames, []);
33}
34
35// We need to set --cpu-interval to a smaller value to make sure we can
36// find our workload in the samples. 50us should be a small enough sampling
37// interval for this.
38const kCpuProfInterval = 50;
39const env = {
40  ...process.env,
41  NODE_DEBUG_NATIVE: 'INSPECTOR_PROFILER',
42};
43
44module.exports = {
45  getCpuProfiles,
46  kCpuProfInterval,
47  env,
48  getFrames,
49  verifyFrames,
50};
51