bitcoinjs-lib/test/message.js

65 lines
2 KiB
JavaScript
Raw Normal View History

var assert = require('assert')
var networks = require('../src/networks')
2014-05-13 16:35:07 +10:00
2014-05-16 15:39:17 +10:00
var BigInteger = require('bigi')
var ECKey = require('../src/eckey')
var Message = require('../src/message')
2014-05-18 19:47:39 +10:00
var fixtures = require('./fixtures/message.json')
2014-04-21 21:24:58 +10:00
describe('Message', function() {
2014-04-21 21:24:58 +10:00
describe('magicHash', function() {
it('matches the test vectors', function() {
2014-05-22 13:22:59 +10:00
fixtures.valid.magicHash.forEach(function(f) {
2014-05-16 15:39:17 +10:00
var network = networks[f.network]
var actual = Message.magicHash(f.message, network)
2014-04-21 21:24:58 +10:00
2014-05-16 15:39:17 +10:00
assert.equal(actual.toString('hex'), f.magicHash)
2014-04-21 21:24:58 +10:00
})
})
})
describe('verify', function() {
2014-05-22 13:22:59 +10:00
it('verifies a valid signature', function() {
fixtures.valid.verify.forEach(function(f) {
var network = networks[f.network]
2014-05-24 13:54:46 +10:00
var signature = new Buffer(f.signature, 'base64')
assert.ok(Message.verify(f.address, signature, f.message, network))
2014-05-22 13:22:59 +10:00
if (f.compressed) {
2014-05-24 13:54:46 +10:00
var compressedSignature = new Buffer(f.compressed.signature, 'base64')
2014-05-24 13:54:46 +10:00
assert.ok(Message.verify(f.compressed.address, compressedSignature, f.message, network))
2014-05-22 13:22:59 +10:00
}
})
})
2014-05-16 15:39:17 +10:00
2014-05-22 13:22:59 +10:00
fixtures.invalid.verify.forEach(function(f) {
it(f.description, function() {
var signature = new Buffer(f.signature, 'base64')
assert.ok(!Message.verify(f.address, signature, f.message))
})
2014-05-16 15:39:17 +10:00
})
})
describe('signing', function() {
2014-05-22 13:22:59 +10:00
fixtures.valid.signing.forEach(function(f) {
it(f.description, function() {
var network = networks[f.network]
2014-05-24 13:54:46 +10:00
var privKey = new ECKey(new BigInteger(f.D), false)
var signature = Message.sign(privKey, f.message, network)
assert.equal(signature.toString('base64'), f.signature)
2014-05-16 15:39:17 +10:00
2014-05-22 13:22:59 +10:00
if (f.compressed) {
2014-05-24 13:54:46 +10:00
var compressedPrivKey = new ECKey(new BigInteger(f.D))
var compressedSignature = Message.sign(compressedPrivKey, f.message)
2014-05-16 15:39:17 +10:00
2014-05-24 13:54:46 +10:00
assert.equal(compressedSignature.toString('base64'), f.compressed.signature)
2014-05-22 13:22:59 +10:00
}
})
2014-05-16 15:39:17 +10:00
})
})
})