Browse Source

Merge pull request #1268 from brandonrobertz/master

modularize network version check issues/1265 (2nd)
patch-2
Braydon Fuller 10 years ago
parent
commit
8e13b68405
  1. 7
      lib/privatekey.js
  2. 32
      test/privatekey.js

7
lib/privatekey.js

@ -157,11 +157,8 @@ PrivateKey._transformBuffer = function(buf, network) {
} }
info.network = Networks.get(buf[0], 'privatekey'); info.network = Networks.get(buf[0], 'privatekey');
if (buf[0] === Networks.livenet.privatekey) {
info.network = Networks.livenet; if (!info.network) {
} else if (buf[0] === Networks.testnet.privatekey) {
info.network = Networks.testnet;
} else {
throw new Error('Invalid network'); throw new Error('Invalid network');
} }

32
test/privatekey.js

@ -22,6 +22,7 @@ describe('PrivateKey', function() {
var wifTestnetUncompressed = '92jJzK4tbURm1C7udQXxeCBvXHoHJstDXRxAMouPG1k1XUaXdsu'; var wifTestnetUncompressed = '92jJzK4tbURm1C7udQXxeCBvXHoHJstDXRxAMouPG1k1XUaXdsu';
var wifLivenet = 'L2Gkw3kKJ6N24QcDuH4XDqt9cTqsKTVNDGz1CRZhk9cq4auDUbJy'; var wifLivenet = 'L2Gkw3kKJ6N24QcDuH4XDqt9cTqsKTVNDGz1CRZhk9cq4auDUbJy';
var wifLivenetUncompressed = '5JxgQaFM1FMd38cd14e3mbdxsdSa9iM2BV6DHBYsvGzxkTNQ7Un'; var wifLivenetUncompressed = '5JxgQaFM1FMd38cd14e3mbdxsdSa9iM2BV6DHBYsvGzxkTNQ7Un';
var wifNamecoin = '74pxNKNpByQ2kMow4d9kF6Z77BYeKztQNLq3dSyU4ES1K5KLNiz';
it('should create a new random private key', function() { it('should create a new random private key', function() {
var a = new PrivateKey(); var a = new PrivateKey();
@ -44,6 +45,31 @@ describe('PrivateKey', function() {
should.exist(a.bn); should.exist(a.bn);
}); });
it('should create a private key from a custom network WIF string', function() {
var nmc = {
name: 'namecoin',
alias: 'namecoin',
pubkeyhash: 0x34,
privatekey: 0xB4,
// these below aren't the real NMC version numbers
scripthash: 0x08,
xpubkey: 0x0278b20e,
xprivkey: 0x0278ade4,
networkMagic: 0xf9beb4fe,
port: 20001,
dnsSeeds: [
'localhost',
'mynet.localhost'
]
};
Networks.add(nmc);
var nmcNet = Networks.get('namecoin');
var a = new PrivateKey(wifNamecoin, nmcNet);
should.exist(a);
should.exist(a.bn);
Networks.remove(nmcNet);
});
it('should create a new random testnet private key with empty data', function() { it('should create a new random testnet private key with empty data', function() {
var a = new PrivateKey(null, Networks.testnet); var a = new PrivateKey(null, Networks.testnet);
should.exist(a); should.exist(a);
@ -114,6 +140,12 @@ describe('PrivateKey', function() {
}).to.throw('Invalid network'); }).to.throw('Invalid network');
}); });
it('should not be able to instantiate private key WIF because of network mismatch', function() {
expect(function(){
var a = new PrivateKey(wifNamecoin, 'testnet');
}).to.throw('Invalid network');
});
it('can be instantiated from a hex string', function() { it('can be instantiated from a hex string', function() {
var privhex = '906977a061af29276e40bf377042ffbde414e496ae2260bbf1fa9d085637bfff'; var privhex = '906977a061af29276e40bf377042ffbde414e496ae2260bbf1fa9d085637bfff';
var pubhex = '02a1633cafcc01ebfb6d78e39f687a1f0995c62fc95f51ead10a02ee0be551b5dc'; var pubhex = '02a1633cafcc01ebfb6d78e39f687a1f0995c62fc95f51ead10a02ee0be551b5dc';

Loading…
Cancel
Save