mirror of
https://github.com/nodejs/node.git
synced 2025-05-05 13:43:55 +00:00

Fixed an intermittent issue on AIX where the 600ms timeout was reached before the 'connection' event was fired. This resulted in a failure as serverConnection would be undefined and the assert.equal would throw an error. Changed the flow of the test so that the timeout is only set after a connection has been made. PR-URL: https://github.com/nodejs/node/pull/3646 Reviewed-By: Michael Dawson <michael_dawson@ca.ibm.com> Reviewed-By: James M Snell <jasnell@gmail.com>
35 lines
1.0 KiB
JavaScript
35 lines
1.0 KiB
JavaScript
'use strict';
|
|
var common = require('../common');
|
|
var assert = require('assert');
|
|
var net = require('net');
|
|
|
|
var serverConnection;
|
|
var clientConnection;
|
|
var echoServer = net.createServer(function(connection) {
|
|
serverConnection = connection;
|
|
setTimeout(function() {
|
|
// make sure both connections are still open
|
|
assert.equal(serverConnection.readyState, 'open');
|
|
assert.equal(clientConnection.readyState, 'open');
|
|
serverConnection.end();
|
|
clientConnection.end();
|
|
echoServer.close();
|
|
}, 600);
|
|
connection.setTimeout(0);
|
|
assert.equal(typeof connection.setKeepAlive, 'function');
|
|
connection.on('end', function() {
|
|
connection.end();
|
|
});
|
|
});
|
|
echoServer.listen(common.PORT);
|
|
|
|
echoServer.on('listening', function() {
|
|
clientConnection = new net.Socket();
|
|
// send a keepalive packet after 1000 ms
|
|
// and make sure it persists
|
|
var s = clientConnection.setKeepAlive(true, 400);
|
|
assert.ok(s instanceof net.Socket);
|
|
clientConnection.connect(common.PORT);
|
|
clientConnection.setTimeout(0);
|
|
});
|