-
Notifications
You must be signed in to change notification settings - Fork 44
/
test_blake2s.js
80 lines (69 loc) · 2.39 KB
/
test_blake2s.js
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
const test = require('tape')
const toHex = require('./util').toHex
const util = require('./util')
const b2s = require('./blake2s')
const blake2s = b2s.blake2s
const blake2sHex = b2s.blake2sHex
const blake2sInit = b2s.blake2sInit
const blake2sUpdate = b2s.blake2sUpdate
const blake2sFinal = b2s.blake2sFinal
test('BLAKE2s basic', function (t) {
// From the example computation in the RFC
t.equal(blake2sHex('abc'),
'508c5e8c327c14e2e1a72ba34eeb452f37458b209ed63a294d999b4c86675982')
t.equal(blake2sHex(new Uint8Array([97, 98, 99])),
'508c5e8c327c14e2e1a72ba34eeb452f37458b209ed63a294d999b4c86675982')
t.equal(blake2sHex(Buffer.from([97, 98, 99])),
'508c5e8c327c14e2e1a72ba34eeb452f37458b209ed63a294d999b4c86675982')
t.end()
})
test('BLAKE2s self test', function (t) {
// Grand hash of hash results
const expectedHash = [
0x6A, 0x41, 0x1F, 0x08, 0xCE, 0x25, 0xAD, 0xCD,
0xFB, 0x02, 0xAB, 0xA6, 0x41, 0x45, 0x1C, 0xEC,
0x53, 0xC5, 0x98, 0xB2, 0x4F, 0x4F, 0xC7, 0x87,
0xFB, 0xDC, 0x88, 0x79, 0x7F, 0x4C, 0x1D, 0xFE]
// Parameter sets
const outputLengths = [16, 20, 28, 32]
const inputLengths = [0, 3, 64, 65, 255, 1024]
// 256-bit hash for testing
const ctx = blake2sInit(32)
for (let i = 0; i < 4; i++) {
const outlen = outputLengths[i]
for (let j = 0; j < 6; j++) {
const inlen = inputLengths[j]
const arr = generateInput(inlen, inlen)
let hash = blake2s(arr, null, outlen) // unkeyed hash
blake2sUpdate(ctx, hash) // hash the hash
const key = generateInput(outlen, outlen)
hash = blake2s(arr, key, outlen) // keyed hash
blake2sUpdate(ctx, hash) // hash the hash
}
}
// Compute and compare the hash of hashes
const finalHash = blake2sFinal(ctx)
t.equal(toHex(finalHash), toHex(expectedHash))
t.end()
})
// Returns a Uint8Array of len bytes
function generateInput (len, seed) {
const out = new Uint8Array(len)
const a = new Uint32Array(3)
a[0] = 0xDEAD4BAD * seed // prime
a[1] = 1
for (let i = 0; i < len; i++) { // fill the buf
a[2] = a[0] + a[1]
a[0] = a[1]
a[1] = a[2]
out[i] = (a[2] >>> 24) & 0xFF
}
return out
}
test('BLAKE2s performance', function (t) {
const N = 1 << 22 // number of bytes to hash
const RUNS = 3 // how often to repeat, to allow JIT to finish
console.log('Benchmarking BLAKE2s(' + (N >> 20) + ' MB input)')
util.testSpeed(blake2sHex, N, RUNS)
t.end()
})