From 600209b1a633a134aa18482a8220713929b4e64d Mon Sep 17 00:00:00 2001 From: Kyle Drake Date: Sun, 25 May 2014 11:58:10 +1000 Subject: [PATCH] hdwallet: remove fromHex, add better tests for edge cases --- src/hdwallet.js | 4 ---- test/hdwallet.js | 21 +++++++++++++++++++++ 2 files changed, 21 insertions(+), 4 deletions(-) diff --git a/src/hdwallet.js b/src/hdwallet.js index cd0787d..20766ac 100644 --- a/src/hdwallet.js +++ b/src/hdwallet.js @@ -57,10 +57,6 @@ HDWallet.fromBase58 = function(string) { return HDWallet.fromBuffer(payload) } -HDWallet.fromHex = function(input) { - return HDWallet.fromBuffer(new Buffer(input, 'hex')) -} - HDWallet.fromBuffer = function(input) { assert.strictEqual(input.length, HDWallet.LENGTH, 'Invalid buffer length') diff --git a/test/hdwallet.js b/test/hdwallet.js index b0284f7..a6ed497 100644 --- a/test/hdwallet.js +++ b/test/hdwallet.js @@ -53,6 +53,21 @@ describe('HDWallet', function() { assert(hd.pub) }) }) + + describe('fromBuffer', function() { + it('fails for invalid parent fingerprint', function() { + var buffer = new HDWallet(seed).toBuffer() + buffer.writeUInt8(0x00, 4) + buffer.writeUInt32BE(0xFFFFFFFF, 5) + assert.throws(function() { HDWallet.fromBuffer(buffer) }, /Invalid parent fingerprint/) + }) + + it('fails for invalid index', function() { + var buffer = new HDWallet(seed).toBuffer() + buffer.writeUInt32BE(0xFFFFFFFF, 9) + assert.throws(function() { HDWallet.fromBuffer(buffer) }, /Invalid index/) + }) + }) }) describe('Test vectors', function() { @@ -247,5 +262,11 @@ describe('HDWallet', function() { it('throws an exception when unknown network type is passed in', function() { assert.throws(function() { new HDWallet(new Buffer('foobar'), 'doge') }) }) + + it('throws an exception with bad network type using fromBuffer', function() { + var buffer = new HDWallet(new Buffer('foobar'), 'bitcoin').toBuffer() + buffer.writeUInt32BE(0x00000000, 0) + assert.throws(function() { HDWallet.fromBuffer(buffer) }, /Could not find version 0/) + }) }) })