From 9e32c892ef90abda3b1db3e0f459a7faf06bd4a0 Mon Sep 17 00:00:00 2001 From: Daniel Cousens Date: Thu, 25 Feb 2016 13:26:05 +1100 Subject: [PATCH 1/3] ECPair/tests: always use WIF for error throwing --- src/ecpair.js | 3 +-- test/ecpair.js | 4 +++- test/fixtures/ecpair.json | 5 +++++ 3 files changed, 9 insertions(+), 3 deletions(-) diff --git a/src/ecpair.js b/src/ecpair.js index a01f363..d81b5be 100644 --- a/src/ecpair.js +++ b/src/ecpair.js @@ -58,7 +58,6 @@ ECPair.fromPublicKeyBuffer = function (buffer, network) { } ECPair.fromWIF = function (string, network) { - network = network || NETWORKS.bitcoin var buffer = bs58check.decode(string) if (types.Array(network)) { @@ -67,9 +66,9 @@ ECPair.fromWIF = function (string, network) { network = network.filter(function (network) { return version === network.wif }).pop() - if (!network) throw new Error('Invalid network version') } + network = network || NETWORKS.bitcoin var decoded = wif.decodeRaw(buffer, network.wif) var d = BigInteger.fromBuffer(decoded.privateKey) diff --git a/test/ecpair.js b/test/ecpair.js index b7edbd0..f9e594a 100644 --- a/test/ecpair.js +++ b/test/ecpair.js @@ -107,7 +107,9 @@ describe('ECPair', function () { fixtures.invalid.fromWIF.forEach(function (f) { it('throws on ' + f.WIF, function () { assert.throws(function () { - ECPair.fromWIF(f.WIF) + var networks = f.network ? NETWORKS[f.network] : NETWORKS_LIST + + ECPair.fromWIF(f.WIF, networks) }, new RegExp(f.exception)) }) }) diff --git a/test/fixtures/ecpair.json b/test/fixtures/ecpair.json index 652eb2d..d4e8cfb 100644 --- a/test/fixtures/ecpair.json +++ b/test/fixtures/ecpair.json @@ -107,8 +107,13 @@ "fromWIF": [ { "exception": "Invalid network version", + "network": "bitcoin", "WIF": "92Qba5hnyWSn5Ffcka56yMQauaWY6ZLd91Vzxbi4a9CCetaHtYj" }, + { + "exception": "Invalid network version", + "WIF": "brQnSed3Fia1w9VcbbS6ZGDgJ6ENkgwuQY2LS7pEC5bKHD1fMF" + }, { "exception": "Invalid compression flag", "WIF": "KwDiBf89QgGbjEhKnhXJuH7LrciVrZi3qYjgd9M7rFU73sfZr2ym" From bdb0dd4a17fdf47d1998da91b72e1553faa0bf41 Mon Sep 17 00:00:00 2001 From: Daniel Cousens Date: Thu, 25 Feb 2016 13:41:35 +1100 Subject: [PATCH 2/3] HDNode/tests: add testing for invalid network version from networks list --- src/hdnode.js | 6 ++++-- test/fixtures/hdnode.json | 5 +++-- test/hdnode.js | 4 ++-- 3 files changed, 9 insertions(+), 6 deletions(-) diff --git a/src/hdnode.js b/src/hdnode.js index 784acf5..0efd61c 100644 --- a/src/hdnode.js +++ b/src/hdnode.js @@ -64,7 +64,9 @@ HDNode.fromBase58 = function (string, networks) { network = networks.filter(function (network) { return version === network.bip32.private || version === network.bip32.public - }).pop() || {} + }).pop() + + if (!network) throw new Error('Invalid network version') // otherwise, assume a network object (or default to bitcoin) } else { @@ -72,7 +74,7 @@ HDNode.fromBase58 = function (string, networks) { } if (version !== network.bip32.private && - version !== network.bip32.public) throw new Error('Invalid network') + version !== network.bip32.public) throw new Error('Invalid network version') // 1 byte: depth: 0x00 for master nodes, 0x01 for level-1 descendants, ... var depth = buffer[4] diff --git a/test/fixtures/hdnode.json b/test/fixtures/hdnode.json index 21ca41d..59e0647 100644 --- a/test/fixtures/hdnode.json +++ b/test/fixtures/hdnode.json @@ -199,11 +199,12 @@ "string": "xprvQQQQQQQQQQQQQQQQCviVfJSKyQ1mDYahRjijr5idH2WwLsEd4Hsb2Tyh8RfQMuPh7f7RtyzTtdrbdqqsunu5Mm3wDvUAKRHSC34sJ7in334" }, { - "exception": "Invalid network", + "exception": "Invalid network version", "string": "1111111111111adADjFaSNPxwXqLjHLj4mBfYxuewDPbw9hEj1uaXCzMxRPXDFF3cUoezTFYom4sEmEVSQmENPPR315cFk9YUFVek73wE9" }, { - "exception": "Invalid network", + "exception": "Invalid network version", + "network": "bitcoin", "string": "Ltpv73XYpw28ZyVe2zEVyiFnxUZxoKLGQNdZ8NxUi1WcqjNmMBgtLbh3KimGSnPHCoLv1RmvxHs4dnKmo1oXQ8dXuDu8uroxrbVxZPA1gXboYvx" } ], diff --git a/test/hdnode.js b/test/hdnode.js index c5a55fb..e901850 100644 --- a/test/hdnode.js +++ b/test/hdnode.js @@ -210,9 +210,9 @@ describe('HDNode', function () { fixtures.invalid.fromBase58.forEach(function (f) { it('throws on ' + f.string, function () { assert.throws(function () { - var network = NETWORKS[f.network] + var networks = f.network ? NETWORKS[f.network] : NETWORKS_LIST - HDNode.fromBase58(f.string, network) + HDNode.fromBase58(f.string, networks) }, new RegExp(f.exception)) }) }) From aae5db6a59f51f3f017dda110e9cbfc4da65283b Mon Sep 17 00:00:00 2001 From: Daniel Cousens Date: Thu, 25 Feb 2016 13:48:29 +1100 Subject: [PATCH 3/3] ECPair/HDNode: missing version from list is Unknown, not Invalid --- src/ecpair.js | 2 ++ src/hdnode.js | 2 +- test/fixtures/ecpair.json | 2 +- test/fixtures/hdnode.json | 2 +- 4 files changed, 5 insertions(+), 3 deletions(-) diff --git a/src/ecpair.js b/src/ecpair.js index d81b5be..c647196 100644 --- a/src/ecpair.js +++ b/src/ecpair.js @@ -66,6 +66,8 @@ ECPair.fromWIF = function (string, network) { network = network.filter(function (network) { return version === network.wif }).pop() + + if (!network) throw new Error('Unknown network version') } network = network || NETWORKS.bitcoin diff --git a/src/hdnode.js b/src/hdnode.js index 0efd61c..27228e9 100644 --- a/src/hdnode.js +++ b/src/hdnode.js @@ -66,7 +66,7 @@ HDNode.fromBase58 = function (string, networks) { version === network.bip32.public }).pop() - if (!network) throw new Error('Invalid network version') + if (!network) throw new Error('Unknown network version') // otherwise, assume a network object (or default to bitcoin) } else { diff --git a/test/fixtures/ecpair.json b/test/fixtures/ecpair.json index d4e8cfb..6f0a1a2 100644 --- a/test/fixtures/ecpair.json +++ b/test/fixtures/ecpair.json @@ -111,7 +111,7 @@ "WIF": "92Qba5hnyWSn5Ffcka56yMQauaWY6ZLd91Vzxbi4a9CCetaHtYj" }, { - "exception": "Invalid network version", + "exception": "Unknown network version", "WIF": "brQnSed3Fia1w9VcbbS6ZGDgJ6ENkgwuQY2LS7pEC5bKHD1fMF" }, { diff --git a/test/fixtures/hdnode.json b/test/fixtures/hdnode.json index 59e0647..877dd6d 100644 --- a/test/fixtures/hdnode.json +++ b/test/fixtures/hdnode.json @@ -199,7 +199,7 @@ "string": "xprvQQQQQQQQQQQQQQQQCviVfJSKyQ1mDYahRjijr5idH2WwLsEd4Hsb2Tyh8RfQMuPh7f7RtyzTtdrbdqqsunu5Mm3wDvUAKRHSC34sJ7in334" }, { - "exception": "Invalid network version", + "exception": "Unknown network version", "string": "1111111111111adADjFaSNPxwXqLjHLj4mBfYxuewDPbw9hEj1uaXCzMxRPXDFF3cUoezTFYom4sEmEVSQmENPPR315cFk9YUFVek73wE9" }, {