2015-05-19 13:00:06 +02:00
|
|
|
'use strict';
|
2015-12-24 01:02:12 +01:00
|
|
|
require('../common');
|
2011-12-17 11:52:40 +01:00
|
|
|
var assert = require('assert');
|
2012-01-04 15:28:13 +01:00
|
|
|
var childProcess = require('child_process');
|
2011-12-17 11:52:40 +01:00
|
|
|
|
2012-01-04 15:28:13 +01:00
|
|
|
// Child pipe test
|
2016-01-29 08:02:57 +01:00
|
|
|
if (process.argv[2] === 'pipe') {
|
2012-01-04 15:28:13 +01:00
|
|
|
process.stdout.write('stdout message');
|
|
|
|
process.stderr.write('stderr message');
|
2011-12-17 11:52:40 +01:00
|
|
|
|
2016-01-29 08:02:57 +01:00
|
|
|
} else if (process.argv[2] === 'ipc') {
|
2012-01-04 15:28:13 +01:00
|
|
|
// Child IPC test
|
2011-12-17 11:52:40 +01:00
|
|
|
process.send('message from child');
|
2012-01-04 15:28:13 +01:00
|
|
|
process.on('message', function() {
|
2011-12-17 11:52:40 +01:00
|
|
|
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
|
|
|
|
|
2016-01-29 08:02:57 +01:00
|
|
|
const child = childProcess.fork(process.argv[1], ['pipe'], {silent: true});
|
2012-01-04 15:28:13 +01:00
|
|
|
|
|
|
|
// Allow child process to self terminate
|
|
|
|
child._channel.close();
|
|
|
|
child._channel = null;
|
|
|
|
|
|
|
|
child.on('exit', function() {
|
|
|
|
process.exit(0);
|
|
|
|
});
|
|
|
|
|
2011-12-17 11:52:40 +01:00
|
|
|
} 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);
|
2011-12-17 11:52:40 +01:00
|
|
|
|
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
|
2016-01-29 08:02:57 +01:00
|
|
|
const child = childProcess.fork(process.argv[1], ['ipc'], {silent: true});
|
2012-01-04 15:28:13 +01:00
|
|
|
|
|
|
|
// 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');
|
2011-12-17 11:52:40 +01:00
|
|
|
}
|
|
|
|
|
2012-01-04 15:28:13 +01:00
|
|
|
if (childReciveing === false) {
|
|
|
|
childReciveing = (message === 'got message from master');
|
2011-12-17 11:52:40 +01:00
|
|
|
}
|
|
|
|
|
2012-01-04 15:28:13 +01:00
|
|
|
if (childReciveing === true) {
|
2011-12-17 11:52:40 +01:00
|
|
|
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();
|
2011-12-17 11:52:40 +01:00
|
|
|
|
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');
|
2011-12-17 11:52:40 +01:00
|
|
|
|
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');
|
2011-12-17 11:52:40 +01:00
|
|
|
});
|
|
|
|
}
|