| 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');
 
- 	});
 
- });
 
 
  |