2014-04-08 23:39:22 +10:00
|
|
|
var assert = require('assert')
|
2014-05-13 17:55:53 +10:00
|
|
|
var crypto = require('../src/crypto')
|
2014-05-13 16:35:07 +10:00
|
|
|
|
2014-05-18 19:47:39 +10:00
|
|
|
var fixtures = require('./fixtures/crypto.json')
|
2014-04-08 23:39:22 +10:00
|
|
|
|
|
|
|
describe('Crypto', function() {
|
|
|
|
describe('HASH160', function() {
|
2014-05-16 12:36:09 +10:00
|
|
|
it('matches the test vectors', function() {
|
2014-05-13 16:35:07 +10:00
|
|
|
fixtures.before.hex.forEach(function(hex, i) {
|
2014-05-16 12:36:09 +10:00
|
|
|
var data = new Buffer(hex, 'hex')
|
|
|
|
var actual = crypto.hash160(data)
|
2014-05-13 16:35:07 +10:00
|
|
|
var expected = fixtures.after.hash160[i]
|
2014-04-08 23:39:22 +10:00
|
|
|
|
2014-05-16 12:36:09 +10:00
|
|
|
assert.equal(actual.toString('hex'), expected)
|
2014-04-08 23:39:22 +10:00
|
|
|
})
|
|
|
|
})
|
|
|
|
})
|
|
|
|
|
|
|
|
describe('HASH256', function() {
|
2014-05-16 12:36:09 +10:00
|
|
|
it('matches the test vectors', function() {
|
2014-05-13 16:35:07 +10:00
|
|
|
fixtures.before.hex.forEach(function(hex, i) {
|
2014-05-16 12:36:09 +10:00
|
|
|
var data = new Buffer(hex, 'hex')
|
|
|
|
var actual = crypto.hash256(data)
|
2014-05-13 16:35:07 +10:00
|
|
|
var expected = fixtures.after.hash256[i]
|
2014-04-08 23:39:22 +10:00
|
|
|
|
2014-05-16 12:36:09 +10:00
|
|
|
assert.equal(actual.toString('hex'), expected)
|
2014-04-08 23:39:22 +10:00
|
|
|
})
|
|
|
|
})
|
|
|
|
})
|
|
|
|
|
|
|
|
describe('SHA1', function() {
|
2014-05-16 12:36:09 +10:00
|
|
|
it('matches the test vectors', function() {
|
2014-05-13 16:35:07 +10:00
|
|
|
fixtures.before.hex.forEach(function(hex, i) {
|
2014-05-16 12:36:09 +10:00
|
|
|
var data = new Buffer(hex, 'hex')
|
|
|
|
var actual = crypto.sha1(data)
|
2014-05-13 16:35:07 +10:00
|
|
|
var expected = fixtures.after.sha1[i]
|
2014-04-08 23:39:22 +10:00
|
|
|
|
2014-05-16 12:36:09 +10:00
|
|
|
assert.equal(actual.toString('hex'), expected)
|
2014-04-08 23:39:22 +10:00
|
|
|
})
|
|
|
|
})
|
|
|
|
})
|
|
|
|
|
|
|
|
describe('SHA256', function() {
|
2014-05-16 12:36:09 +10:00
|
|
|
it('matches the test vectors', function() {
|
2014-05-13 16:35:07 +10:00
|
|
|
fixtures.before.hex.forEach(function(hex, i) {
|
2014-05-16 12:36:09 +10:00
|
|
|
var data = new Buffer(hex, 'hex')
|
|
|
|
var actual = crypto.sha256(data)
|
2014-05-13 16:35:07 +10:00
|
|
|
var expected = fixtures.after.sha256[i]
|
2014-04-08 23:39:22 +10:00
|
|
|
|
2014-05-16 12:36:09 +10:00
|
|
|
assert.equal(actual.toString('hex'), expected)
|
|
|
|
})
|
|
|
|
})
|
|
|
|
})
|
|
|
|
|
|
|
|
describe('HmacSHA256', function() {
|
|
|
|
it('matches the test vectors', function() {
|
|
|
|
fixtures.before.hex.forEach(function(hex, i) {
|
|
|
|
var data = new Buffer(hex, 'hex')
|
|
|
|
var secret = new Buffer(fixtures.before.secret)
|
|
|
|
|
|
|
|
var actual = crypto.HmacSHA256(data, secret)
|
|
|
|
var expected = fixtures.after.hmacsha256[i]
|
|
|
|
|
|
|
|
assert.equal(actual.toString('hex'), expected)
|
2014-04-08 23:39:22 +10:00
|
|
|
})
|
|
|
|
})
|
|
|
|
})
|
2014-05-10 09:55:55 +10:00
|
|
|
|
2014-05-16 12:36:09 +10:00
|
|
|
describe('HmacSHA512', function() {
|
|
|
|
it('matches the test vectors', function() {
|
2014-05-13 16:35:07 +10:00
|
|
|
fixtures.before.hex.forEach(function(hex, i) {
|
2014-05-10 09:55:55 +10:00
|
|
|
var data = new Buffer(hex, 'hex')
|
2014-05-16 12:36:09 +10:00
|
|
|
var secret = new Buffer(fixtures.before.secret)
|
2014-05-10 09:55:55 +10:00
|
|
|
|
|
|
|
var actual = crypto.HmacSHA512(data, secret)
|
2014-05-16 12:36:09 +10:00
|
|
|
var expected = fixtures.after.hmacsha512[i]
|
2014-05-10 09:55:55 +10:00
|
|
|
|
|
|
|
assert.equal(actual.toString('hex'), expected)
|
|
|
|
})
|
|
|
|
})
|
|
|
|
})
|
2014-04-08 23:39:22 +10:00
|
|
|
})
|