2014-01-11 13:57:43 +07:00
|
|
|
/* global describe, it */
|
2013-02-17 00:39:15 -05:00
|
|
|
var assert = require('assert');
|
2014-03-22 18:19:56 +11:00
|
|
|
|
2014-01-11 13:57:43 +07:00
|
|
|
var ECKey = require('../src/eckey.js').ECKey;
|
2014-03-22 18:19:56 +11:00
|
|
|
var ECPubKey = require('../src/eckey.js').ECPubKey;
|
|
|
|
|
2014-01-11 13:57:43 +07:00
|
|
|
var convert = require('../src/convert.js');
|
|
|
|
var bytesToHex = convert.bytesToHex;
|
|
|
|
var hexToBytes = convert.hexToBytes;
|
2014-02-24 18:31:18 +02:00
|
|
|
var Address = require('../src/address');
|
2014-02-28 16:05:43 +08:00
|
|
|
var Network = require('../src/network')
|
|
|
|
var testnet = Network.testnet.addressVersion
|
2014-01-11 13:57:43 +07:00
|
|
|
|
|
|
|
describe('ECKey', function() {
|
2014-03-22 18:19:56 +11:00
|
|
|
describe('constructor', function() {
|
2014-02-24 18:31:18 +02:00
|
|
|
it('parses hex', function() {
|
2014-01-11 13:57:43 +07:00
|
|
|
var priv = '18e14a7b6a307f426a94f8114701e7c8e774e7f9a47e2c2035db29a206321725';
|
|
|
|
var pub = '0450863ad64a87ae8a2fe83c1af1a8403cb53f53e486d8511dad8a04887e5b235' +
|
|
|
|
'22cd470243453a299fa9e77237716103abc11a1df38855ed6f2ee187e9c582ba6';
|
2014-02-24 18:31:18 +02:00
|
|
|
var key = new ECKey(priv);
|
2014-01-11 13:57:43 +07:00
|
|
|
|
2014-02-24 18:31:18 +02:00
|
|
|
assert.equal(key.getPub().toHex(), pub);
|
2014-01-11 13:57:43 +07:00
|
|
|
assert.equal(key.compressed, false);
|
|
|
|
})
|
|
|
|
|
2014-02-24 18:31:18 +02:00
|
|
|
it('parses base64', function() {
|
|
|
|
var priv = 'VYdB+iv47y5FaUVIPdQInkgATrABeuD1lACUoM4x7tU=';
|
|
|
|
var pub = '042f43c16c08849fed20a35bb7b1947bbf0923c52d613ee13b5c665a1e10d24b2' +
|
|
|
|
'8be909a70f5f87c1adb79fbcd1b3f17d20aa91c04fc355112dba2ce9b1cbf013b';
|
|
|
|
var key = new ECKey(priv);
|
|
|
|
|
|
|
|
assert.equal(key.getPub().toHex(), pub);
|
|
|
|
assert.equal(key.compressed, false);
|
|
|
|
})
|
|
|
|
|
|
|
|
it('parses WIF', function() {
|
2014-01-11 13:57:43 +07:00
|
|
|
var priv = '5HwoXVkHoRM8sL2KmNRS217n1g8mPPBomrY7yehCuXC1115WWsh';
|
|
|
|
var pub = '044f355bdcb7cc0af728ef3cceb9615d90684bb5b2ca5f859ab0' +
|
|
|
|
'f0b704075871aa385b6b1b8ead809ca67454d9683fcf2ba03456d6fe2c4abe2b07f0fbdbb2f1c1';
|
|
|
|
var addr = '1MsHWS1BnwMc3tLE8G35UXsS58fKipzB7a';
|
|
|
|
var key = new ECKey(priv);
|
|
|
|
|
|
|
|
assert.equal(key.compressed, false);
|
2014-02-24 18:31:18 +02:00
|
|
|
assert.equal(key.getPub().toHex(), pub);
|
2014-03-22 18:19:56 +11:00
|
|
|
assert.equal(key.getAddress().toString(), addr);
|
2014-01-11 13:57:43 +07:00
|
|
|
})
|
|
|
|
|
2014-02-24 18:31:18 +02:00
|
|
|
it('parses compressed WIF', function() {
|
2014-01-11 13:57:43 +07:00
|
|
|
var priv = 'KwntMbt59tTsj8xqpqYqRRWufyjGunvhSyeMo3NTYpFYzZbXJ5Hp';
|
|
|
|
var pub = '034f355bdcb7cc0af728ef3cceb9615d90684bb5b2ca5f859ab0f0b704075871aa'
|
|
|
|
var addr = '1Q1pE5vPGEEMqRcVRMbtBK842Y6Pzo6nK9';
|
|
|
|
var key = new ECKey(priv);
|
|
|
|
|
|
|
|
assert.equal(key.compressed, true);
|
2014-02-24 18:31:18 +02:00
|
|
|
assert.equal(key.getPub().toHex(), pub);
|
2014-03-22 18:19:56 +11:00
|
|
|
assert.equal(key.getAddress().toString(), addr);
|
2014-02-24 18:31:18 +02:00
|
|
|
})
|
|
|
|
|
2014-03-22 18:19:56 +11:00
|
|
|
it('alternative constructor syntax', function() {
|
2014-02-24 18:31:18 +02:00
|
|
|
var priv = 'ca48ec9783cf3ad0dfeff1fc254395a2e403cbbc666477b61b45e31d3b8ab458';
|
|
|
|
var pub = '044b12d9d7c77db68388b6ff7c89046174c871546436806bcd80d07c28ea81199' +
|
|
|
|
'283fbec990dad6fb98f93f712d50cb874dd717de6a184158d63886dda3090f566';
|
2014-03-22 18:19:56 +11:00
|
|
|
var key = ECKey(priv, false);
|
2014-02-24 18:31:18 +02:00
|
|
|
|
|
|
|
assert.equal(key.getPub().toHex(), pub);
|
|
|
|
assert.equal(key.compressed, false);
|
|
|
|
assert.equal(key.toHex(), priv);
|
|
|
|
})
|
2014-03-22 18:19:56 +11:00
|
|
|
})
|
2014-02-24 18:31:18 +02:00
|
|
|
|
2014-03-22 18:19:56 +11:00
|
|
|
describe('toAddress', function() {
|
|
|
|
var privkeys = [
|
2014-03-25 03:31:55 +11:00
|
|
|
'ca48ec9783cf3ad0dfeff1fc254395a2e403cbbc666477b61b45e31d3b8ab458',
|
2014-03-24 03:19:39 +08:00
|
|
|
'1111111111111111111111111111111111111111111111111111111111111111',
|
2014-03-25 03:31:55 +11:00
|
|
|
'18e14a7b6a307f426a94f8114701e7c8e774e7f9a47e2c2035db29a206321725'
|
2014-03-24 03:19:39 +08:00
|
|
|
];
|
|
|
|
|
|
|
|
// compressed pubkeys
|
|
|
|
var cpubkeys = [
|
2014-03-25 03:31:55 +11:00
|
|
|
'024b12d9d7c77db68388b6ff7c89046174c871546436806bcd80d07c28ea811992',
|
|
|
|
'034f355bdcb7cc0af728ef3cceb9615d90684bb5b2ca5f859ab0f0b704075871aa',
|
|
|
|
'0250863ad64a87ae8a2fe83c1af1a8403cb53f53e486d8511dad8a04887e5b2352'
|
2014-03-24 03:19:39 +08:00
|
|
|
];
|
|
|
|
|
|
|
|
var pubkeys = cpubkeys.map(function(x) {
|
2014-03-25 03:31:55 +11:00
|
|
|
return ECPubKey(x).toHex(false)
|
2014-03-24 03:19:39 +08:00
|
|
|
});
|
2014-03-22 18:19:56 +11:00
|
|
|
|
|
|
|
it('mainnet', function() {
|
2014-03-24 03:19:39 +08:00
|
|
|
var addresses = [
|
|
|
|
'19SgmoUj4xowEjwtXvNAtYTAgbvR9iBCui',
|
|
|
|
'1MsHWS1BnwMc3tLE8G35UXsS58fKipzB7a',
|
|
|
|
'16UwLL9Risc3QfPqBUvKofHmBQ7wMtjvM'
|
|
|
|
];
|
|
|
|
var compressedAddresses = [
|
|
|
|
'1AA4sjKW2aUmbtN3MtegdvhYtDBbDEke1q',
|
|
|
|
'1Q1pE5vPGEEMqRcVRMbtBK842Y6Pzo6nK9',
|
|
|
|
'1PMycacnJaSqwwJqjawXBErnLsZ7RkXUAs',
|
|
|
|
];
|
|
|
|
|
|
|
|
for (var i = 0; i < addresses.length; ++i) {
|
|
|
|
var priv = new ECKey(privkeys[i], false);
|
|
|
|
var pub = new ECPubKey(pubkeys[i], false);
|
2014-03-25 03:31:55 +11:00
|
|
|
var cpub = new ECPubKey(cpubkeys[i], true);
|
2014-03-24 03:19:39 +08:00
|
|
|
|
|
|
|
var addr = addresses[i];
|
|
|
|
var caddr = compressedAddresses[i];
|
|
|
|
|
|
|
|
assert.equal(priv.getAddress().toString(), addr);
|
|
|
|
assert.equal(pub.getAddress().toString(), addr);
|
2014-03-25 03:31:55 +11:00
|
|
|
assert.equal(cpub.getAddress().toString(), caddr);
|
2014-03-24 03:19:39 +08:00
|
|
|
}
|
2014-01-11 13:57:43 +07:00
|
|
|
})
|
2014-03-22 16:26:44 +11:00
|
|
|
|
2014-03-22 18:19:56 +11:00
|
|
|
it('testnet', function() {
|
2014-03-24 03:19:39 +08:00
|
|
|
var addresses = [
|
|
|
|
'19SgmoUj4xowEjwtXvNAtYTAgbvR9iBCui',
|
|
|
|
'1MsHWS1BnwMc3tLE8G35UXsS58fKipzB7a',
|
|
|
|
'16UwLL9Risc3QfPqBUvKofHmBQ7wMtjvM'
|
|
|
|
];
|
|
|
|
var compressedAddresses = [
|
|
|
|
'1AA4sjKW2aUmbtN3MtegdvhYtDBbDEke1q',
|
|
|
|
'1Q1pE5vPGEEMqRcVRMbtBK842Y6Pzo6nK9',
|
|
|
|
'1PMycacnJaSqwwJqjawXBErnLsZ7RkXUAs',
|
|
|
|
];
|
|
|
|
|
|
|
|
for (var i = 0; i < addresses.length; ++i) {
|
|
|
|
var priv = new ECKey(privkeys[i], false);
|
|
|
|
var pub = new ECPubKey(pubkeys[i], false);
|
2014-03-25 03:31:55 +11:00
|
|
|
var cpub = new ECPubKey(cpubkeys[i], true);
|
2014-03-24 03:19:39 +08:00
|
|
|
|
|
|
|
var addr = addresses[i];
|
|
|
|
var caddr = compressedAddresses[i];
|
|
|
|
|
|
|
|
assert.equal(priv.getAddress().toString(), addr);
|
|
|
|
assert.equal(pub.getAddress().toString(), addr);
|
2014-03-25 03:31:55 +11:00
|
|
|
assert.equal(cpub.getAddress().toString(), caddr);
|
2014-03-24 03:19:39 +08:00
|
|
|
}
|
2014-03-22 16:26:44 +11:00
|
|
|
})
|
2014-03-22 18:19:56 +11:00
|
|
|
});
|
2014-03-25 03:48:50 +11:00
|
|
|
|
|
|
|
describe('signing', function() {
|
|
|
|
var hpriv = 'ca48ec9783cf3ad0dfeff1fc254395a2e403cbbc666477b61b45e31d3b8ab458'
|
|
|
|
var hcpub = '024b12d9d7c77db68388b6ff7c89046174c871546436806bcd80d07c28ea811992'
|
|
|
|
var message = 'Vires in numeris'
|
|
|
|
|
|
|
|
it('should verify against the private key', function() {
|
|
|
|
var priv = new ECKey(hpriv)
|
|
|
|
var signature = priv.sign(message)
|
|
|
|
|
|
|
|
assert(priv.verify(message, signature))
|
|
|
|
})
|
|
|
|
|
|
|
|
it('should verify against the public key', function() {
|
|
|
|
var priv = new ECKey(hpriv)
|
|
|
|
var pub = new ECPubKey(hcpub, true)
|
|
|
|
var signature = priv.sign(message)
|
|
|
|
|
|
|
|
assert(pub.verify(message, signature))
|
|
|
|
})
|
|
|
|
|
|
|
|
it('should not verify against the wrong private key', function() {
|
|
|
|
var priv1 = new ECKey(hpriv)
|
|
|
|
var priv2 = new ECKey('1111111111111111111111111111111111111111111111111111111111111111')
|
|
|
|
|
|
|
|
var signature = priv1.sign(message)
|
|
|
|
|
|
|
|
assert(!priv2.verify(message, signature))
|
|
|
|
})
|
|
|
|
})
|
2014-03-24 15:11:34 -07:00
|
|
|
|
2014-03-25 03:31:55 +11:00
|
|
|
describe('output of ECPubKey', function() {
|
|
|
|
var hcpub = '024b12d9d7c77db68388b6ff7c89046174c871546436806bcd80d07c28ea811992'
|
|
|
|
var hpub = '044b12d9d7c77db68388b6ff7c89046174c871546436806bcd80d07c28ea81199283fbec990dad6fb98f93f712d50cb874dd717de6a184158d63886dda3090f566'
|
|
|
|
|
|
|
|
it('using toHex should support compression', function() {
|
|
|
|
var pub = new ECPubKey(hpub)
|
|
|
|
|
|
|
|
assert.equal(pub.toHex(true), hcpub)
|
|
|
|
assert.equal(pub.toHex(false), hpub)
|
|
|
|
})
|
|
|
|
|
|
|
|
it('using toBytes should support compression', function() {
|
|
|
|
var pub = new ECPubKey(hpub)
|
|
|
|
|
|
|
|
assert.equal(bytesToHex(pub.toBytes(true)), hcpub)
|
|
|
|
assert.equal(bytesToHex(pub.toBytes(false)), hpub)
|
|
|
|
})
|
|
|
|
})
|
2014-01-11 13:57:43 +07:00
|
|
|
})
|