0
0
mirror of https://github.com/nodejs/node.git synced 2024-11-30 15:30:56 +01:00
nodejs/test/mjsunit/test-tcp-reconnect.js
Ryan 041af82b8c Bugfix: Sockets not properly reattached if reconnected during disconnect event.
The problem was that Connection::on_close was calling Detach() directly
after executing the "disconnect" event. Since we had a boolean attach count,
this was leaving sockets detached even if they had reattached in during the
event.

 * Added many asserts in http.cc and net.cc to ensure that sockets are
   connected when they should be.

 * Changed ObjectWrap to use a reference count instead of boolean attached_
   value.

 * Fixed similar bug in Timer.
2009-07-13 16:38:55 +02:00

55 lines
1.2 KiB
JavaScript

include("mjsunit.js");
var N = 50;
var port = 8921;
var disconnect_count = 0;
var client_recv_count = 0;
function onLoad () {
var server = node.tcp.createServer(function (socket) {
socket.addListener("connect", function () {
socket.send("hello\r\n");
});
socket.addListener("eof", function () {
socket.close();
});
socket.addListener("disconnect", function (had_error) {
//puts("server had_error: " + JSON.stringify(had_error));
assertFalse(had_error);
});
});
server.listen(port);
var client = node.tcp.createConnection(port);
client.setEncoding("UTF8");
client.addListener("connect", function () {
puts("client connected.");
});
client.addListener("receive", function (chunk) {
client_recv_count += 1;
puts("client_recv_count " + client_recv_count);
assertEquals("hello\r\n", chunk);
client.fullClose();
});
client.addListener("disconnect", function (had_error) {
puts("disconnect");
assertFalse(had_error);
if (disconnect_count++ < N)
client.connect(port); // reconnect
else
server.close();
});
}
function onExit () {
assertEquals(N+1, disconnect_count);
assertEquals(N+1, client_recv_count);
}