From 03e56a1e276239eeb332e779f14132a83fefbf0c Mon Sep 17 00:00:00 2001 From: Gireesh Punathil Date: Sun, 2 Dec 2018 19:53:28 +0530 Subject: [PATCH] child_process: ensure message sanity at source Error messages coming out of de-serialization at the send target is not consumable. So detect the scenario and fix it at the send source Ref: https://github.com/nodejs/node/issues/20314 PR-URL: https://github.com/nodejs/node/pull/24787 Reviewed-By: Luigi Pinca --- lib/internal/child_process.js | 12 ++++++++++++ test/parallel/test-child-process-fork.js | 6 ++++++ 2 files changed, 18 insertions(+) diff --git a/lib/internal/child_process.js b/lib/internal/child_process.js index be90d23f2a3203..d6121c70ef9943 100644 --- a/lib/internal/child_process.js +++ b/lib/internal/child_process.js @@ -665,6 +665,18 @@ function setupChannel(target, channel) { if (message === undefined) throw new ERR_MISSING_ARGS('message'); + // Non-serializable messages should not reach the remote + // end point; as any failure in the stringification there + // will result in error message that is weakly consumable. + // So perform a sanity check on message prior to sending. + if (typeof message !== 'string' && + typeof message !== 'object' && + typeof message !== 'number' && + typeof message !== 'boolean') { + throw new ERR_INVALID_ARG_TYPE( + 'message', ['string', 'object', 'number', 'boolean'], message); + } + // Support legacy function signature if (typeof options === 'boolean') { options = { swallowErrors: options }; diff --git a/test/parallel/test-child-process-fork.js b/test/parallel/test-child-process-fork.js index 6cfeeefb51952d..5fee2892f3b774 100644 --- a/test/parallel/test-child-process-fork.js +++ b/test/parallel/test-child-process-fork.js @@ -49,6 +49,12 @@ assert.throws(() => n.send(), { code: 'ERR_MISSING_ARGS' }); +assert.throws(() => n.send(Symbol()), { + name: 'TypeError [ERR_INVALID_ARG_TYPE]', + message: 'The "message" argument must be one of type string,' + + ' object, number, or boolean. Received type symbol', + code: 'ERR_INVALID_ARG_TYPE' +}); n.send({ hello: 'world' }); n.on('exit', common.mustCall((c) => {