summaryrefslogtreecommitdiff
path: root/benchmark/tls-connect.js
blob: 512adca142108bf5824ae10c8c274330cc83e6b6 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86

var assert = require('assert'),
    fs = require('fs'),
    path = require('path'),
    tls = require('tls');


var target_connections = 10000,
    concurrency = 10;

for (var i = 2; i < process.argv.length; i++) {
  switch (process.argv[i]) {
    case '-c':
      concurrency = ~~process.argv[++i];
      break;

    case '-n':
      target_connections = ~~process.argv[++i];
      break;

    default:
      throw new Error('Invalid flag: ' + process.argv[i]);
  }
}


var cert_dir = path.resolve(__dirname, '../test/fixtures'),
    options = { key: fs.readFileSync(cert_dir + '/test_key.pem'),
                cert: fs.readFileSync(cert_dir + '/test_cert.pem'),
                ca: [ fs.readFileSync(cert_dir + '/test_ca.pem') ] };

var server = tls.createServer(options, onConnection);
server.listen(8000);


var initiated_connections = 0,
    server_connections = 0,
    client_connections = 0,
    start = Date.now();

for (var i = 0; i < concurrency; i++)
  makeConnection();


process.on('exit', onExit);


function makeConnection() {
  if (initiated_connections >= target_connections)
    return;

  initiated_connections++;

  var conn = tls.connect(8000, function() {
    client_connections++;

    if (client_connections % 100 === 0)
      console.log(client_connections + ' of ' + target_connections +
                  ' connections made');

    conn.end();
    makeConnection();
  });
}


function onConnection(conn) {
  server_connections++;

  if (server_connections === target_connections)
    server.close();
}


function onExit() {
  var end = Date.now(),
      s = (end - start) / 1000,
      persec = Math.round(target_connections / s);

  assert.equal(initiated_connections, target_connections);
  assert.equal(client_connections, target_connections);
  assert.equal(server_connections, target_connections);

  console.log('%d connections in %d s', target_connections, s);
  console.log('%d connections per second', persec);
}