mirror of
https://github.com/nodejs/node.git
synced 2024-12-01 16:10:02 +01:00
8b49cef10b
No need to rely on stdout output now. onExit callbacks should print stack trace from onExit failure
52 lines
1.0 KiB
JavaScript
52 lines
1.0 KiB
JavaScript
include("mjsunit.js");
|
|
var N = 50;
|
|
var port = 8921;
|
|
|
|
var disconnect_count = 0;
|
|
var client_recv_count = 0;
|
|
|
|
function onLoad () {
|
|
|
|
var server = new node.tcp.Server(function (socket) {
|
|
socket.onConnect = function () {
|
|
socket.send("hello\r\n");
|
|
};
|
|
|
|
socket.onEOF = function () {
|
|
socket.close();
|
|
};
|
|
|
|
socket.onDisconnect = function (had_error) {
|
|
//puts("server had_error: " + JSON.stringify(had_error));
|
|
assertFalse(had_error);
|
|
};
|
|
});
|
|
server.listen(port);
|
|
var client = new node.tcp.Connection();
|
|
|
|
client.setEncoding("UTF8");
|
|
client.onConnect = function () {
|
|
};
|
|
|
|
client.onReceive = function (chunk) {
|
|
client_recv_count += 1;
|
|
assertEquals("hello\r\n", chunk);
|
|
client.fullClose();
|
|
};
|
|
|
|
client.onDisconnect = function (had_error) {
|
|
assertFalse(had_error);
|
|
if (disconnect_count++ < N)
|
|
client.connect(port); // reconnect
|
|
else
|
|
server.close();
|
|
};
|
|
|
|
client.connect(port);
|
|
}
|
|
|
|
function onExit () {
|
|
assertEquals(N+1, disconnect_count);
|
|
assertEquals(N+1, client_recv_count);
|
|
}
|