aboutsummaryrefslogtreecommitdiffstats
path: root/vnfmarket/src/main/webapp/vnfmarket/node_modules/http-proxy/benchmark/websockets-throughput.js
blob: 6787385ad102f8fd1d8feb9a66dfd2be8a2de3e5 (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
87
88
var crypto = require('crypto'),
    WebSocket = require('ws'),
    async = require('async'),
    httpProxy = require('../');

var SERVER_PORT = 8415,
    PROXY_PORT = 8514;

var testSets = [
  {
    size: 1024 * 1024, // 1 MB
    count: 128         // 128 MB
  },
  {
    size: 1024,        // 1 KB,
    count: 1024        // 1 MB
  },
  {
    size: 128,         // 128 B
    count: 1024 * 8    // 1 MB
  }
];

testSets.forEach(function (set) {
  set.buffer = new Buffer(crypto.randomBytes(set.size));

  set.buffers = [];
  for (var i = 0; i < set.count; i++) {
    set.buffers.push(set.buffer);
  }
});

function runSet(set, callback) {
  function runAgainst(port, callback) {
    function send(sock) {
      sock.send(set.buffers[got++]);
      if (got === set.count) {
        t = new Date() - t;

        server.close();
        proxy.close();

        callback(null, t);
      }
    }

    var server = new WebSocket.Server({ port: SERVER_PORT }),
        proxy = httpProxy.createServer(SERVER_PORT, 'localhost').listen(PROXY_PORT),
        client = new WebSocket('ws://localhost:' + port),
        got = 0,
        t = new Date();

    server.on('connection', function (ws) {
      send(ws);

      ws.on('message', function (msg) {
        send(ws);
      });
    });

    client.on('message', function () {
      send(client);
    });
  }

  async.series({
    server: async.apply(runAgainst, SERVER_PORT),
    proxy: async.apply(runAgainst, PROXY_PORT)
  }, function (err, results) {
    if (err) {
      throw err;
    }

    var mb = (set.size * set.count) / (1024 * 1024);
    console.log(set.size / (1024) + ' KB * ' + set.count + ' (' + mb + ' MB)');

    Object.keys(results).forEach(function (key) {
      var t = results[key],
          throughput = mb / (t / 1000);

      console.log('  ' + key + ' took ' + t + ' ms (' + throughput + ' MB/s)');
    });

    callback();
  });
}

async.forEachLimit(testSets, 1, runSet);