0
0
mirror of https://github.com/nodejs/node.git synced 2024-11-21 21:19:50 +01:00
nodejs/test/parallel/test-http-client-read-in-error.js
Robert Nagy e573c39b88 http: don't emit 'data' after 'error'
PR-URL: https://github.com/nodejs/node/pull/28711
Reviewed-By: James M Snell <jasnell@gmail.com>
Reviewed-By: Matteo Collina <matteo.collina@gmail.com>
Reviewed-By: Rich Trott <rtrott@gmail.com>
Reviewed-By: Trivikram Kamat <trivikr.dev@gmail.com>
Reviewed-By: Luigi Pinca <luigipinca@gmail.com>
2019-09-22 18:08:20 -07:00

42 lines
870 B
JavaScript

'use strict';
const common = require('../common');
const net = require('net');
const http = require('http');
class Agent extends http.Agent {
createConnection() {
const socket = new net.Socket();
socket.on('error', function() {
socket.push('HTTP/1.1 200\r\n\r\n');
});
let onNewListener;
socket.on('newListener', onNewListener = (name) => {
if (name !== 'error')
return;
socket.removeListener('newListener', onNewListener);
// Let other listeners to be set up too
process.nextTick(() => {
this.breakSocket(socket);
});
});
return socket;
}
breakSocket(socket) {
socket.emit('error', new Error('Intentional error'));
}
}
const agent = new Agent();
http.request({
agent
}).once('error', function() {
console.log('ignore');
this.on('data', common.mustNotCall());
});