mirror of https://github.com/nodejs/node.git
63 lines
1.6 KiB
JavaScript
63 lines
1.6 KiB
JavaScript
|
'use strict';
|
||
|
const common = require('../common');
|
||
|
const tmpdir = require('../common/tmpdir');
|
||
|
tmpdir.refresh();
|
||
|
|
||
|
if (!common.enoughTestCpu)
|
||
|
common.skip('test is CPU-intensive');
|
||
|
|
||
|
if (common.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 cp = require('child_process');
|
||
|
const path = require('path');
|
||
|
const fs = 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 = cp.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;
|
||
|
fs.writeFileSync(LOG_FILE, content);
|
||
|
const child = cp.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);
|