From 87c3e1d7de88dbd33b7185c23c1491c64fe1b499 Mon Sep 17 00:00:00 2001 From: davidmarkclements Date: Mon, 21 Aug 2017 19:01:06 +0100 Subject: [PATCH] fix --prof-process --preprocess flag This is a one-line fix to prevent the --preprocess option (used with --prof-process to output JSON) to cause an isolate log file profiling process to crash. PR-URL: https://github.com/nodejs/node/pull/14966 Reviewed-By: Luca Maraschi Reviewed-By: Matteo Collina Reviewed-By: James M Snell --- lib/internal/v8_prof_processor.js | 1 + .../test-tick-processor-preprocess-flag.js | 24 +++++++++++++++++++ test/tick-processor/tick-processor-base.js | 6 +++-- 3 files changed, 29 insertions(+), 2 deletions(-) create mode 100644 test/tick-processor/test-tick-processor-preprocess-flag.js diff --git a/lib/internal/v8_prof_processor.js b/lib/internal/v8_prof_processor.js index f0bcff7482d724..01b81c6ba56492 100644 --- a/lib/internal/v8_prof_processor.js +++ b/lib/internal/v8_prof_processor.js @@ -32,6 +32,7 @@ if (process.platform === 'darwin') { tickArguments.push.apply(tickArguments, process.argv.slice(1)); script = `(function() { arguments = ${JSON.stringify(tickArguments)}; + function write (s) { process.stdout.write(s) } ${script} })()`; eval(script); diff --git a/test/tick-processor/test-tick-processor-preprocess-flag.js b/test/tick-processor/test-tick-processor-preprocess-flag.js new file mode 100644 index 00000000000000..52d642a3ae3fc0 --- /dev/null +++ b/test/tick-processor/test-tick-processor-preprocess-flag.js @@ -0,0 +1,24 @@ +'use strict'; +const common = require('../common'); + +if (!common.enoughTestCpu) + common.skip('test is CPU-intensive'); + +if (common.isWindows || + common.isSunOS || + common.isAIX || + common.isLinuxPPCBE || + common.isFreeBSD) + common.skip('C++ symbols are not mapped for this os.'); + +const base = require('./tick-processor-base.js'); + +base.runTest({ + pattern: /^{/, + code: `function f() { + require('vm').runInDebugContext('Debug'); + setImmediate(function() { f(); }); + }; + f();`, + profProcessFlags: ['--preprocess'] +}); diff --git a/test/tick-processor/tick-processor-base.js b/test/tick-processor/tick-processor-base.js index aff37ba109e141..3017dc6bb47250 100644 --- a/test/tick-processor/tick-processor-base.js +++ b/test/tick-processor/tick-processor-base.js @@ -24,23 +24,25 @@ function runTest(test) { // Try to match after timeout setTimeout(() => { - match(test.pattern, proc, () => ticks); + match(test.pattern, proc, () => ticks, test.profProcessFlags); }, RETRY_TIMEOUT); } -function match(pattern, parent, ticks) { +function match(pattern, parent, ticks, flags = []) { // Store current ticks log fs.writeFileSync(LOG_FILE, ticks()); const proc = cp.spawn(process.execPath, [ '--prof-process', '--call-graph-size=10', + ...flags, LOG_FILE ], { stdio: [ 'ignore', 'pipe', 'inherit' ] }); let out = ''; + proc.stdout.on('data', (chunk) => out += chunk); proc.stdout.once('end', () => { proc.once('exit', () => {