Browse Source

ECPubKey: improve tests and extract test data to fixtures

The use of fixtures allows for more behavioural driven tests and simpler
addition of more test cases in future.

However, as ECPubKey is just a wrapper around other strenuously tested
modules, the test data is currently limited to testing a subset of the
total wrapper.

This should probably be done better by using mocked out modules instead.
hk-custom-address
Daniel Cousens 11 years ago
parent
commit
bf109f32a9
  1. 159
      test/ecpubkey.js
  2. 19
      test/fixtures/ecpubkey.js

159
test/ecpubkey.js

@ -1,95 +1,104 @@
var assert = require('assert') var assert = require('assert')
var crypto = require('../src/crypto')
var sec = require('../src/sec')
var ecparams = sec('secp256k1')
var BigInteger = require('bigi')
var ECPointFp = require('../src/ec').ECPointFp
var ECPubKey = require('../src/ecpubkey') var ECPubKey = require('../src/ecpubkey')
var fixtures = require('./fixtures/ecpubkey')
describe('ECPubKey', function() { describe('ECPubKey', function() {
describe('toBuffer/toHex', function() { var Q
var hcpub = '024b12d9d7c77db68388b6ff7c89046174c871546436806bcd80d07c28ea811992'
var hpub = '044b12d9d7c77db68388b6ff7c89046174c871546436806bcd80d07c28ea81199283fbec990dad6fb98f93f712d50cb874dd717de6a184158d63886dda3090f566' beforeEach(function() {
var curve = ecparams.getCurve()
Q = new ECPointFp(
curve,
curve.fromBigInteger(new BigInteger(fixtures.Q.x)),
curve.fromBigInteger(new BigInteger(fixtures.Q.y))
)
})
describe('constructor', function() {
it('defaults to compressed', function() {
var pubKey = new ECPubKey(Q)
assert.equal(pubKey.compressed, true)
})
it('using toHex should support compression', function() { it('supports the uncompressed flag', function() {
var pub = ECPubKey.fromHex(hcpub) var pubKey = new ECPubKey(Q, false)
assert.equal(pub.toHex(), hcpub) assert.equal(pubKey.compressed, false)
assert.equal(pub.compressed, true) })
})
describe('fromHex/toHex', function() {
it('supports compressed points', function() {
var pubKey = ECPubKey.fromHex(fixtures.compressed.hex)
assert(pubKey.Q.equals(Q))
assert.equal(pubKey.toHex(), fixtures.compressed.hex)
assert.equal(pubKey.compressed, true)
}) })
it('using toHex should support uncompressed', function() { it('supports uncompressed points', function() {
var pub = ECPubKey.fromHex(hpub) var pubKey = ECPubKey.fromHex(fixtures.uncompressed.hex)
assert.equal(pub.toHex(), hpub) assert(pubKey.Q.equals(Q))
assert.equal(pub.compressed, false) assert.equal(pubKey.toHex(), fixtures.uncompressed.hex)
assert.equal(pubKey.compressed, false)
}) })
}) })
describe('getAddress', function() { describe('getAddress', function() {
var privkeys = [ it('calculates the expected hash (compressed)', function() {
'ca48ec9783cf3ad0dfeff1fc254395a2e403cbbc666477b61b45e31d3b8ab458', var pubKey = new ECPubKey(Q, true)
'1111111111111111111111111111111111111111111111111111111111111111', var address = pubKey.getAddress()
'18e14a7b6a307f426a94f8114701e7c8e774e7f9a47e2c2035db29a206321725'
] assert.equal(address.hash.toString('hex'), fixtures.compressed.hash160)
// compressed pubkeys
var cpubkeys = [
'024b12d9d7c77db68388b6ff7c89046174c871546436806bcd80d07c28ea811992',
'034f355bdcb7cc0af728ef3cceb9615d90684bb5b2ca5f859ab0f0b704075871aa',
'0250863ad64a87ae8a2fe83c1af1a8403cb53f53e486d8511dad8a04887e5b2352'
]
var pubkeys = cpubkeys.map(function(x) {
var pk = ECPubKey.fromHex(x)
pk.compressed = false
return pk.toHex()
})
it('bitcoin', function() {
var addresses = [
'19SgmoUj4xowEjwtXvNAtYTAgbvR9iBCui',
'1MsHWS1BnwMc3tLE8G35UXsS58fKipzB7a',
'16UwLL9Risc3QfPqBUvKofHmBQ7wMtjvM'
]
var compressedAddresses = [
'1AA4sjKW2aUmbtN3MtegdvhYtDBbDEke1q',
'1Q1pE5vPGEEMqRcVRMbtBK842Y6Pzo6nK9',
'1PMycacnJaSqwwJqjawXBErnLsZ7RkXUAs',
]
for (var i = 0; i < addresses.length; ++i) {
var pub = ECPubKey.fromHex(pubkeys[i])
var cpub = ECPubKey.fromHex(cpubkeys[i])
cpub.compressed = true
var addr = addresses[i]
var caddr = compressedAddresses[i]
assert.equal(pub.getAddress().toString(), addr)
assert.equal(cpub.getAddress().toString(), caddr)
}
}) })
it('testnet', function() { it('calculates the expected hash (uncompressed)', function() {
var addresses = [ var pubKey = new ECPubKey(Q, false)
'19SgmoUj4xowEjwtXvNAtYTAgbvR9iBCui', var address = pubKey.getAddress()
'1MsHWS1BnwMc3tLE8G35UXsS58fKipzB7a',
'16UwLL9Risc3QfPqBUvKofHmBQ7wMtjvM' assert.equal(address.hash.toString('hex'), fixtures.uncompressed.hash160)
] })
var compressedAddresses = [
'1AA4sjKW2aUmbtN3MtegdvhYtDBbDEke1q', it('supports alternative networks', function() {
'1Q1pE5vPGEEMqRcVRMbtBK842Y6Pzo6nK9', var pubKey = new ECPubKey(Q)
'1PMycacnJaSqwwJqjawXBErnLsZ7RkXUAs', var address = pubKey.getAddress(0x09)
]
assert.equal(address.version, 0x09)
for (var i = 0; i < addresses.length; ++i) { assert.equal(address.hash.toString('hex'), fixtures.compressed.hash160)
var pub = ECPubKey.fromHex(pubkeys[i]) })
var cpub = ECPubKey.fromHex(cpubkeys[i]) })
cpub.compressed = true
describe('verify', function() {
var addr = addresses[i] var pubKey, signature
var caddr = compressedAddresses[i] beforeEach(function() {
pubKey = new ECPubKey(Q)
assert.equal(pub.getAddress().toString(), addr)
assert.equal(cpub.getAddress().toString(), caddr) signature = {
r: new BigInteger(fixtures.signature.r),
s: new BigInteger(fixtures.signature.s)
} }
}) })
it('verifies a valid signature', function() {
var hash = crypto.sha256(fixtures.message)
assert.ok(pubKey.verify(hash, signature))
})
it('doesn\'t verify the wrong signature', function() {
var hash = crypto.sha256('mushrooms')
assert.ok(!pubKey.verify(hash, signature))
})
}) })
}) })

19
test/fixtures/ecpubkey.js

@ -0,0 +1,19 @@
module.exports = {
"Q": {
"x": "55066263022277343669578718895168534326250603453777594175500187360389116729240",
"y": "32670510020758816978083085130507043184471273380659243275938904335757337482424"
},
"compressed": {
"hex": "0279be667ef9dcbbac55a06295ce870b07029bfcdb2dce28d959f2815b16f81798",
"hash160": "751e76e8199196d454941c45d1b3a323f1433bd6"
},
"uncompressed": {
"hex": "0479be667ef9dcbbac55a06295ce870b07029bfcdb2dce28d959f2815b16f81798483ada7726a3c4655da4fbfc0e1108a8fd17b448a68554199c47d08ffb10d4b8",
"hash160": "91b24bf9f5288532960ac687abb035127b1d28a5"
},
"message": "vires in numeris",
"signature": {
"r": "68972263025625296948424563184904289678530916807200550828762374724416876919710",
"s": "43478152510424186005054433052302509227777805602212468112169549534899266476898"
}
}
Loading…
Cancel
Save