From dca193be4eb7f0a66043bfbf9355c6dc9185856e Mon Sep 17 00:00:00 2001 From: Daniel Cousens Date: Tue, 3 Jun 2014 17:22:13 +1000 Subject: [PATCH] HDNode: adds neutered test examples --- test/hdnode.js | 33 +++++++++++++++++++++++++++++---- 1 file changed, 29 insertions(+), 4 deletions(-) diff --git a/test/hdnode.js b/test/hdnode.js index 59515fd..ecd4328 100644 --- a/test/hdnode.js +++ b/test/hdnode.js @@ -193,7 +193,7 @@ describe('HDNode', function() { describe('getAddress', function() { var f = fixtures.valid[0] - it('returns the Address (pubKeyHash) for ' + f.master.fingerprint, function() { + it('returns the Address (pubHash) for ' + f.master.fingerprint, function() { var hd = HDNode.fromBase58(f.master.base58) assert.equal(hd.getAddress().toString(), f.master.address) @@ -224,6 +224,7 @@ describe('HDNode', function() { fixtures.valid.forEach(function(f, j) { var hd = HDNode.fromSeedHex(f.master.seed) + // FIXME: test data is only testing Private -> private for now f.children.forEach(function(c, i) { it(c.description + ' from ' + f.master.fingerprint, function() { if (c.hardened) { @@ -238,7 +239,31 @@ describe('HDNode', function() { }) }) - it('works for public -> public', function() { + it('works for Private -> public (neutered)', function() { + var f = fixtures.valid[1] + var c = f.children[0] + + var parentNode = HDNode.fromBase58(f.master.base58Priv) + var child = parentNode.derive(c.m) + + // FIXME: N(CKDpriv((kpar, cpar), i)), could be done better... + var childNeutered = HDNode.fromBase58(child.toBase58(false)) // neuter + assert.equal(childNeutered.toBase58(), c.base58) + }) + + it('works for Private -> public (neutered, hardened)', function() { + var f = fixtures.valid[0] + var c = f.children[0] + + var parentNode = HDNode.fromBase58(f.master.base58Priv) + var child = parentNode.deriveHardened(c.m) + + // FIXME: N(CKDpriv((kpar, cpar), i)), could be done better... + var childNeutered = HDNode.fromBase58(child.toBase58(false)) // neuter + assert.equal(childNeutered.toBase58(), c.base58) + }) + + it('works for Public -> public', function() { var f = fixtures.valid[1] var c = f.children[0] @@ -248,8 +273,8 @@ describe('HDNode', function() { assert.equal(child.toBase58(), c.base58) }) - it('throws on public -> public (hardened)', function() { - var f = fixtures.valid[1] + it('throws on Public -> public (hardened)', function() { + var f = fixtures.valid[0] var c = f.children[0] var parentNode = HDNode.fromBase58(f.master.base58)