This helps to prevent issues where a failed test can keep a bound socket open long enough to cause other tests to fail with EADDRINUSE because the same port number is used. PR-URL: https://github.com/nodejs/node/pull/7045 Reviewed-By: Ben Noordhuis <info@bnoordhuis.nl> Reviewed-By: Matteo Collina <matteo.collina@gmail.com> Reviewed-By: Rod Vagg <rod@vagg.org>
50 lines
1.2 KiB
JavaScript
50 lines
1.2 KiB
JavaScript
'use strict';
|
|
var common = require('../common');
|
|
var net = require('net');
|
|
var assert = require('assert');
|
|
|
|
// Verify that invalid delays throw
|
|
var noop = function() {};
|
|
var s = new net.Socket();
|
|
var nonNumericDelays = ['100', true, false, undefined, null, '', {}, noop, []];
|
|
var badRangeDelays = [-0.001, -1, -Infinity, Infinity, NaN];
|
|
var validDelays = [0, 0.001, 1, 1e6];
|
|
|
|
for (let i = 0; i < nonNumericDelays.length; i++) {
|
|
assert.throws(function() {
|
|
s.setTimeout(nonNumericDelays[i], noop);
|
|
}, TypeError);
|
|
}
|
|
|
|
for (let i = 0; i < badRangeDelays.length; i++) {
|
|
assert.throws(function() {
|
|
s.setTimeout(badRangeDelays[i], noop);
|
|
}, RangeError);
|
|
}
|
|
|
|
for (let i = 0; i < validDelays.length; i++) {
|
|
assert.doesNotThrow(function() {
|
|
s.setTimeout(validDelays[i], noop);
|
|
});
|
|
}
|
|
|
|
var timedout = false;
|
|
|
|
var server = net.Server();
|
|
server.listen(0, function() {
|
|
var socket = net.createConnection(this.address().port);
|
|
socket.setTimeout(100, function() {
|
|
timedout = true;
|
|
socket.destroy();
|
|
server.close();
|
|
clearTimeout(timer);
|
|
});
|
|
var timer = setTimeout(function() {
|
|
process.exit(1);
|
|
}, common.platformTimeout(200));
|
|
});
|
|
|
|
process.on('exit', function() {
|
|
assert.ok(timedout);
|
|
});
|