mirror of https://github.com/nodejs/node.git
64 lines
1.6 KiB
JavaScript
64 lines
1.6 KiB
JavaScript
'use strict';
|
|
const common = require('../common');
|
|
const { isCPPSymbolsNotMapped } = require('./util');
|
|
const tmpdir = require('../common/tmpdir');
|
|
tmpdir.refresh();
|
|
|
|
if (!common.enoughTestCpu)
|
|
common.skip('test is CPU-intensive');
|
|
|
|
if (isCPPSymbolsNotMapped) {
|
|
common.skip('C++ symbols are not mapped for this OS.');
|
|
}
|
|
|
|
// This test will produce a broken profile log.
|
|
// ensure prof-polyfill not stuck in infinite loop
|
|
// and success process
|
|
|
|
|
|
const assert = require('assert');
|
|
const { spawn, spawnSync } = require('child_process');
|
|
const path = require('path');
|
|
const { writeFileSync } = require('fs');
|
|
|
|
const LOG_FILE = path.join(tmpdir.path, 'tick-processor.log');
|
|
const RETRY_TIMEOUT = 150;
|
|
const BROKEN_PART = 'tick,';
|
|
const WARN_REG_EXP = /\(node:\d+\) \[BROKEN_PROFILE_FILE] Warning: Profile file .* is broken/;
|
|
const WARN_DETAIL_REG_EXP = /".*tick," at the file end is broken/;
|
|
|
|
const code = `function f() {
|
|
this.ts = Date.now();
|
|
setImmediate(function() { new f(); });
|
|
};
|
|
f();`;
|
|
|
|
const proc = spawn(process.execPath, [
|
|
'--no_logfile_per_isolate',
|
|
'--logfile=-',
|
|
'--prof',
|
|
'-pe', code
|
|
], {
|
|
stdio: ['ignore', 'pipe', 'inherit']
|
|
});
|
|
|
|
let ticks = '';
|
|
proc.stdout.on('data', (chunk) => ticks += chunk);
|
|
|
|
|
|
function runPolyfill(content) {
|
|
proc.kill();
|
|
content += BROKEN_PART;
|
|
writeFileSync(LOG_FILE, content);
|
|
const child = spawnSync(
|
|
`${process.execPath}`,
|
|
[
|
|
'--prof-process', LOG_FILE
|
|
]);
|
|
assert(WARN_REG_EXP.test(child.stderr.toString()));
|
|
assert(WARN_DETAIL_REG_EXP.test(child.stderr.toString()));
|
|
assert.strictEqual(child.status, 0);
|
|
}
|
|
|
|
setTimeout(() => runPolyfill(ticks), RETRY_TIMEOUT);
|