node/test/parallel/test-debugger-profile-command.js
Joyee Cheung 812e236df9
test: move debugger tests with --port=0 to parallel
Before

```
❯ tools/test.py "sequential/test-debugger*"
[00:25|% 100|+  32|-   0]: Done

All tests passed.
❯ tools/test.py -J "parallel/test-debugger*"
[00:05|% 100|+   6|-   0]: Done

All tests passed.
```

After

```
❯ tools/test.py "sequential/test-debugger*"
[00:06|% 100|+   5|-   0]: Done

All tests passed.
❯ tools/test.py -J "parallel/test-debugger*"
[00:05|% 100|+  33|-   0]: Done

All tests passed.
```

PR-URL: https://github.com/nodejs/node/pull/47274
Refs: https://github.com/nodejs/node/issues/47146
Reviewed-By: Colin Ihrig <cjihrig@gmail.com>
Reviewed-By: Michaël Zasso <targos@protonmail.com>
Reviewed-By: Luigi Pinca <luigipinca@gmail.com>
Reviewed-By: Moshe Atlow <moshe@atlow.co.il>
Reviewed-By: James M Snell <jasnell@gmail.com>
2023-04-05 00:49:46 +02:00

36 lines
1.0 KiB
JavaScript

'use strict';
const common = require('../common');
common.skipIfInspectorDisabled();
const fixtures = require('../common/fixtures');
const startCLI = require('../common/debugger');
const assert = require('assert');
const fs = require('fs');
const path = require('path');
const cli = startCLI(['--port=0', fixtures.path('debugger/empty.js')]);
const rootDir = path.resolve(__dirname, '..', '..');
(async () => {
await cli.waitForInitialBreak();
await cli.waitForPrompt();
await cli.command('profile');
await cli.command('profileEnd');
assert.match(cli.output, /\[Profile \d+μs\]/);
await cli.command('profiles');
assert.match(cli.output, /\[ \[Profile \d+μs\] \]/);
await cli.command('profiles[0].save()');
assert.match(cli.output, /Saved profile to .*node\.cpuprofile/);
const cpuprofile = path.resolve(rootDir, 'node.cpuprofile');
const data = JSON.parse(fs.readFileSync(cpuprofile, 'utf8'));
assert.strictEqual(Array.isArray(data.nodes), true);
fs.rmSync(cpuprofile);
})()
.then(common.mustCall())
.finally(() => cli.quit());