mirror of
https://github.com/nodejs/node.git
synced 2024-11-29 23:16:30 +01:00
8b49cef10b
No need to rely on stdout output now. onExit callbacks should print stack trace from onExit failure
77 lines
1.6 KiB
JavaScript
77 lines
1.6 KiB
JavaScript
include("mjsunit.js");
|
|
|
|
var port = 8222;
|
|
|
|
var request_number = 0;
|
|
var requests_sent = 0;
|
|
var server_response = "";
|
|
var client_got_eof = false;
|
|
|
|
function onLoad() {
|
|
|
|
new node.http.Server(function (req, res) {
|
|
res.id = request_number;
|
|
req.id = request_number++;
|
|
|
|
if (req.id == 0) {
|
|
assertEquals("GET", req.method);
|
|
assertEquals("/hello", req.uri.path);
|
|
}
|
|
|
|
if (req.id == 1) {
|
|
assertEquals("POST", req.method);
|
|
assertEquals("/quit", req.uri.path);
|
|
this.close();
|
|
//puts("server closed");
|
|
}
|
|
|
|
setTimeout(function () {
|
|
res.sendHeader(200, [["Content-Type", "text/plain"]]);
|
|
res.sendBody(req.uri.path);
|
|
res.finish();
|
|
}, 1);
|
|
|
|
}).listen(port);
|
|
|
|
var c = new node.tcp.Connection();
|
|
c.setEncoding("utf8");
|
|
c.onConnect = function () {
|
|
c.send( "GET /hello HTTP/1.1\r\n\r\n" );
|
|
requests_sent += 1;
|
|
};
|
|
|
|
c.onReceive = function (chunk) {
|
|
server_response += chunk;
|
|
|
|
if ( requests_sent == 1) {
|
|
c.send("POST /quit HTTP/1.1\r\n\r\n");
|
|
c.close();
|
|
assertEquals(c.readyState, "readOnly");
|
|
requests_sent += 1;
|
|
}
|
|
};
|
|
|
|
c.onEOF = function () {
|
|
client_got_eof = true;
|
|
};
|
|
|
|
c.onDisconnect = function () {
|
|
assertEquals(c.readyState, "closed");
|
|
};
|
|
|
|
c.connect(port);
|
|
}
|
|
|
|
function onExit () {
|
|
assertEquals(2, request_number);
|
|
assertEquals(2, requests_sent);
|
|
|
|
var hello = new RegExp("/hello");
|
|
assertTrue(hello.exec(server_response) != null);
|
|
|
|
var quit = new RegExp("/quit");
|
|
assertTrue(quit.exec(server_response) != null);
|
|
|
|
assertTrue(client_got_eof);
|
|
}
|