add remaining public key derivation test vectors

...all pass in node and the browser.
This commit is contained in:
Ryan X. Charles 2014-03-28 16:29:12 -04:00
parent c03d3c5818
commit 0eedeed449
1 changed files with 45 additions and 1 deletions

View File

@ -94,7 +94,6 @@ describe('BIP32', function() {
}); });
it("should get m/0'/1 ext. public key from m/0' public key from test vector 1", function() { it("should get m/0'/1 ext. public key from m/0' public key from test vector 1", function() {
//TEST
var bip32 = new BIP32(vector1_m_private); var bip32 = new BIP32(vector1_m_private);
var child = bip32.derive("m/0'"); var child = bip32.derive("m/0'");
var child_pub = new BIP32(child.extendedPublicKeyString()); var child_pub = new BIP32(child.extendedPublicKeyString());
@ -124,6 +123,15 @@ describe('BIP32', function() {
child.extendedPrivateKeyString().should.equal(vector1_m0h12h2_private); child.extendedPrivateKeyString().should.equal(vector1_m0h12h2_private);
}); });
it("should get m/0'/1/2'/2 ext. public key from m/0'/1/2' public key from test vector 1", function() {
var bip32 = new BIP32(vector1_m_private);
var child = bip32.derive("m/0'/1/2'");
var child_pub = new BIP32(child.extendedPublicKeyString());
var child2 = child_pub.derive("m/2");
should.exist(child2);
child2.extendedPublicKeyString().should.equal(vector1_m0h12h2_public);
});
it("should get m/0'/1/2h/2 ext. public key from test vector 1", function() { it("should get m/0'/1/2h/2 ext. public key from test vector 1", function() {
var bip32 = new BIP32(vector1_m_private); var bip32 = new BIP32(vector1_m_private);
var child = bip32.derive("m/0'/1/2'/2"); var child = bip32.derive("m/0'/1/2'/2");
@ -145,6 +153,15 @@ describe('BIP32', function() {
child.extendedPublicKeyString().should.equal(vector1_m0h12h21000000000_public); child.extendedPublicKeyString().should.equal(vector1_m0h12h21000000000_public);
}); });
it("should get m/0'/1/2'/2/1000000000 ext. public key from m/0'/1/2'/2 public key from test vector 1", function() {
var bip32 = new BIP32(vector1_m_private);
var child = bip32.derive("m/0'/1/2'/2");
var child_pub = new BIP32(child.extendedPublicKeyString());
var child2 = child_pub.derive("m/1000000000");
should.exist(child2);
child2.extendedPublicKeyString().should.equal(vector1_m0h12h21000000000_public);
});
it('should initialize test vector 2 from the extended public key', function() { it('should initialize test vector 2 from the extended public key', function() {
var bip32 = new BIP32(vector2_m_public); var bip32 = new BIP32(vector2_m_public);
should.exist(bip32); should.exist(bip32);
@ -174,6 +191,15 @@ describe('BIP32', function() {
child.extendedPublicKeyString().should.equal(vector2_m0_public); child.extendedPublicKeyString().should.equal(vector2_m0_public);
}); });
it("should get m/0 ext. public key from m public key from test vector 2", function() {
var bip32 = new BIP32(vector2_m_private);
var child = bip32.derive("m");
var child_pub = new BIP32(child.extendedPublicKeyString());
var child2 = child_pub.derive("m/0");
should.exist(child2);
child2.extendedPublicKeyString().should.equal(vector2_m0_public);
});
it("should get m/0/2147483647h ext. private key from test vector 2", function() { it("should get m/0/2147483647h ext. private key from test vector 2", function() {
var bip32 = new BIP32(vector2_m_private); var bip32 = new BIP32(vector2_m_private);
var child = bip32.derive("m/0/2147483647'"); var child = bip32.derive("m/0/2147483647'");
@ -202,6 +228,15 @@ describe('BIP32', function() {
child.extendedPublicKeyString().should.equal(vector2_m02147483647h1_public); child.extendedPublicKeyString().should.equal(vector2_m02147483647h1_public);
}); });
it("should get m/0/2147483647h/1 ext. public key from m/0/2147483647h public key from test vector 2", function() {
var bip32 = new BIP32(vector2_m_private);
var child = bip32.derive("m/0/2147483647'");
var child_pub = new BIP32(child.extendedPublicKeyString());
var child2 = child_pub.derive("m/1");
should.exist(child2);
child2.extendedPublicKeyString().should.equal(vector2_m02147483647h1_public);
});
it("should get m/0/2147483647h/1/2147483646h ext. private key from test vector 2", function() { it("should get m/0/2147483647h/1/2147483646h ext. private key from test vector 2", function() {
var bip32 = new BIP32(vector2_m_private); var bip32 = new BIP32(vector2_m_private);
var child = bip32.derive("m/0/2147483647'/1/2147483646'"); var child = bip32.derive("m/0/2147483647'/1/2147483646'");
@ -230,4 +265,13 @@ describe('BIP32', function() {
child.extendedPublicKeyString().should.equal(vector2_m02147483647h12147483646h2_public); child.extendedPublicKeyString().should.equal(vector2_m02147483647h12147483646h2_public);
}); });
it("should get m/0/2147483647h/1/2147483646h/2 ext. public key from m/0/2147483647h/2147483646h public key from test vector 2", function() {
var bip32 = new BIP32(vector2_m_private);
var child = bip32.derive("m/0/2147483647'/1/2147483646'");
var child_pub = new BIP32(child.extendedPublicKeyString());
var child2 = child_pub.derive("m/2");
should.exist(child2);
child2.extendedPublicKeyString().should.equal(vector2_m02147483647h12147483646h2_public);
});
}); });