From dfbbfbb765e46899b67ce5c7cab6c2bb618c8f68 Mon Sep 17 00:00:00 2001 From: Luigi Pinca Date: Fri, 31 May 2019 20:36:23 +0200 Subject: [PATCH] net: make writeAfterFIN() return false If `false` is not returned a readable stream piped into the socket might continue reading indefinitely until the process goes out of memory. PR-URL: https://github.com/nodejs/node/pull/27996 Reviewed-By: Anna Henningsen Reviewed-By: Rich Trott Reviewed-By: Colin Ihrig --- lib/net.js | 2 ++ test/parallel/test-net-write-after-end-nt.js | 10 ++++++++-- 2 files changed, 10 insertions(+), 2 deletions(-) diff --git a/lib/net.js b/lib/net.js index 54ddaa3b403044..6c2bf568758ed6 100644 --- a/lib/net.js +++ b/lib/net.js @@ -410,6 +410,8 @@ function writeAfterFIN(chunk, encoding, cb) { if (typeof cb === 'function') { defaultTriggerAsyncIdScope(this[async_id_symbol], process.nextTick, cb, er); } + + return false; } Socket.prototype.setTimeout = setStreamTimeout; diff --git a/test/parallel/test-net-write-after-end-nt.js b/test/parallel/test-net-write-after-end-nt.js index 3f93b444f4cb36..d2f7c5c212ca0e 100644 --- a/test/parallel/test-net-write-after-end-nt.js +++ b/test/parallel/test-net-write-after-end-nt.js @@ -4,7 +4,7 @@ const common = require('../common'); const assert = require('assert'); const net = require('net'); -const { mustCall } = common; +const { expectsError, mustCall } = common; // This test ensures those errors caused by calling `net.Socket.write()` // after sockets ending will be emitted in the next tick. @@ -18,7 +18,13 @@ const server = net.createServer(mustCall((socket) => { server.close(); })); client.on('end', mustCall(() => { - client.write('hello', mustCall()); + const ret = client.write('hello', expectsError({ + code: 'EPIPE', + message: 'This socket has been ended by the other party', + type: Error + })); + + assert.strictEqual(ret, false); assert(!hasError, 'The error should be emitted in the next tick.'); })); client.end();