2013-04-30 21:50:21 +00:00
|
|
|
// throughput benchmark
|
|
|
|
// creates a single hasher, then pushes a bunch of data through it
|
2016-02-20 01:03:16 +00:00
|
|
|
'use strict';
|
2017-09-14 01:48:53 +00:00
|
|
|
const common = require('../common.js');
|
|
|
|
const crypto = require('crypto');
|
2013-04-30 21:50:21 +00:00
|
|
|
|
2017-09-14 01:48:53 +00:00
|
|
|
const bench = common.createBenchmark(main, {
|
2013-04-30 21:50:21 +00:00
|
|
|
writes: [500],
|
2015-04-02 12:33:24 +00:00
|
|
|
algo: ['sha1', 'sha256', 'sha512'],
|
2013-04-30 21:50:21 +00:00
|
|
|
type: ['asc', 'utf', 'buf'],
|
|
|
|
len: [2, 1024, 102400, 1024 * 1024],
|
|
|
|
api: ['legacy', 'stream']
|
|
|
|
});
|
|
|
|
|
2018-01-23 12:17:56 +00:00
|
|
|
function main({ api, type, len, algo, writes }) {
|
2017-06-08 15:30:57 +00:00
|
|
|
if (api === 'stream' && /^v0\.[0-8]\./.test(process.version)) {
|
2013-04-30 21:50:21 +00:00
|
|
|
console.error('Crypto streams not available until v0.10');
|
2019-01-21 00:22:27 +00:00
|
|
|
// Use the legacy, just so that we can compare them.
|
2013-04-30 21:50:21 +00:00
|
|
|
api = 'legacy';
|
|
|
|
}
|
|
|
|
|
|
|
|
var message;
|
|
|
|
var encoding;
|
2018-01-23 12:17:56 +00:00
|
|
|
switch (type) {
|
2013-04-30 21:50:21 +00:00
|
|
|
case 'asc':
|
2018-01-23 12:17:56 +00:00
|
|
|
message = 'a'.repeat(len);
|
2013-04-30 21:50:21 +00:00
|
|
|
encoding = 'ascii';
|
|
|
|
break;
|
|
|
|
case 'utf':
|
2018-01-23 12:17:56 +00:00
|
|
|
message = 'ü'.repeat(len / 2);
|
2013-04-30 21:50:21 +00:00
|
|
|
encoding = 'utf8';
|
|
|
|
break;
|
|
|
|
case 'buf':
|
2018-01-23 12:17:56 +00:00
|
|
|
message = Buffer.alloc(len, 'b');
|
2013-04-30 21:50:21 +00:00
|
|
|
break;
|
|
|
|
default:
|
2018-01-23 12:17:56 +00:00
|
|
|
throw new Error(`unknown message type: ${type}`);
|
2013-04-30 21:50:21 +00:00
|
|
|
}
|
|
|
|
|
2017-09-14 01:48:53 +00:00
|
|
|
const fn = api === 'stream' ? streamWrite : legacyWrite;
|
2013-04-30 21:50:21 +00:00
|
|
|
|
|
|
|
bench.start();
|
2018-01-23 12:17:56 +00:00
|
|
|
fn(algo, message, encoding, writes, len);
|
2013-04-30 21:50:21 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
function legacyWrite(algo, message, encoding, writes, len) {
|
2017-09-14 01:48:53 +00:00
|
|
|
const written = writes * len;
|
|
|
|
const bits = written * 8;
|
|
|
|
const gbits = bits / (1024 * 1024 * 1024);
|
|
|
|
const h = crypto.createHash(algo);
|
2013-04-30 21:50:21 +00:00
|
|
|
|
|
|
|
while (writes-- > 0)
|
|
|
|
h.update(message, encoding);
|
|
|
|
|
|
|
|
h.digest();
|
|
|
|
|
|
|
|
bench.end(gbits);
|
|
|
|
}
|
|
|
|
|
|
|
|
function streamWrite(algo, message, encoding, writes, len) {
|
2017-09-14 01:48:53 +00:00
|
|
|
const written = writes * len;
|
|
|
|
const bits = written * 8;
|
|
|
|
const gbits = bits / (1024 * 1024 * 1024);
|
|
|
|
const h = crypto.createHash(algo);
|
2013-04-30 21:50:21 +00:00
|
|
|
|
|
|
|
while (writes-- > 0)
|
|
|
|
h.write(message, encoding);
|
|
|
|
|
|
|
|
h.end();
|
|
|
|
h.read();
|
|
|
|
|
|
|
|
bench.end(gbits);
|
|
|
|
}
|