2015-05-19 19:00:06 +08:00
|
|
|
'use strict';
|
2012-06-18 04:14:20 +08:00
|
|
|
var common = require('../common');
|
|
|
|
var assert = require('assert');
|
|
|
|
|
2015-03-04 09:11:21 +08:00
|
|
|
if (!common.hasCrypto) {
|
|
|
|
console.log('1..0 # Skipped: missing crypto');
|
2015-07-07 23:25:55 +08:00
|
|
|
return;
|
2015-03-04 09:11:21 +08:00
|
|
|
}
|
2012-06-18 04:14:20 +08:00
|
|
|
var crypto = require('crypto');
|
|
|
|
|
|
|
|
var p = crypto.createDiffieHellman(256).getPrime();
|
|
|
|
|
|
|
|
for (var i = 0; i < 2000; i++) {
|
|
|
|
var a = crypto.createDiffieHellman(p),
|
|
|
|
b = crypto.createDiffieHellman(p);
|
|
|
|
|
|
|
|
a.generateKeys();
|
|
|
|
b.generateKeys();
|
|
|
|
|
2012-10-24 21:35:58 +08:00
|
|
|
assert.deepEqual(
|
2012-06-18 04:14:20 +08:00
|
|
|
a.computeSecret(b.getPublicKey()),
|
|
|
|
b.computeSecret(a.getPublicKey()),
|
|
|
|
'secrets should be equal!'
|
|
|
|
);
|
|
|
|
}
|