0
0
mirror of https://github.com/nodejs/node.git synced 2024-12-01 16:10:02 +01:00
nodejs/test/parallel/test-child-process-silent.js

87 lines
2.3 KiB
JavaScript
Raw Normal View History

'use strict';
require('../common');
var assert = require('assert');
2012-01-04 15:28:13 +01:00
var childProcess = require('child_process');
2012-01-04 15:28:13 +01:00
// Child pipe test
if (process.argv[2] === 'pipetest') {
process.stdout.write('stdout message');
process.stderr.write('stderr message');
2012-01-04 15:28:13 +01:00
} else if (process.argv[2] === 'ipctest') {
// Child IPC test
process.send('message from child');
2012-01-04 15:28:13 +01:00
process.on('message', function() {
process.send('got message from master');
});
2012-01-04 15:28:13 +01:00
} else if (process.argv[2] === 'parent') {
// Parent | start child pipe test
var child = childProcess.fork(process.argv[1], ['pipetest'], {silent: true});
// Allow child process to self terminate
child._channel.close();
child._channel = null;
child.on('exit', function() {
process.exit(0);
});
} else {
2012-01-04 15:28:13 +01:00
// testcase | start parent && child IPC test
// testing: is stderr and stdout piped to parent
2012-02-19 00:01:35 +01:00
var args = [process.argv[1], 'parent'];
var parent = childProcess.spawn(process.execPath, args);
2012-01-04 15:28:13 +01:00
//got any stderr or std data
var stdoutData = false;
parent.stdout.on('data', function() {
stdoutData = true;
});
var stderrData = false;
parent.stdout.on('data', function() {
stderrData = true;
});
// testing: do message system work when using silent
var child = childProcess.fork(process.argv[1], ['ipctest'], {silent: true});
// Manual pipe so we will get errors
child.stderr.pipe(process.stderr, {end: false});
child.stdout.pipe(process.stdout, {end: false});
var childSending = false;
var childReciveing = false;
child.on('message', function(message) {
if (childSending === false) {
childSending = (message === 'message from child');
}
2012-01-04 15:28:13 +01:00
if (childReciveing === false) {
childReciveing = (message === 'got message from master');
}
2012-01-04 15:28:13 +01:00
if (childReciveing === true) {
child.kill();
}
});
child.send('message to child');
2012-01-04 15:28:13 +01:00
// Check all values
process.on('exit', function() {
// clean up
child.kill();
parent.kill();
2012-01-04 15:28:13 +01:00
// Check std(out|err) pipes
assert.ok(!stdoutData, 'The stdout socket was piped to parent');
assert.ok(!stderrData, 'The stderr socket was piped to parent');
2012-01-04 15:28:13 +01:00
// Check message system
assert.ok(childSending, 'The child was able to send a message');
assert.ok(childReciveing, 'The child was able to receive a message');
});
}