node/test/pummel/test-net-timeout2.js

45 lines
905 B
JavaScript
Raw Normal View History

// socket.write was not resetting the timeout timer. See
// https://github.com/joyent/node/issues/2002
2012-02-20 20:22:12 +08:00
var common = require('../common');
var assert = require('assert');
var net = require('net');
var seconds = 5;
var gotTimeout = false;
var counter = 0;
var server = net.createServer(function(socket) {
socket.setTimeout((seconds / 2) * 1000, function() {
gotTimeout = true;
2012-01-18 02:43:34 +08:00
console.log('timeout!!');
socket.destroy();
process.exit(1);
2012-01-18 02:43:34 +08:00
});
2012-01-18 02:43:34 +08:00
var interval = setInterval(function() {
counter++;
if (counter == seconds) {
clearInterval(interval);
server.close();
socket.destroy();
}
2012-01-18 02:43:34 +08:00
if (socket.writable) {
socket.write(Date.now() + '\n');
}
}, 1000);
});
server.listen(common.PORT, function() {
var s = net.connect(common.PORT);
s.pipe(process.stdout);
});
process.on('exit', function() {
assert.equal(false, gotTimeout);
});