1 var common = require('../common');
3 if (!common.opensslCli) {
4 console.error('Skipping because node compiled without OpenSSL CLI.');
8 var assert = require('assert');
10 var join = require('path').join;
11 var net = require('net');
12 var fs = require('fs');
13 var tls = require('tls');
14 var spawn = require('child_process').spawn;
17 var key = fs.readFileSync(join(common.fixturesDir, 'agent.key')).toString();
18 var cert = fs.readFileSync(join(common.fixturesDir, 'agent.crt')).toString();
21 console.error('***server*** ' + a);
24 var server = net.createServer(function(socket) {
26 log('connection fd=' + socket.fd);
27 var sslcontext = tls.createSecureContext({key: key, cert: cert});
28 sslcontext.context.setCiphers('RC4-SHA:AES128-SHA:AES256-SHA');
30 var pair = tls.createSecurePair(sslcontext, true);
32 assert.ok(pair.encrypted.writable);
33 assert.ok(pair.cleartext.writable);
35 pair.encrypted.pipe(socket);
36 socket.pipe(pair.encrypted);
38 log('i set it secure');
40 pair.on('secure', function() {
41 log('connected+secure!');
42 pair.cleartext.write('hello\r\n');
43 log(pair.cleartext.getPeerCertificate());
44 log(pair.cleartext.getCipher());
47 pair.cleartext.on('data', function(data) {
48 log('read bytes ' + data.length);
49 pair.cleartext.write(data);
52 socket.on('end', function() {
56 pair.cleartext.on('error', function(err) {
63 pair.encrypted.on('error', function(err) {
64 log('encrypted error: ');
70 socket.on('error', function(err) {
71 log('socket error: ');
77 socket.on('close', function(err) {
81 pair.on('error', function(err) {
82 log('secure error: ');
90 var sentWorld = false;
92 var opensslExitCode = -1;
94 server.listen(common.PORT, function() {
95 // To test use: openssl s_client -connect localhost:8000
96 var client = spawn(common.opensslCli, ['s_client', '-connect', '127.0.0.1:' +
102 client.stdout.setEncoding('utf8');
103 client.stdout.on('data', function(d) {
106 if (!gotHello && /hello/.test(out)) {
108 client.stdin.write('world\r\n');
112 if (!gotWorld && /world/.test(out)) {
118 client.stdout.pipe(process.stdout, { end: false });
120 client.on('exit', function(code) {
121 opensslExitCode = code;
126 process.on('exit', function() {
127 assert.equal(1, connections);
129 assert.ok(sentWorld);
131 assert.equal(0, opensslExitCode);