|
@ -1,21 +1,21 @@ |
|
|
/* global describe, it */ |
|
|
/* global describe, it */ |
|
|
|
|
|
|
|
|
var assert = require('assert') |
|
|
var assert = require('assert') |
|
|
|
|
|
var message = require('../src/message') |
|
|
var networks = require('../src/networks') |
|
|
var networks = require('../src/networks') |
|
|
|
|
|
|
|
|
var Address = require('../src/address') |
|
|
var Address = require('../src/address') |
|
|
var BigInteger = require('bigi') |
|
|
var BigInteger = require('bigi') |
|
|
var ECKey = require('../src/eckey') |
|
|
var ECKey = require('../src/eckey') |
|
|
var Message = require('../src/message') |
|
|
|
|
|
|
|
|
|
|
|
var fixtures = require('./fixtures/message.json') |
|
|
var fixtures = require('./fixtures/message.json') |
|
|
|
|
|
|
|
|
describe('Message', function () { |
|
|
describe('message', function () { |
|
|
describe('magicHash', function () { |
|
|
describe('magicHash', function () { |
|
|
fixtures.valid.magicHash.forEach(function (f) { |
|
|
fixtures.valid.magicHash.forEach(function (f) { |
|
|
it('produces the correct magicHash for "' + f.message + '" (' + f.network + ')', function () { |
|
|
it('produces the correct magicHash for \"' + f.message + '\" (' + f.network + ')', function () { |
|
|
var network = networks[f.network] |
|
|
var network = networks[f.network] |
|
|
var actual = Message.magicHash(f.message, network) |
|
|
var actual = message.magicHash(f.message, network) |
|
|
|
|
|
|
|
|
assert.equal(actual.toString('hex'), f.magicHash) |
|
|
assert.equal(actual.toString('hex'), f.magicHash) |
|
|
}) |
|
|
}) |
|
@ -28,24 +28,24 @@ describe('Message', function () { |
|
|
var network = networks[f.network] |
|
|
var network = networks[f.network] |
|
|
|
|
|
|
|
|
var address = Address.fromBase58Check(f.address) |
|
|
var address = Address.fromBase58Check(f.address) |
|
|
assert(Message.verify(address, f.signature, f.message, network)) |
|
|
assert(message.verify(address, f.signature, f.message, network)) |
|
|
}) |
|
|
}) |
|
|
|
|
|
|
|
|
fixtures.valid.verify.forEach(function (f) { |
|
|
fixtures.valid.verify.forEach(function (f) { |
|
|
it('verifies a valid signature for "' + f.message + '" (' + f.network + ')', function () { |
|
|
it('verifies a valid signature for "' + f.message + '" (' + f.network + ')', function () { |
|
|
var network = networks[f.network] |
|
|
var network = networks[f.network] |
|
|
|
|
|
|
|
|
assert(Message.verify(f.address, f.signature, f.message, network)) |
|
|
assert(message.verify(f.address, f.signature, f.message, network)) |
|
|
|
|
|
|
|
|
if (f.compressed) { |
|
|
if (f.compressed) { |
|
|
assert(Message.verify(f.compressed.address, f.compressed.signature, f.message, network)) |
|
|
assert(message.verify(f.compressed.address, f.compressed.signature, f.message, network)) |
|
|
} |
|
|
} |
|
|
}) |
|
|
}) |
|
|
}) |
|
|
}) |
|
|
|
|
|
|
|
|
fixtures.invalid.verify.forEach(function (f) { |
|
|
fixtures.invalid.verify.forEach(function (f) { |
|
|
it(f.description, function () { |
|
|
it(f.description, function () { |
|
|
assert(!Message.verify(f.address, f.signature, f.message)) |
|
|
assert(!message.verify(f.address, f.signature, f.message)) |
|
|
}) |
|
|
}) |
|
|
}) |
|
|
}) |
|
|
}) |
|
|
}) |
|
@ -56,12 +56,12 @@ describe('Message', function () { |
|
|
var network = networks[f.network] |
|
|
var network = networks[f.network] |
|
|
|
|
|
|
|
|
var privKey = new ECKey(new BigInteger(f.d), false) |
|
|
var privKey = new ECKey(new BigInteger(f.d), false) |
|
|
var signature = Message.sign(privKey, f.message, network) |
|
|
var signature = message.sign(privKey, f.message, network) |
|
|
assert.equal(signature.toString('base64'), f.signature) |
|
|
assert.equal(signature.toString('base64'), f.signature) |
|
|
|
|
|
|
|
|
if (f.compressed) { |
|
|
if (f.compressed) { |
|
|
var compressedPrivKey = new ECKey(new BigInteger(f.d)) |
|
|
var compressedPrivKey = new ECKey(new BigInteger(f.d)) |
|
|
var compressedSignature = Message.sign(compressedPrivKey, f.message) |
|
|
var compressedSignature = message.sign(compressedPrivKey, f.message) |
|
|
|
|
|
|
|
|
assert.equal(compressedSignature.toString('base64'), f.compressed.signature) |
|
|
assert.equal(compressedSignature.toString('base64'), f.compressed.signature) |
|
|
} |
|
|
} |
|
|