0
0
mirror of https://github.com/nodejs/node.git synced 2024-11-29 23:16:30 +01:00
nodejs/test/mjsunit/disabled/test-http-stress.js
Ryan 316e2833f0 Use flat object instead of array-of-arrays for HTTP headers.
E.G. { "Content-Length": 10, "Content-Type": "text/html" } instead of
[["Content-Length", 10], ["Content-Type", "text/html"]].
The main reason for this change is object-creation efficiency.

This still needs testing and some further changes (like when receiving
multiple header lines with the same field-name, they are concatenated with a
comma but some headers ("Content-Length") should not be concatenated ; the
new header line should replace the old value).

Various thoughts on this subject:
http://groups.google.com/group/nodejs/browse_thread/thread/9a67bb32706d9efc#
http://four.livejournal.com/979640.html
http://mail.gnome.org/archives/libsoup-list/2009-March/msg00015.html
2009-08-23 12:32:49 +02:00

42 lines
999 B
JavaScript

include('../mjsunit.js');
var PORT = 8003;
var request_count = 1000;
var response_body = '{"ok": true}';
var server = node.http.createServer(function(req, res) {
res.sendHeader(200, {'Content-Type': 'text/javascript'});
res.sendBody(response_body);
res.finish();
});
server.listen(PORT, 4024);
var requests_ok = 0;
var requests_complete = 0;
function onLoad () {
for (var i = 0; i < request_count; i++) {
node.http.cat('http://localhost:'+PORT+'/', 'utf8')
.addCallback(function (content) {
assertEquals(response_body, content)
print(".");
requests_ok++;
requests_complete++;
if (requests_ok == request_count) {
puts("\nrequests ok: " + requests_ok);
server.close();
}
})
.addErrback(function() {
print("-");
requests_complete++;
//node.debug("error " + i);
});
}
}
function onExit () {
assertEquals(request_count, requests_complete);
assertEquals(request_count, requests_ok);
}