bitcore/test/test.key.js

144 lines
4.4 KiB
JavaScript
Raw Normal View History

2014-08-07 21:31:36 -07:00
var should = require('chai').should();
var bn = require('../lib/bn');
var point = require('../lib/point');
2014-08-13 15:00:41 -07:00
var Address = require('../lib/address');
2014-08-09 17:43:24 -07:00
var Privkey = require('../lib/privkey');
var Pubkey = require('../lib/pubkey');
2014-08-07 21:31:36 -07:00
var Key = require('../lib/key');
2014-08-14 08:32:47 -07:00
describe('Key', function() {
2014-08-07 21:31:36 -07:00
it('should make a blank key', function() {
var key = new Key();
should.exist(key);
});
it('should make a key with a priv and pub', function() {
2014-08-09 17:43:24 -07:00
var priv = new Privkey();
var pub = new Pubkey();
2014-08-28 16:18:36 -07:00
var key = new Key({privkey: priv, pubkey: pub});
2014-08-07 21:31:36 -07:00
should.exist(key);
2014-08-09 17:43:24 -07:00
should.exist(key.privkey);
should.exist(key.pubkey);
2014-08-07 21:31:36 -07:00
});
2014-08-28 16:18:36 -07:00
describe("#set", function() {
it('should make a new priv and pub', function() {
should.exist(Key().set({privkey: Privkey()}).privkey);
});
});
2014-08-07 21:31:36 -07:00
describe("#fromRandom", function() {
2014-08-29 12:38:43 -07:00
it('should make a new priv and pub, should be compressed, mainnet', function() {
2014-08-07 21:31:36 -07:00
var key = new Key();
key.fromRandom();
2014-08-09 17:43:24 -07:00
should.exist(key.privkey);
should.exist(key.pubkey);
2014-08-13 12:23:06 -07:00
key.privkey.bn.gt(bn(0)).should.equal(true);
key.pubkey.point.getX().gt(bn(0)).should.equal(true);
key.pubkey.point.getY().gt(bn(0)).should.equal(true);
2014-08-29 12:38:43 -07:00
key.privkey.compressed.should.equal(true);
key.privkey.networkstr.should.equal('mainnet');
key.pubkey.compressed.should.equal(true);
2014-08-07 21:31:36 -07:00
});
});
describe("#fromString()", function() {
it('should recover a key creating with toString', function() {
var key = new Key();
key.fromRandom();
2014-08-09 17:43:24 -07:00
var priv = key.privkey;
var pub = key.pubkey;
2014-08-07 21:31:36 -07:00
var str = key.toString();
key.fromString(str);
2014-08-09 17:43:24 -07:00
should.exist(key.privkey);
should.exist(key.pubkey);
key.privkey.toString().should.equal(priv.toString());
key.pubkey.toString().should.equal(pub.toString());
2014-08-07 21:31:36 -07:00
});
2014-08-09 17:43:24 -07:00
it('should work with only Privkey set', function() {
2014-08-07 21:31:36 -07:00
var key = new Key();
key.fromRandom();
2014-08-09 17:43:24 -07:00
key.pubkey = undefined;
var priv = key.privkey;
2014-08-07 21:31:36 -07:00
var str = key.toString();
key.fromString(str);
2014-08-09 17:43:24 -07:00
should.exist(key.privkey);
key.privkey.toString().should.equal(priv.toString());
2014-08-07 21:31:36 -07:00
});
2014-08-09 17:43:24 -07:00
it('should work with only Pubkey set', function() {
2014-08-07 21:31:36 -07:00
var key = new Key();
key.fromRandom();
2014-08-09 17:43:24 -07:00
key.privkey = undefined;
var pub = key.pubkey;
2014-08-07 21:31:36 -07:00
var str = key.toString();
key.fromString(str);
2014-08-09 17:43:24 -07:00
should.exist(key.pubkey);
key.pubkey.toString().should.equal(pub.toString());
2014-08-07 21:31:36 -07:00
});
});
2014-08-13 15:00:41 -07:00
describe('#getAddress', function() {
it('should return an address', function() {
var privhex = '906977a061af29276e40bf377042ffbde414e496ae2260bbf1fa9d085637bfff';
var pubhex = '02a1633cafcc01ebfb6d78e39f687a1f0995c62fc95f51ead10a02ee0be551b5dc';
var key = new Key();
2014-08-28 17:26:56 -07:00
key.privkey = new Privkey({bn: bn(new Buffer(privhex, 'hex'))});
2014-08-13 15:00:41 -07:00
key.privkey2pubkey();
key.getAddress().toString().should.equal((new Address()).fromPubkey(key.pubkey).toString());
});
});
2014-08-09 17:43:24 -07:00
describe("#privkey2pubkey", function() {
2014-08-07 21:31:36 -07:00
2014-08-09 17:43:24 -07:00
it('should convert this known Privkey to known Pubkey', function() {
2014-08-07 21:31:36 -07:00
var privhex = '906977a061af29276e40bf377042ffbde414e496ae2260bbf1fa9d085637bfff';
var pubhex = '02a1633cafcc01ebfb6d78e39f687a1f0995c62fc95f51ead10a02ee0be551b5dc';
var key = new Key();
2014-08-28 17:26:56 -07:00
key.privkey = new Privkey({bn: bn(new Buffer(privhex, 'hex'))});
2014-08-09 17:43:24 -07:00
key.privkey2pubkey();
key.pubkey.toString().should.equal(pubhex);
2014-08-07 21:31:36 -07:00
});
it('should convert this known Privkey to known Pubkey and preserve compressed=true', function() {
var privhex = '906977a061af29276e40bf377042ffbde414e496ae2260bbf1fa9d085637bfff';
var key = new Key();
2014-08-28 17:26:56 -07:00
key.privkey = new Privkey({bn: bn(new Buffer(privhex, 'hex'))});
key.privkey.compressed = true;
key.privkey2pubkey();
key.pubkey.compressed.should.equal(true);
});
it('should convert this known Privkey to known Pubkey and preserve compressed=true', function() {
var privhex = '906977a061af29276e40bf377042ffbde414e496ae2260bbf1fa9d085637bfff';
var key = new Key();
2014-08-28 17:26:56 -07:00
key.privkey = new Privkey({bn: bn(new Buffer(privhex, 'hex'))});
key.privkey.compressed = false;
key.privkey2pubkey();
key.pubkey.compressed.should.equal(false);
});
2014-08-07 21:31:36 -07:00
});
describe("#toString()", function() {
it('should exist', function() {
var key = new Key();
key.fromRandom();
should.exist(key.toString());
});
});
});