|
|
|
process.mixin(require("./common"));
|
|
|
|
http = require("http");
|
|
|
|
url = require("url");
|
|
|
|
PORT = 8888;
|
|
|
|
|
|
|
|
HOST = "localhost";
|
|
|
|
|
|
|
|
var have_tls;
|
|
|
|
try {
|
|
|
|
var dummy_server = http.createServer();
|
|
|
|
dummy_server.setSecure();
|
|
|
|
have_tls=true;
|
|
|
|
} catch (e) {
|
|
|
|
have_tls=false;
|
|
|
|
puts("Not compiled with TLS support.");
|
|
|
|
process.exit();
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
var responses_sent = 0;
|
|
|
|
var responses_recvd = 0;
|
|
|
|
var body0 = "";
|
|
|
|
var body1 = "";
|
|
|
|
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 http_server=http.createServer(function (req, res) {
|
|
|
|
var verified = req.connection.verifyPeer();
|
|
|
|
var peerDN = req.connection.getPeerCertificate("DNstring");
|
|
|
|
assert.equal(verified, 1);
|
|
|
|
assert.equal(peerDN, "C=UK,ST=Acknack Ltd,L=Rhys Jones,O=node.js,"
|
|
|
|
+ "OU=Test TLS Certificate,CN=localhost");
|
|
|
|
|
|
|
|
if (responses_sent == 0) {
|
|
|
|
assert.equal("GET", req.method);
|
|
|
|
assert.equal("/hello", url.parse(req.url).pathname);
|
|
|
|
|
|
|
|
p(req.headers);
|
|
|
|
assert.equal(true, "accept" in req.headers);
|
|
|
|
assert.equal("*/*", req.headers["accept"]);
|
|
|
|
|
|
|
|
assert.equal(true, "foo" in req.headers);
|
|
|
|
assert.equal("bar", req.headers["foo"]);
|
|
|
|
}
|
|
|
|
|
|
|
|
if (responses_sent == 1) {
|
|
|
|
assert.equal("POST", req.method);
|
|
|
|
assert.equal("/world", url.parse(req.url).pathname);
|
|
|
|
this.close();
|
|
|
|
}
|
|
|
|
|
|
|
|
req.addListener('end', function () {
|
|
|
|
res.writeHeader(200, {"Content-Type": "text/plain"});
|
|
|
|
res.write("The path was " + url.parse(req.url).pathname);
|
|
|
|
res.close();
|
|
|
|
responses_sent += 1;
|
|
|
|
});
|
|
|
|
|
|
|
|
//assert.equal("127.0.0.1", res.connection.remoteAddress);
|
|
|
|
});
|
|
|
|
http_server.setSecure("X509_PEM", caPem, 0, keyPem, certPem);
|
|
|
|
http_server.listen(PORT);
|
|
|
|
|
|
|
|
var client = http.createClient(PORT, HOST);
|
|
|
|
client.setSecure("x509_PEM", caPem, 0, keyPem, certPem);
|
|
|
|
var req = client.request("/hello", {"Accept": "*/*", "Foo": "bar"});
|
|
|
|
req.addListener('response', function (res) {
|
|
|
|
var verified = res.connection.verifyPeer();
|
|
|
|
var peerDN = res.connection.getPeerCertificate("DNstring");
|
|
|
|
assert.equal(verified, 1);
|
|
|
|
assert.equal(peerDN, "C=UK,ST=Acknack Ltd,L=Rhys Jones,O=node.js,"
|
|
|
|
+ "OU=Test TLS Certificate,CN=localhost");
|
|
|
|
assert.equal(200, res.statusCode);
|
|
|
|
responses_recvd += 1;
|
|
|
|
res.setBodyEncoding("ascii");
|
|
|
|
res.addListener('data', function (chunk) { body0 += chunk; });
|
|
|
|
debug("Got /hello response");
|
|
|
|
});
|
|
|
|
req.close();
|
|
|
|
|
|
|
|
setTimeout(function () {
|
|
|
|
req = client.request("POST", "/world");
|
|
|
|
req.addListener('response', function (res) {
|
|
|
|
var verified = res.connection.verifyPeer();
|
|
|
|
var peerDN = res.connection.getPeerCertificate("DNstring");
|
|
|
|
assert.equal(verified, 1);
|
|
|
|
assert.equal(peerDN, "C=UK,ST=Acknack Ltd,L=Rhys Jones,O=node.js,"
|
|
|
|
+ "OU=Test TLS Certificate,CN=localhost");
|
|
|
|
assert.equal(200, res.statusCode);
|
|
|
|
responses_recvd += 1;
|
|
|
|
res.setBodyEncoding("utf8");
|
|
|
|
res.addListener('data', function (chunk) { body1 += chunk; });
|
|
|
|
debug("Got /world response");
|
|
|
|
});
|
|
|
|
req.close();
|
|
|
|
}, 1);
|
|
|
|
|
|
|
|
process.addListener("exit", function () {
|
|
|
|
debug("responses_recvd: " + responses_recvd);
|
|
|
|
assert.equal(2, responses_recvd);
|
|
|
|
|
|
|
|
debug("responses_sent: " + responses_sent);
|
|
|
|
assert.equal(2, responses_sent);
|
|
|
|
|
|
|
|
assert.equal("The path was /hello", body0);
|
|
|
|
assert.equal("The path was /world", body1);
|
|
|
|
});
|
|
|
|
|