'use strict'; var assert = require('assert'); var siphash = require('../lib/crypto/siphash'); var U64 = siphash.U64; describe('SipHash', function() { it('should perform siphash with no data', function() { var k0 = U64(0x07060504, 0x03020100).toRaw(); var k1 = U64(0x0f0e0d0c, 0x0b0a0908).toRaw(); var key = Buffer.concat([k0, k1]); assert.equal(siphash(new Buffer(0), key).toString('hex'), '310e0edd47db6f72'); }); it('should perform siphash with data', function() { var k0 = U64(0x07060504, 0x03020100).toRaw(); var k1 = U64(0x0f0e0d0c, 0x0b0a0908).toRaw(); var data = U64(0x07060504, 0x03020100).toRaw(); var key = Buffer.concat([k0, k1]); assert.equal(siphash(data, key).toString('hex'), '6224939a79f5f593'); }); it('should perform siphash with uint256', function() { var k0 = U64(0x07060504, 0x03020100).toRaw(); var k1 = U64(0x0f0e0d0c, 0x0b0a0908).toRaw(); var hash = new Buffer('000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f', 'hex'); var key = Buffer.concat([k0, k1]); assert.equal(siphash(hash, key).toString('hex'), 'ce7cf2722f512771'); }); });