2014-01-11 13:57:43 +07:00
|
|
|
/* global describe, it */
|
2013-02-17 00:39:15 -05:00
|
|
|
var assert = require('assert');
|
|
|
|
var sec = require('../src/jsbn/sec');
|
|
|
|
var ecdsa = require('../').ecdsa;
|
|
|
|
|
|
|
|
var ecparams = sec('secp256k1');
|
|
|
|
|
2014-01-11 13:57:43 +07:00
|
|
|
describe('ecdsa', function() {
|
2014-03-11 12:23:37 -07:00
|
|
|
it('handles point multiplication', function() {
|
2014-01-11 13:57:43 +07:00
|
|
|
var G = ecparams.getG();
|
|
|
|
var n = ecparams.getN();
|
2013-02-17 00:39:15 -05:00
|
|
|
|
2014-01-11 13:57:43 +07:00
|
|
|
assert.ok(G.multiply(n).isInfinity(), "Gn is infinite");
|
2013-02-17 00:39:15 -05:00
|
|
|
|
2014-01-11 13:57:43 +07:00
|
|
|
var k = ecdsa.getBigRandom(n);
|
|
|
|
var P = G.multiply(k);
|
|
|
|
assert.ok(!P.isInfinity(), "kG is not infinite");
|
|
|
|
assert.ok(P.isOnCurve(), "kG on curve");
|
|
|
|
assert.ok(P.multiply(n).isInfinity(), "kGn is infinite");
|
2013-02-17 00:39:15 -05:00
|
|
|
|
2014-01-11 13:57:43 +07:00
|
|
|
assert.ok(P.validate(), "kG validates as a public key");
|
|
|
|
})
|
|
|
|
})
|