Browse Source

Merge pull request #54 from coinpunk/moreaddresstesting

More address testing
hk-custom-address
Wei Lu 11 years ago
parent
commit
ef1a4017f8
  1. 13
      src/address.js
  2. 54
      test/address.js

13
src/address.js

@ -14,7 +14,7 @@ var Address = function (bytes, version) {
this.hash = this.hash =
bytes.length <= 35 ? base58.checkDecode(bytes) bytes.length <= 35 ? base58.checkDecode(bytes)
: bytes.length <= 40 ? conv.hexToBytes(bytes) : bytes.length <= 40 ? conv.hexToBytes(bytes)
: util.error('Bad input'); : util.error('invalid or unrecognized input');
this.version = version || this.hash.version || mainnet; this.version = version || this.hash.version || mainnet;
} }
@ -33,10 +33,6 @@ Address.prototype.toString = function () {
return base58.checkEncode(this.hash.slice(0), this.version); return base58.checkEncode(this.hash.slice(0), this.version);
}; };
Address.prototype.getHash = function () {
return conv.bytesToHex(this.hash);
};
Address.getVersion = function(string) { Address.getVersion = function(string) {
return base58.decode(string)[0]; return base58.decode(string)[0];
} }
@ -50,11 +46,4 @@ Address.validate = function(string) {
} }
}; };
/**
* Parse a Bitcoin address contained in a string.
*/
Address.decodeString = function (string) {
return base58.checkDecode(string);
};
module.exports = Address; module.exports = Address;

54
test/address.js

@ -1,13 +1,14 @@
/* global describe, it */ /* global describe, it */
var assert = require('assert'); var assert = require('assert')
var Address = require('../src/address.js'); var Address = require('../src/address.js')
var network = require('../src/network.js'); var network = require('../src/network.js')
var base58 = require('../src/base58.js')
var mainnet = network.mainnet.addressVersion var mainnet = network.mainnet.addressVersion
var testnet = network.testnet.addressVersion var testnet = network.testnet.addressVersion
describe('Address', function() { describe('Address', function() {
var testnetAddress, mainnetAddress; var testnetAddress, mainnetAddress;
var testnetP2shAddress, mainnetP2shAddress; var testnetP2shAddress, mainnetP2shAddress
beforeEach(function(){ beforeEach(function(){
testnetAddress = 'mzBc4XEFSdzCDcTxAgf6EZXgsZWpztRhef' testnetAddress = 'mzBc4XEFSdzCDcTxAgf6EZXgsZWpztRhef'
@ -16,6 +17,51 @@ describe('Address', function() {
mainnetP2shAddress = '3NJZLcZEEYBpxYEUGewU4knsQRn1WM5Fkt' mainnetP2shAddress = '3NJZLcZEEYBpxYEUGewU4knsQRn1WM5Fkt'
}) })
describe('parsing', function() {
it('works with Address object', function() {
var addr = new Address(new Address('mwrB4fgT1KSBCqELaWv7o7tsExuQzW3NY3', network.testnet.addressVersion))
assert.equal(addr.toString(), 'mwrB4fgT1KSBCqELaWv7o7tsExuQzW3NY3')
assert.equal(addr.version, network.testnet.addressVersion)
})
it('works with hex', function() {
var addr = new Address('13483382d3c3d43fc9d7b52e652b6bbb70e8b667')
assert.equal(addr.toString(), '12kxLGqrnnchwN9bHHNV2fWDtJGwxKTcJS')
})
it('throws error for invalid or unrecognized input', function() {
assert.throws(function() {
new Address('beepboopbeepboopbeepboopbeepboopbeepboopbeep')
}, Error)
})
it('works for byte input', function() {
var hash = base58.checkDecode('1A1zP1eP5QGefi2DMPTfTL5SLmv7DivfNa')
var addr = new Address(hash)
assert.equal(addr.hash, hash)
assert.equal(network.mainnet.addressVersion, hash.version)
var hash = base58.checkDecode('mzBc4XEFSdzCDcTxAgf6EZXgsZWpztRhef')
var addr = new Address(hash)
assert.equal(addr.hash, hash)
assert.equal(network.testnet.addressVersion, hash.version)
})
it('fails for bad input', function() {
assert.throws(function() {
new Address('foo')
}, Error)
})
})
describe('getVersion', function() {
it('returns the proper address version', function() {
assert.equal(Address.getVersion('1A1zP1eP5QGefi2DMPTfTL5SLmv7DivfNa'), network.mainnet.addressVersion)
assert.equal(Address.getVersion('mzBc4XEFSdzCDcTxAgf6EZXgsZWpztRhef'), network.testnet.addressVersion)
})
})
describe('toString', function() { describe('toString', function() {
it('defaults to base58', function() { it('defaults to base58', function() {
var addr = '18fN1QTGWmHWCA9r2dyDH6FbMEyc7XHmQQ'; var addr = '18fN1QTGWmHWCA9r2dyDH6FbMEyc7XHmQQ';

Loading…
Cancel
Save