summaryrefslogtreecommitdiff
path: root/test/parallel/test-net-socket-timeout-unref.js
diff options
context:
space:
mode:
authorRich Trott <rtrott@gmail.com>2016-03-28 17:07:22 -0700
committerRich Trott <rtrott@gmail.com>2016-04-04 09:56:25 -0700
commitc60faf6ba85b6365145fd8215ed572efa9f25fdc (patch)
treee5278ebc41c50d4fd80b1c819754410fb2fd1626 /test/parallel/test-net-socket-timeout-unref.js
parent539cede42627df4726041558b2c0a377ff55bffd (diff)
downloadandroid-node-v8-c60faf6ba85b6365145fd8215ed572efa9f25fdc.tar.gz
android-node-v8-c60faf6ba85b6365145fd8215ed572efa9f25fdc.tar.bz2
android-node-v8-c60faf6ba85b6365145fd8215ed572efa9f25fdc.zip
test: fix flaky test-net-socket-timeout-unref
Throw immediately on socket timeout rather than checking boolean in exit handler. PR-URL: https://github.com/nodejs/node/pull/6003 Fixes: https://github.com/nodejs/node/issues/5128 Reviewed-By: Myles Borins <myles.borins@gmail.com>
Diffstat (limited to 'test/parallel/test-net-socket-timeout-unref.js')
-rw-r--r--test/parallel/test-net-socket-timeout-unref.js36
1 files changed, 16 insertions, 20 deletions
diff --git a/test/parallel/test-net-socket-timeout-unref.js b/test/parallel/test-net-socket-timeout-unref.js
index b7ed0ec344..bbc2dffcc1 100644
--- a/test/parallel/test-net-socket-timeout-unref.js
+++ b/test/parallel/test-net-socket-timeout-unref.js
@@ -1,39 +1,35 @@
'use strict';
-var common = require('../common');
-var assert = require('assert');
-var net = require('net');
-var server = net.createServer(function(c) {
+// Test that unref'ed sockets with timeouts do not prevent exit.
+
+const common = require('../common');
+const net = require('net');
+
+const server = net.createServer(function(c) {
c.write('hello');
c.unref();
});
server.listen(common.PORT);
server.unref();
-var timedout = false;
var connections = 0;
-var sockets = [];
-var delays = [8, 5, 3, 6, 2, 4];
+const sockets = [];
+const delays = [8, 5, 3, 6, 2, 4];
delays.forEach(function(T) {
- var socket = net.createConnection(common.PORT, 'localhost');
- socket.on('connect', function() {
+ const socket = net.createConnection(common.PORT, 'localhost');
+ socket.on('connect', common.mustCall(function() {
if (++connections === delays.length) {
sockets.forEach(function(s) {
- s[0].setTimeout(s[1] * 1000, function() {
- timedout = true;
- s[0].destroy();
+ s.socket.setTimeout(s.timeout, function() {
+ s.socket.destroy();
+ throw new Error('socket timed out unexpectedly');
});
- s[0].unref();
+ s.socket.unref();
});
}
- });
-
- sockets.push([socket, T]);
-});
+ }));
-process.on('exit', function() {
- assert.strictEqual(timedout, false,
- 'Socket timeout should not hold loop open');
+ sockets.push({socket: socket, timeout: T * 1000});
});