1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162 |
- 'use strict';
- var mods = [
- 'secp256k1',
- 'secp224r1',
- 'prime256v1',
- 'prime192v1'
- ];
- var test = require('tape');
- var createECDH1 = require('../').createECDH;
- var createECDH2 = require('create-ecdh/browser');
- mods.forEach(function (mod) {
- test('createECDH: ' + mod + ' uncompressed', function (t) {
- t.plan(2);
- var dh1 = createECDH1(mod);
- dh1.generateKeys();
- var dh2 = createECDH2(mod);
- dh2.generateKeys();
- var pubk1 = dh1.getPublicKey();
- var pubk2 = dh2.getPublicKey();
- t.notEquals(pubk1.toString('hex'), pubk2.toString('hex'), 'diff public keys');
- var pub1 = dh1.computeSecret(pubk2).toString('hex');
- var pub2 = dh2.computeSecret(pubk1).toString('hex');
- t.equals(pub1, pub2, 'equal secrets');
- });
- test('createECDH: ' + mod + ' compressed', function (t) {
- t.plan(2);
- var dh1 = createECDH1(mod);
- dh1.generateKeys();
- var dh2 = createECDH2(mod);
- dh2.generateKeys();
- var pubk1 = dh1.getPublicKey(null, 'compressed');
- var pubk2 = dh2.getPublicKey(null, 'compressed');
- t.notEquals(pubk1.toString('hex'), pubk2.toString('hex'), 'diff public keys');
- var pub1 = dh1.computeSecret(pubk2).toString('hex');
- var pub2 = dh2.computeSecret(pubk1).toString('hex');
- t.equals(pub1, pub2, 'equal secrets');
- });
- test('createECDH: ' + mod + ' set stuff', function (t) {
- t.plan(5);
- var dh1 = createECDH1(mod);
- var dh2 = createECDH2(mod);
- dh1.generateKeys();
- dh2.generateKeys();
- dh1.setPrivateKey(dh2.getPrivateKey());
- dh1.setPublicKey(dh2.getPublicKey());
- var priv1 = dh1.getPrivateKey('hex');
- var priv2 = dh2.getPrivateKey('hex');
- t.equals(priv1, priv2, 'same private key');
- var pubk1 = dh1.getPublicKey();
- var pubk2 = dh2.getPublicKey();
- t.equals(pubk1.toString('hex'), pubk2.toString('hex'), 'same public keys, uncompressed');
- t.equals(dh1.getPublicKey('hex', 'compressed'), dh2.getPublicKey('hex', 'compressed'), 'same public keys compressed');
- t.equals(dh1.getPublicKey('hex', 'hybrid'), dh2.getPublicKey('hex', 'hybrid'), 'same public keys hybrid');
- var pub1 = dh1.computeSecret(pubk2).toString('hex');
- var pub2 = dh2.computeSecret(pubk1).toString('hex');
- t.equals(pub1, pub2, 'equal secrets');
- });
- });
|