61 lines
		
	
	
		
			1.7 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			61 lines
		
	
	
		
			1.7 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
var test = require('tape')
 | 
						|
var crypto = require('../')
 | 
						|
 | 
						|
var randomBytesFunctions = {
 | 
						|
  randomBytes: require('randombytes'),
 | 
						|
  pseudoRandomBytes: crypto.pseudoRandomBytes
 | 
						|
}
 | 
						|
 | 
						|
for (var randomBytesName in randomBytesFunctions) {
 | 
						|
  // Both randomBytes and pseudoRandomBytes should provide the same interface
 | 
						|
  var randomBytes = randomBytesFunctions[randomBytesName]
 | 
						|
 | 
						|
  test('get error message', function (t) {
 | 
						|
    try {
 | 
						|
      var b = randomBytes(10)
 | 
						|
      t.ok(Buffer.isBuffer(b))
 | 
						|
      t.end()
 | 
						|
    } catch (err) {
 | 
						|
      t.ok(/not supported/.test(err.message), '"not supported"  is in error message')
 | 
						|
      t.end()
 | 
						|
    }
 | 
						|
  })
 | 
						|
 | 
						|
  test(randomBytesName, function (t) {
 | 
						|
    t.plan(5)
 | 
						|
    t.equal(randomBytes(10).length, 10)
 | 
						|
    t.ok(Buffer.isBuffer(randomBytes(10)))
 | 
						|
    randomBytes(10, function (ex, bytes) {
 | 
						|
      t.error(ex)
 | 
						|
      t.equal(bytes.length, 10)
 | 
						|
      t.ok(Buffer.isBuffer(bytes))
 | 
						|
      t.end()
 | 
						|
    })
 | 
						|
  })
 | 
						|
 | 
						|
  test(randomBytesName + ' seem random', function (t) {
 | 
						|
    var L = 1000
 | 
						|
    var b = randomBytes(L)
 | 
						|
 | 
						|
    var mean = [].reduce.call(b, function (a, b) { return a + b }, 0) / L
 | 
						|
 | 
						|
    // test that the random numbers are plausably random.
 | 
						|
    // Math.random() will pass this, but this will catch
 | 
						|
    // terrible mistakes such as this blunder:
 | 
						|
    // https://github.com/dominictarr/crypto-browserify/commit/3267955e1df7edd1680e52aeede9a89506ed2464#commitcomment-7916835
 | 
						|
 | 
						|
    // this doesn't check that the bytes are in a random *order*
 | 
						|
    // but it's better than nothing.
 | 
						|
 | 
						|
    var expected = 256 / 2
 | 
						|
    var smean = Math.sqrt(mean)
 | 
						|
 | 
						|
    // console.log doesn't work right on testling, *grumble grumble*
 | 
						|
    console.log(JSON.stringify([expected - smean, mean, expected + smean]))
 | 
						|
    t.ok(mean < expected + smean)
 | 
						|
    t.ok(mean > expected - smean)
 | 
						|
 | 
						|
    t.end()
 | 
						|
  })
 | 
						|
}
 |