Skip to content

Commit

Permalink
test: refactor http-end-throw-socket-handling
Browse files Browse the repository at this point in the history
Remove timer to avoid the test timing out occasionally.

PR-URL: #5676
Reviewed-By: James M Snell <[email protected]>
Reviewed-By: Claudio Rodriguez <[email protected]>
  • Loading branch information
santigimeno authored and Myles Borins committed May 18, 2016
1 parent 918d33a commit 3d4d577
Showing 1 changed file with 16 additions and 24 deletions.
40 changes: 16 additions & 24 deletions test/parallel/test-http-end-throw-socket-handling.js
Original file line number Diff line number Diff line change
@@ -1,47 +1,39 @@
'use strict';
var common = require('../common');
var assert = require('assert');
const common = require('../common');
const assert = require('assert');

// Make sure that throwing in 'end' handler doesn't lock
// up the socket forever.
//
// This is NOT a good way to handle errors in general, but all
// the same, we should not be so brittle and easily broken.

var http = require('http');
const http = require('http');

var n = 0;
var server = http.createServer(function(req, res) {
let n = 0;
const server = http.createServer((req, res) => {
if (++n === 10) server.close();
res.end('ok');
});

server.listen(common.PORT, function() {
for (var i = 0; i < 10; i++) {
var options = { port: common.PORT };

var req = http.request(options, function(res) {
server.listen(common.PORT, common.mustCall(() => {
for (let i = 0; i < 10; i++) {
const options = { port: common.PORT };
const req = http.request(options, (res) => {
res.resume();
res.on('end', function() {
res.on('end', common.mustCall(() => {
throw new Error('gleep glorp');
});
}));
});
req.end();
}
});
}));

setTimeout(function() {
process.removeListener('uncaughtException', catcher);
throw new Error('Taking too long!');
}, common.platformTimeout(1000)).unref();

process.on('uncaughtException', catcher);
var errors = 0;
function catcher() {
let errors = 0;
process.on('uncaughtException', () => {
errors++;
}
});

process.on('exit', function() {
process.on('exit', () => {
assert.equal(errors, 10);
console.log('ok');
});

0 comments on commit 3d4d577

Please sign in to comment.