You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 

126 lines
3.3 KiB

'use strict';
var chai = require('chai');
var bitcore = require('../bitcore');
var should = chai.should();
var Address = bitcore.Address.class();
var PrivateKey = bitcore.PrivateKey.class();
var networks = bitcore.networks;
var KeyModule = bitcore.KeyModule;
var test_data = require('../browser/testdata');
function test_encode_priv(b58, payload, isTestnet, isCompressed) {
var network = isTestnet ? networks.testnet : networks.livenet;
var version = network.keySecret;
var buf_pl = new Buffer(payload, 'hex');
var buf;
if (isCompressed) {
buf = new Buffer(buf_pl.length + 1);
buf_pl.copy(buf);
buf[buf_pl.length] = 1;
} else
buf = buf_pl;
var key = new KeyModule.Key();
key.private = buf;
key.compressed = isCompressed;
var privkey = new PrivateKey(version, buf);
privkey.toString().should.equal(b58);
}
function test_encode_pub(b58, payload, isTestnet, addrType) {
var isScript = (addrType === 'script');
var network = isTestnet ? networks.testnet : networks.livenet;
var version = isScript ? network.addressScript : network.addressPubkey;
var buf = new Buffer(payload, 'hex');
var addr = new Address(version, buf);
addr.toString().should.equal(b58);
}
function test_decode_priv(b58, payload, isTestnet, isCompressed) {
var network = isTestnet ? networks.testnet : networks.livenet;
var version = network.keySecret;
var buf_pl = new Buffer(payload, 'hex');
var buf;
if (isCompressed) {
buf = new Buffer(buf_pl.length + 1);
buf_pl.copy(buf);
buf[buf_pl.length] = 1;
} else
buf = buf_pl;
var privkey = new PrivateKey(b58);
version.should.equal(privkey.version());
buf_pl.toString().should.equal(privkey.payload().toString());
}
function test_decode_pub(b58, payload, isTestnet, addrType) {
var isScript = (addrType === 'script');
var network = isTestnet ? networks.testnet : networks.livenet;
var version = isScript ? network.addressScript : network.addressPubkey;
var buf = new Buffer(payload, 'hex');
var addr = new Address(b58);
version.should.equal(addr.version());
buf.toString().should.equal(addr.payload().toString());
}
function is_valid(datum) {
var b58 = datum[0];
var payload = datum[1];
var obj = datum[2];
var isPrivkey = obj.isPrivkey;
var isTestnet = obj.isTestnet;
if (isPrivkey) {
var isCompressed = obj.isCompressed;
test_encode_priv(b58, payload, isTestnet, isCompressed);
test_decode_priv(b58, payload, isTestnet, isCompressed);
} else {
var addrType = obj.addrType;
test_encode_pub(b58, payload, isTestnet, addrType);
test_decode_pub(b58, payload, isTestnet, addrType);
}
}
function is_invalid(datum) {
if (datum.length < 1)
throw new Error('Bad test');
// ignore succeeding elements, as comments
var b58 = datum[0];
var privkey = new PrivateKey(b58);
var addr = new Address(b58);
var valid = true;
try {
privkey.validate();
addr.validate();
} catch (e) {
valid = false;
}
valid.should.equal(false);
}
describe('Valid base58 keys', function() {
test_data.dataValid.forEach(function(datum) {
it('valid ' + datum[0], function() {
is_valid(datum);
});
});
});
describe('Invalid base58 keys', function() {
test_data.dataInvalid.forEach(function(datum) {
it('invalid ' + datum, function() {
is_invalid(datum);
});
});
});