Skip to content

Commit

Permalink
test: check error type in net.Server.listen() callback and avoid setT…
Browse files Browse the repository at this point in the history
…imeout() in test
  • Loading branch information
Trott committed May 30, 2015
1 parent 5759722 commit ca60bd7
Showing 1 changed file with 17 additions and 15 deletions.
32 changes: 17 additions & 15 deletions test/parallel/test-net-server-try-ports.js
Original file line number Diff line number Diff line change
Expand Up @@ -9,6 +9,7 @@ var connections = 0;

var server1listening = false;
var server2listening = false;
var server2eaddrinuse = false;

var server1 = net.Server(function(socket) {
connections++;
Expand All @@ -21,36 +22,37 @@ var server2 = net.Server(function(socket) {
});

var server2errors = 0;
server2.on('error', function() {

server2.on('error', function(e) {
server2errors++;
console.error('server2 error');

if (e.code == 'EADDRINUSE') {
server2eaddrinuse = true;
}

server2.listen(common.PORT + 1, function() {
console.error('server2 listening');
server2listening = true;

server1.close();
server2.close();
});
});


server1.listen(common.PORT, function() {
console.error('server1 listening');
server1listening = true;

// This should make server2 emit EADDRINUSE
server2.listen(common.PORT);

// Wait a bit, now try again.
// TODO, the listen callback should report if there was an error.
// Then we could avoid this very unlikely but potential race condition
// here.
setTimeout(function() {
server2.listen(common.PORT + 1, function() {
console.error('server2 listening');
server2listening = true;

server1.close();
server2.close();
});
}, 100);
});


process.on('exit', function() {
assert.equal(1, server2errors);
assert.ok(server2eaddrinuse);
assert.ok(server2listening);
assert.ok(server1listening);
});

0 comments on commit ca60bd7

Please sign in to comment.