http: add test for incomingmessage destroy
Test uncaught exceptions when destroying IncomingMessage. PR-URL: https://github.com/nodejs/node/pull/33035 Refs: https://github.com/nodejs/node/issues/30625 Reviewed-By: Robert Nagy <ronagy@icloud.com> Reviewed-By: Matteo Collina <matteo.collina@gmail.com> Reviewed-By: Rich Trott <rtrott@gmail.com>
This commit is contained in:
parent
a6bf74eac0
commit
8154e47e2b
@ -361,14 +361,13 @@ IncomingMessage.prototype._dump = function _dump() {
|
|||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
function onError(instance, error, cb) {
|
function onError(self, error, cb) {
|
||||||
// This is to keep backward compatible behavior.
|
// This is to keep backward compatible behavior.
|
||||||
// An error is emitted only if there are listeners attached to
|
// An error is emitted only if there are listeners attached to the event.
|
||||||
// the event.
|
if (self.listenerCount('error') === 0) {
|
||||||
if (instance.listenerCount('error') > 0) {
|
|
||||||
cb(error);
|
|
||||||
} else {
|
|
||||||
cb();
|
cb();
|
||||||
|
} else {
|
||||||
|
cb(error);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
25
test/parallel/test-http-client-incomingmessage-destroy.js
Normal file
25
test/parallel/test-http-client-incomingmessage-destroy.js
Normal file
@ -0,0 +1,25 @@
|
|||||||
|
'use strict';
|
||||||
|
|
||||||
|
const common = require('../common');
|
||||||
|
const { createServer, get } = require('http');
|
||||||
|
const assert = require('assert');
|
||||||
|
|
||||||
|
const server = createServer(common.mustCall((req, res) => {
|
||||||
|
res.writeHead(200);
|
||||||
|
res.write('Part of res.');
|
||||||
|
}));
|
||||||
|
|
||||||
|
function onUncaught(error) {
|
||||||
|
assert.strictEqual(error.message, 'Destroy test');
|
||||||
|
server.close();
|
||||||
|
}
|
||||||
|
|
||||||
|
process.on('uncaughtException', common.mustCall(onUncaught));
|
||||||
|
|
||||||
|
server.listen(0, () => {
|
||||||
|
get({
|
||||||
|
port: server.address().port
|
||||||
|
}, common.mustCall((res) => {
|
||||||
|
res.destroy(new Error('Destroy test'));
|
||||||
|
}));
|
||||||
|
});
|
25
test/parallel/test-http-server-incomingmessage-destroy.js
Normal file
25
test/parallel/test-http-server-incomingmessage-destroy.js
Normal file
@ -0,0 +1,25 @@
|
|||||||
|
'use strict';
|
||||||
|
|
||||||
|
const common = require('../common');
|
||||||
|
const { createServer, get } = require('http');
|
||||||
|
const assert = require('assert');
|
||||||
|
|
||||||
|
const server = createServer(common.mustCall((req, res) => {
|
||||||
|
req.destroy(new Error('Destroy test'));
|
||||||
|
}));
|
||||||
|
|
||||||
|
function onUncaught(error) {}
|
||||||
|
|
||||||
|
process.on('uncaughtException', common.mustNotCall(onUncaught));
|
||||||
|
|
||||||
|
server.listen(0, common.mustCall(() => {
|
||||||
|
get({
|
||||||
|
port: server.address().port
|
||||||
|
}, (res) => {
|
||||||
|
res.resume();
|
||||||
|
}).on('error', (error) => {
|
||||||
|
assert.strictEqual(error.message, 'socket hang up');
|
||||||
|
assert.strictEqual(error.code, 'ECONNRESET');
|
||||||
|
server.close();
|
||||||
|
});
|
||||||
|
}));
|
Loading…
x
Reference in New Issue
Block a user