Browse Source

test: update test-child-process-recv-handle

change var to const/let where appropriate
use strictEqual instead of equal
call toString on buffers in strictEqual asserts
use common.mustCall on callbacks containing asserts

PR-URL: https://github.com/nodejs/node/pull/8648
Reviewed-By: James M Snell <jasnell@gmail.com>
Reviewed-By: Michaël Zasso <targos@protonmail.com>
v6.x
Jonathan Prince 8 years ago
committed by Jeremiah Senkpiel
parent
commit
714cbfd46c
  1. 45
      test/parallel/test-child-process-recv-handle.js

45
test/parallel/test-child-process-recv-handle.js

@ -2,10 +2,10 @@
// Test that a Linux specific quirk in the handle passing protocol is handled // Test that a Linux specific quirk in the handle passing protocol is handled
// correctly. See https://github.com/joyent/node/issues/5330 for details. // correctly. See https://github.com/joyent/node/issues/5330 for details.
var common = require('../common'); const common = require('../common');
var assert = require('assert'); const assert = require('assert');
var net = require('net'); const net = require('net');
var spawn = require('child_process').spawn; const spawn = require('child_process').spawn;
if (process.argv[2] === 'worker') if (process.argv[2] === 'worker')
worker(); worker();
@ -15,15 +15,15 @@ else
function master() { function master() {
// spawn() can only create one IPC channel so we use stdin/stdout as an // spawn() can only create one IPC channel so we use stdin/stdout as an
// ad-hoc command channel. // ad-hoc command channel.
var proc = spawn(process.execPath, [__filename, 'worker'], { const proc = spawn(process.execPath, [__filename, 'worker'], {
stdio: ['pipe', 'pipe', 'pipe', 'ipc'] stdio: ['pipe', 'pipe', 'pipe', 'ipc']
}); });
var handle = null; let handle = null;
proc.on('exit', function() { proc.on('exit', () => {
handle.close(); handle.close();
}); });
proc.stdout.on('data', function(data) { proc.stdout.on('data', common.mustCall((data) => {
assert.equal(data, 'ok\r\n'); assert.strictEqual(data.toString(), 'ok\r\n');
net.createServer(common.fail).listen(0, function() { net.createServer(common.fail).listen(0, function() {
handle = this._handle; handle = this._handle;
proc.send('one'); proc.send('one');
@ -31,7 +31,7 @@ function master() {
proc.send('three'); proc.send('three');
proc.stdin.write('ok\r\n'); proc.stdin.write('ok\r\n');
}); });
}); }));
proc.stderr.pipe(process.stderr); proc.stderr.pipe(process.stderr);
} }
@ -39,25 +39,24 @@ function worker() {
process._channel.readStop(); // Make messages batch up. process._channel.readStop(); // Make messages batch up.
process.stdout.ref(); process.stdout.ref();
process.stdout.write('ok\r\n'); process.stdout.write('ok\r\n');
process.stdin.once('data', function(data) { process.stdin.once('data', common.mustCall((data) => {
assert.equal(data, 'ok\r\n'); assert.strictEqual(data.toString(), 'ok\r\n');
process._channel.readStart(); process._channel.readStart();
}); }));
var n = 0; let n = 0;
process.on('message', function(msg, handle) { process.on('message', common.mustCall((msg, handle) => {
n += 1; n += 1;
if (n === 1) { if (n === 1) {
assert.equal(msg, 'one'); assert.strictEqual(msg, 'one');
assert.equal(handle, undefined); assert.strictEqual(handle, undefined);
} else if (n === 2) { } else if (n === 2) {
assert.equal(msg, 'two'); assert.strictEqual(msg, 'two');
assert.equal(typeof handle, 'object'); // Also matches null, therefore... assert.ok(handle !== null && typeof handle === 'object');
assert.ok(handle); // also check that it's truthy.
handle.close(); handle.close();
} else if (n === 3) { } else if (n === 3) {
assert.equal(msg, 'three'); assert.strictEqual(msg, 'three');
assert.equal(handle, undefined); assert.strictEqual(handle, undefined);
process.exit(); process.exit();
} }
}); }, 3));
} }

Loading…
Cancel
Save