1'use strict'; 2require('../common'); 3const fs = require('fs'); 4const cp = require('child_process'); 5const path = require('path'); 6 7const tmpdir = require('../common/tmpdir'); 8tmpdir.refresh(); 9 10const LOG_FILE = path.join(tmpdir.path, 'tick-processor.log'); 11const RETRY_TIMEOUT = 150; 12 13function runTest(test) { 14 const proc = cp.spawn(process.execPath, [ 15 '--no_logfile_per_isolate', 16 '--logfile=-', 17 '--prof', 18 '-pe', test.code, 19 ], { 20 stdio: [ 'ignore', 'pipe', 'inherit' ], 21 }); 22 23 let ticks = ''; 24 proc.stdout.on('data', (chunk) => ticks += chunk); 25 26 // Try to match after timeout 27 setTimeout(() => { 28 match(test.pattern, proc, () => ticks, test.profProcessFlags); 29 }, RETRY_TIMEOUT); 30} 31 32function match(pattern, parent, ticks, flags = []) { 33 // Store current ticks log 34 fs.writeFileSync(LOG_FILE, ticks()); 35 36 const proc = cp.spawn(process.execPath, [ 37 '--prof-process', 38 '--call-graph-size=10', 39 ...flags, 40 LOG_FILE, 41 ], { 42 stdio: [ 'ignore', 'pipe', 'inherit' ], 43 }); 44 45 let out = ''; 46 47 proc.stdout.on('data', (chunk) => out += chunk); 48 proc.stdout.once('end', () => { 49 proc.once('exit', () => { 50 fs.unlinkSync(LOG_FILE); 51 52 // Retry after timeout 53 if (!pattern.test(out)) 54 return setTimeout(() => match(pattern, parent, ticks), RETRY_TIMEOUT); 55 56 parent.stdout.removeAllListeners(); 57 parent.kill(); 58 }); 59 60 proc.stdout.removeAllListeners(); 61 proc.kill(); 62 }); 63} 64 65exports.runTest = runTest; 66