node/test/simple/test-http-tls.js

136 lines
3.7 KiB
JavaScript

require("../common");
net = require("net");
http = require("http");
url = require("url");
qs = require("querystring");
var fs = require('fs');
var sys = require('sys');
var have_openssl;
try {
var crypto = require('crypto');
var dummy_server = http.createServer(function(){});
dummy_server.setSecure();
have_openssl=true;
} catch (e) {
have_openssl=false;
puts("Not compiled with OPENSSL support.");
process.exit();
}
var request_number = 0;
var requests_sent = 0;
var server_response = "";
var client_got_eof = false;
var caPem = fs.readFileSync(fixturesDir+"/test_ca.pem");
var certPem = fs.readFileSync(fixturesDir+"/test_cert.pem");
var keyPem = fs.readFileSync(fixturesDir+"/test_key.pem");
var credentials = crypto.createCredentials({key:keyPem, cert:certPem, ca:caPem});
var https_server = http.createServer(function (req, res) {
res.id = request_number;
req.id = request_number++;
var verified = c.verifyPeer();
var peerDN = JSON.stringify(c.getPeerCertificate());
assert.equal(verified, true);
assert.equal(peerDN, '{"subject":"/C=UK/ST=Acknack Ltd/L=Rhys Jones'
+ '/O=node.js/OU=Test TLS Certificate/CN=localhost",'
+ '"issuer":"/C=UK/ST=Acknack Ltd/L=Rhys Jones/O=node.js'
+ '/OU=Test TLS Certificate/CN=localhost","valid_from":'
+ '"Nov 11 09:52:22 2009 GMT","valid_to":'
+ '"Nov 6 09:52:22 2029 GMT"}');
if (req.id == 0) {
assert.equal("GET", req.method);
assert.equal("/hello", url.parse(req.url).pathname);
assert.equal("world", qs.parse(url.parse(req.url).query).hello);
assert.equal("b==ar", qs.parse(url.parse(req.url).query).foo);
}
if (req.id == 1) {
assert.equal("POST", req.method);
assert.equal("/quit", url.parse(req.url).pathname);
}
if (req.id == 2) {
assert.equal("foo", req.headers['x-x']);
}
if (req.id == 3) {
assert.equal("bar", req.headers['x-x']);
this.close();
//puts("server closed");
}
setTimeout(function () {
res.writeHead(200, {"Content-Type": "text/plain"});
res.write(url.parse(req.url).pathname);
res.end();
}, 1);
});
https_server.setSecure(credentials);
https_server.listen(PORT);
var c = net.createConnection(PORT);
c.setEncoding("utf8");
c.addListener("connect", function () {
c.setSecure(credentials);
});
c.addListener("secure", function () {
var verified = c.verifyPeer();
var peerDN = JSON.stringify(c.getPeerCertificate());
//assert.equal(verified, 1);
assert.equal(peerDN, '{"subject":"/C=UK/ST=Acknack Ltd/L=Rhys Jones'
+ '/O=node.js/OU=Test TLS Certificate/CN=localhost",'
+ '"issuer":"/C=UK/ST=Acknack Ltd/L=Rhys Jones/O=node.js'
+ '/OU=Test TLS Certificate/CN=localhost","valid_from":'
+ '"Nov 11 09:52:22 2009 GMT","valid_to":'
+ '"Nov 6 09:52:22 2029 GMT"}');
c.write( "GET /hello?hello=world&foo=b==ar HTTP/1.1\r\n\r\n" );
requests_sent += 1;
});
c.addListener("data", function (chunk) {
server_response += chunk;
if (requests_sent == 1) {
c.write("POST /quit HTTP/1.1\r\n\r\n");
requests_sent += 1;
}
if (requests_sent == 2) {
c.write("GET / HTTP/1.1\r\nX-X: foo\r\n\r\n"
+"GET / HTTP/1.1\r\nX-X: bar\r\n\r\n");
c.end();
assert.equal(c.readyState, "readOnly");
requests_sent += 2;
}
});
c.addListener("end", function () {
client_got_eof = true;
});
c.addListener("close", function () {
assert.equal(c.readyState, "closed");
});
process.addListener("exit", function () {
assert.equal(4, request_number);
assert.equal(4, requests_sent);
var hello = new RegExp("/hello");
assert.equal(true, hello.exec(server_response) != null);
var quit = new RegExp("/quit");
assert.equal(true, quit.exec(server_response) != null);
assert.equal(true, client_got_eof);
});