mirror of
https://github.com/nodejs/node.git
synced 2024-11-21 10:59:27 +00:00
test: add trace-gc flag test
PR-URL: https://github.com/nodejs/node/pull/42471 Reviewed-By: James M Snell <jasnell@gmail.com> Reviewed-By: Gireesh Punathil <gpunathi@in.ibm.com> Reviewed-By: Darshan Sen <raisinten@gmail.com> Reviewed-By: Luigi Pinca <luigipinca@gmail.com> Reviewed-By: Gerhard Stöbich <deb2001-github@yahoo.de>
This commit is contained in:
parent
dfdfd2471f
commit
00cb0912ef
9
test/fixtures/gc.js
vendored
Normal file
9
test/fixtures/gc.js
vendored
Normal file
@ -0,0 +1,9 @@
|
||||
let arr = new Array(300_000).fill('a');
|
||||
|
||||
for (let index = 0; index < arr.length; index++) {
|
||||
arr[index] = Math.random();
|
||||
}
|
||||
|
||||
arr = [];
|
||||
// .gc() is called to generate a Mark-sweep event
|
||||
global.gc();
|
40
test/v8-updates/test-trace-gc-flag.js
Normal file
40
test/v8-updates/test-trace-gc-flag.js
Normal file
@ -0,0 +1,40 @@
|
||||
'use strict';
|
||||
|
||||
// This test verifies that `--trace-gc` flag is well integrated.
|
||||
// We'll check here, that the console outputs gc events properly.
|
||||
require('../common');
|
||||
|
||||
const assert = require('assert');
|
||||
const { spawnSync } = require('child_process');
|
||||
|
||||
const fixtures = require('../common/fixtures');
|
||||
|
||||
{
|
||||
const childProcess = spawnSync(process.execPath, [
|
||||
'--trace-gc',
|
||||
'--expose-gc',
|
||||
fixtures.path('gc.js'),
|
||||
]);
|
||||
const output = childProcess.stdout.toString().trim();
|
||||
const lines = splitByLine(output);
|
||||
|
||||
const scavengeRegex = /\bScavenge\b/;
|
||||
const expectedOutput = [
|
||||
scavengeRegex,
|
||||
scavengeRegex,
|
||||
scavengeRegex,
|
||||
scavengeRegex,
|
||||
/\bMark-sweep\b/,
|
||||
];
|
||||
lines.forEach((line, index) => {
|
||||
assert.match(line, expectedOutput[index]);
|
||||
});
|
||||
}
|
||||
|
||||
/**
|
||||
* HELPERS
|
||||
*/
|
||||
|
||||
function splitByLine(str) {
|
||||
return str.split(/\n/);
|
||||
}
|
Loading…
Reference in New Issue
Block a user