bitcore/test/crypto/random.js

37 lines
964 B
JavaScript
Raw Normal View History

2014-11-20 13:46:43 -08:00
'use strict';
var bitcore = require('../..');
var Random = bitcore.crypto.Random;
2014-08-07 16:51:24 -07:00
2014-08-14 08:32:47 -07:00
describe('Random', function() {
2014-08-07 16:51:24 -07:00
2014-08-24 20:37:16 -07:00
describe('@getRandomBuffer', function() {
2014-08-07 16:51:24 -07:00
it('should return a buffer', function() {
var bytes = Random.getRandomBuffer(8);
bytes.length.should.equal(8);
Buffer.isBuffer(bytes).should.equal(true);
});
it('should not equate two 256 bit random buffers', function() {
var bytes1 = Random.getRandomBuffer(32);
var bytes2 = Random.getRandomBuffer(32);
bytes1.toString('hex').should.not.equal(bytes2.toString('hex'));
});
it('should generate 100 8 byte buffers in a row that are not equal', function() {
var hexs = [];
2014-12-19 14:32:26 -08:00
for (var i = 0; i < 100; i++) {
hexs[i] = Random.getRandomBuffer(8).toString('hex');
2014-12-19 14:32:26 -08:00
}
for (i = 0; i < 100; i++) {
for (var j = i + 1; j < 100; j++) {
hexs[i].should.not.equal(hexs[j]);
2014-12-19 14:32:26 -08:00
}
}
2014-08-07 16:51:24 -07:00
});
});
});