From 12a5b75cbe208199d594b2c43890254f440c59b8 Mon Sep 17 00:00:00 2001 From: Daniel Cousens Date: Sun, 20 Apr 2014 05:42:36 +1000 Subject: [PATCH 1/3] Address now properly checks malformed base58 --- test/address.js | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/test/address.js b/test/address.js index 722fa08..ba9a21f 100644 --- a/test/address.js +++ b/test/address.js @@ -21,7 +21,7 @@ describe('Address', function() { it('throws on invalid base58check', function() { fixtures.malformed.forEach(function(f) { assert.throws(function() { - Address.fromBase58Check(f.base58check) + Address.fromBase58Check(f) }) }) }) From 1bcc7cfd95133b0b49408cec3493241feacb44cc Mon Sep 17 00:00:00 2001 From: Daniel Cousens Date: Sun, 20 Apr 2014 05:41:20 +1000 Subject: [PATCH 2/3] Adds shared base58 test vectors --- test/base58.js | 42 ++------- test/base58check.js | 85 ++++++----------- test/fixtures/base58.js | 198 ++++++++++++++++++++++++++++++++++++++++ 3 files changed, 234 insertions(+), 91 deletions(-) create mode 100644 test/fixtures/base58.js diff --git a/test/base58.js b/test/base58.js index 388cdd2..c5778e6 100644 --- a/test/base58.js +++ b/test/base58.js @@ -1,49 +1,27 @@ var assert = require('assert') var base58 = require('../').base58 -describe('base58', function() { - var evec, dvec - - beforeEach(function() { - // base58 encoded strings - evec = [ - '5HpHagT65TZzG1PH3CSu63k8DbpvD8s5ip4nEB3kEsreAbuatmU', // 0x00 WIF - '5HpHagT65TZzG1PH3CSu63k8DbpvD8s5ip4nEB3kEsreAnchuDf', // 0x01 WIF - '5HpHagT65TZzG1PH3CSu63k8DbpvD8s5ip4nEB3kEsreQyNNN1W', // 0x7f WIF - '1EHNa6Q4Jz2uvNExL497mE43ikXhwF6kZm', // uncompressed 0x01 address - '1FB8cZijTpRQp3HX8AEkNuQJBqApqfTcX7' // uncompressed 0x7f address - ] - - // decoded equivalent of above - dvec = [ - '8000000000000000000000000000000000000000000000000000000000000000000565fba7', - '800000000000000000000000000000000000000000000000000000000000000001a85aa87e', - '80000000000000000000000000000000000000000000000000000000000000007f64046be9', - '0091b24bf9f5288532960ac687abb035127b1d28a50074ffe0', - '009b7c46977b68474e12066a370b169ec6b9b026444d210d6e' - ].map(function(h) { - return new Buffer(h, 'hex') - }) - }) +var fixtures = require('./fixtures/base58') +describe('base58', function() { describe('decode', function() { it('decodes the test vectors', function() { - evec.forEach(function(x, i) { - var actual = base58.decode(x) - var expected = dvec[i] + fixtures.valid.forEach(function(f) { + var actual = base58.decode(f.encoded.string) + var expected = f.encoded.hex - assert.deepEqual(actual, expected) + assert.equal(actual.toString('hex'), expected) }) }) }) describe('encode', function() { it('encodes the test vectors', function() { - dvec.forEach(function(x, i) { - var actual = base58.encode(x) - var expected = evec[i] + fixtures.valid.forEach(function(f) { + var actual = base58.encode(new Buffer(f.encoded.hex, 'hex')) + var expected = f.encoded.string - assert.deepEqual(actual, expected) + assert.equal(actual, expected) }) }) }) diff --git a/test/base58check.js b/test/base58check.js index 318b1d9..110f988 100644 --- a/test/base58check.js +++ b/test/base58check.js @@ -1,75 +1,42 @@ var assert = require('assert') var base58check = require('../').base58check -describe('base58check', function() { - var evec, dvec - - beforeEach(function() { - function fromHex(h) { return new Buffer(h, 'hex') } - - // base58check encoded strings - evec = [ - '5HpHagT65TZzG1PH3CSu63k8DbpvD8s5ip4nEB3kEsreAbuatmU', // 0x00 WIF - '5HpHagT65TZzG1PH3CSu63k8DbpvD8s5ip4nEB3kEsreAnchuDf', // 0x01 WIF - '5HpHagT65TZzG1PH3CSu63k8DbpvD8s5ip4nEB3kEsreQyNNN1W', // 0x7f WIF - '1EHNa6Q4Jz2uvNExL497mE43ikXhwF6kZm', // uncompressed 0x01 address - '1FB8cZijTpRQp3HX8AEkNuQJBqApqfTcX7' // uncompressed 0x7f address - ] - - // decoded equivalent of above - dvec = [ - { - version: 0x80, - payload: '0000000000000000000000000000000000000000000000000000000000000000', - checksum: '0565fba7' - }, - { - version: 0x80, - payload: '0000000000000000000000000000000000000000000000000000000000000001', - checksum: 'a85aa87e', - }, - { - version: 0x80, - payload: '000000000000000000000000000000000000000000000000000000000000007f', - checksum: '64046be9', - }, - { - version: 0x00, - payload: '91b24bf9f5288532960ac687abb035127b1d28a5', - checksum: '0074ffe0', - }, - { - version: 0x00, - payload: '9b7c46977b68474e12066a370b169ec6b9b02644', - checksum: '4d210d6e' - } - ].map(function(x) { - return { - version: x.version, - payload: fromHex(x.payload), - checksum: fromHex(x.checksum) - } - }) - }) +var fixtures = require('./fixtures/base58') +describe('base58check', function() { describe('decode', function() { it('decodes the test vectors', function() { - evec.forEach(function(x, i) { - var actual = base58check.decode(x) - var expected = dvec[i] + fixtures.valid.forEach(function(f) { + var actual = base58check.decode(f.encoded.string) + var expected = f.decoded + + assert.deepEqual({ + version: actual.version, + payload: actual.payload.toString('hex'), + checksum: actual.checksum.toString('hex') + }, expected) + }) + }) - assert.deepEqual(actual, expected) + it('throws on invalid strings', function() { + fixtures.invalid.forEach(function(f) { + assert.throws(function() { + base58check.decode(f) + }) }) }) }) describe('encode', function() { it('encodes the test vectors', function() { - dvec.forEach(function(x, i) { - var actual = base58check.encode(x.payload, x.version) - var expected = evec[i] - - assert.deepEqual(actual, expected) + fixtures.valid.forEach(function(f) { + var actual = base58check.encode( + new Buffer(f.decoded.payload, 'hex'), + f.decoded.version + ) + var expected = f.encoded.string + + assert.equal(actual, expected) }) }) }) diff --git a/test/fixtures/base58.js b/test/fixtures/base58.js new file mode 100644 index 0000000..e9dfb8b --- /dev/null +++ b/test/fixtures/base58.js @@ -0,0 +1,198 @@ +module.exports = { + valid: [ + { + encoded: { + hex: '800000000000000000000000000000000000000000000000000000000000000001014671fc3f', + string: 'KwDiBf89QgGbjEhKnhXJuH7LrciVrZi3qYjgd9M7rFU73sVHnoWn' + }, + decoded: { + version: 128, + payload: '000000000000000000000000000000000000000000000000000000000000000101', + checksum: '4671fc3f' + } + }, + { + encoded: { + hex: '00751e76e8199196d454941c45d1b3a323f1433bd6510d1634', + string: '1BgGZ9tcN4rm9KBzDn7KprQz87SZ26SAMH' + }, + decoded: { + version: 0, + payload: '751e76e8199196d454941c45d1b3a323f1433bd6', + checksum: '510d1634' + } + }, + { + encoded: { + hex: '80000000000000000000000000000000007777777777777777777777777777777701f0845454', + string: 'KwDiBf89QgGbjEhKnhXJuH7UChJaB4ZGvCvAAf7taDvRnbQnjxps' + }, + decoded: { + version: 128, + payload: '000000000000000000000000000000007777777777777777777777777777777701', + checksum: 'f0845454' + } + }, + { + encoded: { + hex: '006b420cc35afb4d96ea118dbf1fc8ef4b0990798cb4f216d9', + string: '1An8RkWzqVF9GvpQFVX5AM4jpFe43eoPfe' + }, + decoded: { + version: 0, + payload: '6b420cc35afb4d96ea118dbf1fc8ef4b0990798c', + checksum: 'b4f216d9' + } + }, + { + encoded: { + hex: '80fffffffffffffffffffffffffffffffebaaedce6af48a03bbfd25e8cd036414001608f2ef0', + string: 'L5oLkpV3aqBjhki6LmvChTCV6odsp4SXM6FfU2Gppt5kFLaHLuZ9' + }, + decoded: { + version: 128, + payload: 'fffffffffffffffffffffffffffffffebaaedce6af48a03bbfd25e8cd036414001', + checksum: '608f2ef0' + } + }, + { + encoded: { + hex: '00adde4c73c7b9cee17da6c7b3e2b2eea1a0dcbe672c2b0787', + string: '1GrLCmVQXoyJXaPJQdqssNqwxvha1eUo2E' + }, + decoded: { + version: 0, + payload: 'adde4c73c7b9cee17da6c7b3e2b2eea1a0dcbe67', + checksum: '2c2b0787' + } + }, + { + encoded: { + hex: '806685bb38cf8d16d22741f00140622fccf3ab21fe6804d433140a4cf301e6b4dd01c5de2a2f', + string: 'Kzf11e3pDUh5ZRjcQKwvT3BeA25X5ErdccGatoTx8WJi6f49qzrr' + }, + decoded: { + version: 128, + payload: '6685bb38cf8d16d22741f00140622fccf3ab21fe6804d433140a4cf301e6b4dd01', + checksum: 'c5de2a2f' + } + }, + { + encoded: { + hex: '00cce94f5f00db418576b78c6a4dae2366fae89638d0b3efb8', + string: '1KgULoNDuBeHovVskY3MAfNFonzBMETt6B' + }, + decoded: { + version: 0, + payload: 'cce94f5f00db418576b78c6a4dae2366fae89638', + checksum: 'd0b3efb8' + } + }, + { + encoded: { + hex: 'ef00000000000000000000000000000000000000000000000000000000000000010184e38d1f', + string: 'cMahea7zqjxrtgAbB7LSGbcQUr1uX1ojuat9jZodMN87JcbXMTcA' + }, + decoded: { + version: 239, + payload: '000000000000000000000000000000000000000000000000000000000000000101', + checksum: '84e38d1f' + } + }, + { + encoded: { + hex: '6f751e76e8199196d454941c45d1b3a323f1433bd655c484e3', + string: 'mrCDrCybB6J1vRfbwM5hemdJz73FwDBC8r' + }, + decoded: { + version: 111, + payload: '751e76e8199196d454941c45d1b3a323f1433bd6', + checksum: '55c484e3' + } + }, + { + encoded: { + hex: 'ef0000000000000000000000000000000077777777777777777777777777777777014a7bd246', + string: 'cMahea7zqjxrtgAbB7LSGbcXpvbyqWexzF4dH5aQ5LaS3LRBaSUV' + }, + decoded: { + version: 239, + payload: '000000000000000000000000000000007777777777777777777777777777777701', + checksum: '4a7bd246' + } + }, + { + encoded: { + hex: '6f6b420cc35afb4d96ea118dbf1fc8ef4b0990798cc00f9280', + string: 'mqJ5iobyeWgQ43J1y4VSzGH4gFEkxw2dFV' + }, + decoded: { + version: 111, + payload: '6b420cc35afb4d96ea118dbf1fc8ef4b0990798c', + checksum: 'c00f9280' + } + }, + { + encoded: { + hex: 'effffffffffffffffffffffffffffffffebaaedce6af48a03bbfd25e8cd03641400143ef4bf2', + string: 'cWALDjUu1tszsCBMjBjL4mhYj2wHUWYDR8Q8aSjLKzjkW5eBtpzu' + }, + decoded: { + version: 239, + payload: 'fffffffffffffffffffffffffffffffebaaedce6af48a03bbfd25e8cd036414001', + checksum: '43ef4bf2' + } + }, + { + encoded: { + hex: '6fadde4c73c7b9cee17da6c7b3e2b2eea1a0dcbe670a342a51', + string: 'mwNHVpaPLqQZJgrv8CpFhJ4GpvJGumskXi' + }, + decoded: { + version: 111, + payload: 'adde4c73c7b9cee17da6c7b3e2b2eea1a0dcbe67', + checksum: '0a342a51' + } + }, + { + encoded: { + hex: 'ef6685bb38cf8d16d22741f00140622fccf3ab21fe6804d433140a4cf301e6b4dd0124df07e1', + string: 'cR1zUZ3feYPLisCsnjm3pMghnFNvjgxKgeR41DvTdcxiMQ4g9ZYC' + }, + decoded: { + version: 239, + payload: '6685bb38cf8d16d22741f00140622fccf3ab21fe6804d433140a4cf301e6b4dd01', + checksum: '24df07e1' + } + }, + { + encoded: { + hex: '6fcce94f5f00db418576b78c6a4dae2366fae8963831693070', + string: 'mzCRdrTCiD5Yb2yVU71izaaafnatCA4DCT' + }, + decoded: { + version: 111, + payload: 'cce94f5f00db418576b78c6a4dae2366fae89638', + checksum: '31693070' + } + } + ], + invalid: [ + 'fN2C5x86J', + 'BiLLNZvcHTJWoL', + 'MP3zZBT27cEeP4asJD', + 'kfjbP4kdqZcZ5tThHpxmgWQ8vk', + 'oM6DB1STJKkv9NtPs2vHer6yUBh', + 'wkC5tvzZHuKmnrWwVMioYueXCSx', + 'BoW61uTv9aHNZtfZzcGXMSJvuc3', + 'HhRv5VFtWmf6y28fWUC4WijZ6UV', + '2QPqahfnSzPRScGyaCSFL8JUZkar', + '2RpPJRJyxYz1MTShU2gV8Gy1oDdM', + '2p1tshmtxKWeovXFe68Qu6wNFNqg', + '2bYahuZyEDrw12USasbLdxGfkDH9', + '2Pfp453t1TEkj116QEDaW5hkmf3y', + '47aZqGXrM3XzEy5mWs3wC4guA7hJ', + 'BUaVB8rxkTyTPntSRV4sw32vLKUZS', + '2S7rqjHw5yypNZ7WrCCAr9HCQ9Va46WJnNb' + ] +} From 231ccdd721b6d233e104af50568816fa93e55cf3 Mon Sep 17 00:00:00 2001 From: Daniel Cousens Date: Sun, 20 Apr 2014 05:43:10 +1000 Subject: [PATCH 3/3] Now shares base58 data with Address base58 tests --- test/address.js | 4 +++- test/fixtures/address.js | 12 ------------ 2 files changed, 3 insertions(+), 13 deletions(-) diff --git a/test/address.js b/test/address.js index ba9a21f..25a541f 100644 --- a/test/address.js +++ b/test/address.js @@ -1,5 +1,7 @@ var assert = require('assert') var Address = require('..').Address + +var b58fixtures = require('./fixtures/base58') var fixtures = require('./fixtures/address') describe('Address', function() { @@ -19,7 +21,7 @@ describe('Address', function() { describe('fromBase58Check', function() { it('throws on invalid base58check', function() { - fixtures.malformed.forEach(function(f) { + b58fixtures.invalid.forEach(function(f) { assert.throws(function() { Address.fromBase58Check(f) }) diff --git a/test/fixtures/address.js b/test/fixtures/address.js index a4af18d..dd4fa28 100644 --- a/test/fixtures/address.js +++ b/test/fixtures/address.js @@ -26,17 +26,5 @@ module.exports = { hex: 'cd7b44d0b03f2d026d1e586d7ae18903b0d385f6', base58check: '2NByiBUaEXrhmqAsg7BbLpcQSAQs1EDwt5w' } - ], - malformed: [ - '45k2PvUfZw', - '8cVHMKGRJGMEVz', - 'AMPCMAGBmj9EE9oGED', - 'oJPsqvHTSFFWMcmNS3aDidZexw', - 'bpiuHmqwCdiHx4ASNLGvZeBw9taY', - '2ansc1MsREU2HetNdPGs2eHXTY16ircdyaH', - 'iTKsHH39ooQPFxzX6RFtjPESpQ1', - '4TU74v3jnoTZGV5UuJGcr7XRg7hU', - '2a3wk37F1YmfqVtBam4gEn63oNuj', - '3rtH2aquyk4q1KGaXuiMGxaGfVPH' ] }