Resumes reading after a call to `pause()`.
-#### socket.setTimeout(timeout)
+#### socket.setTimeout(timeout, [callback])
Sets the socket to timeout after `timeout` milliseconds of inactivity on
the socket. By default `net.Socket` do not have a timeout.
If `timeout` is 0, then the existing idle timeout is disabled.
+The optional `callback` parameter will be added as a one time listener for the `'timeout'` event.
+
#### socket.setNoDelay(noDelay=true)
Disables the Nagle algorithm. By default TCP connections use the Nagle
}
};
-Socket.prototype.setTimeout = function(msecs) {
+Socket.prototype.setTimeout = function(msecs, callback) {
if (msecs > 0) {
timers.enroll(this, msecs);
if (this.fd) { timers.active(this); }
+ if (callback) {
+ this.once('timeout', callback);
+ }
} else if (msecs === 0) {
timers.unenroll(this);
}
--- /dev/null
+var common = require('../common');
+var net = require('net');
+var assert = require('assert');
+
+var timedout = false;
+
+var server = net.Server();
+server.listen(common.PORT, function() {
+ var socket = net.createConnection(common.PORT);
+ socket.setTimeout(100, function() {
+ timedout = true;
+ socket.destroy();
+ server.close();
+ clearTimeout(timer);
+ });
+ var timer = setTimeout(function() {
+ process.exit(1);
+ }, 200);
+});
+
+process.on('exit', function() {
+ assert.ok(timedout);
+});