react / wstein / node_modules / browserify / node_modules / crypto-browserify / node_modules / browserify-sign / node_modules / elliptic / test / curve-test.js
80559 viewsvar assert = require('assert');1var bn = require('bn.js');2var elliptic = require('../');34describe('Curve', function() {5it('should work with example curve', function() {6var curve = new elliptic.curve.short({7p: '1d',8a: '4',9b: '14'10});1112var p = curve.point('18', '16');13assert(p.validate());14assert(p.dbl().validate());15assert(p.dbl().add(p).validate());16assert(p.dbl().add(p.dbl()).validate());17assert(p.dbl().add(p.dbl()).eq(p.add(p).add(p).add(p)));18});1920it('should work with secp112k1', function() {21var curve = new elliptic.curve.short({22p: 'db7c 2abf62e3 5e668076 bead208b',23a: 'db7c 2abf62e3 5e668076 bead2088',24b: '659e f8ba0439 16eede89 11702b22'25});2627var p = curve.point(28'0948 7239995a 5ee76b55 f9c2f098',29'a89c e5af8724 c0a23e0e 0ff77500');30assert(p.validate());31assert(p.dbl().validate());32});3334it('should work with secp256k1', function() {35var curve = new elliptic.curve.short({36p: 'ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff fffffffe ' +37'fffffc2f',38a: '0',39b: '7',40n: 'ffffffff ffffffff ffffffff fffffffe ' +41'baaedce6 af48a03b bfd25e8c d0364141',42g: [43'79be667ef9dcbbac55a06295ce870b07029bfcdb2dce28d959f2815b16f81798',44'483ada7726a3c4655da4fbfc0e1108a8fd17b448a68554199c47d08ffb10d4b8'45]46});4748var p = curve.point(49'79be667e f9dcbbac 55a06295 ce870b07 029bfcdb 2dce28d9 59f2815b 16f81798',50'483ada77 26a3c465 5da4fbfc 0e1108a8 fd17b448 a6855419 9c47d08f fb10d4b8'51);52assert(p.validate());53assert(p.dbl().validate());54assert(p.toJ().dbl().toP().validate());55assert(p.mul(new bn('79be667e f9dcbbac 55a06295 ce870b07', 16)).validate());5657var j = p.toJ();58assert(j.trpl().eq(j.dbl().add(j)));5960// Endomorphism test61assert(curve.endo);62assert.equal(63curve.endo.beta.fromRed().toString(16),64'7ae96a2b657c07106e64479eac3434e99cf0497512f58995c1396c28719501ee');65assert.equal(66curve.endo.lambda.toString(16),67'5363ad4cc05c30e0a5261c028812645a122e22ea20816678df02967c1b23bd72');6869var k = new bn('1234567890123456789012345678901234', 16);70var split = curve._endoSplit(k);71assert.equal(72split.k1.add(split.k2.mul(curve.endo.lambda)).mod(curve.n).toString(16),73k.toString(16));74});7576it('should compute this problematic secp256k1 multiplication', function() {77var curve = elliptic.curves.secp256k1.curve;78var g1 = curve.g; // precomputed g79assert(g1.precomputed);80var g2 = curve.point(g1.getX(), g1.getY()); // not precomputed g81assert(!g2.precomputed);82var a = new bn('6d1229a6b24c2e775c062870ad26bc261051e0198c67203167273c7c62538846', 16);83var p1 = g1.mul(a);84var p2 = g2.mul(a);85assert(p1.eq(p2));86});8788it('should not fail on secp256k1 regression', function() {89var curve = elliptic.curves.secp256k1.curve;90var k1 = new bn('32efeba414cd0c830aed727749e816a01c471831536fd2fce28c56b54f5a3bb1', 16);91var k2 = new bn('5f2e49b5d64e53f9811545434706cde4de528af97bfd49fde1f6cf792ee37a8c', 16);9293var p1 = curve.g.mul(k1);94var p2 = curve.g.mul(k2);9596// 2 + 2 + 1 = 2 + 1 + 297var two = p2.dbl();98var five = two.dbl().add(p2);99var three = two.add(p2);100var maybeFive = three.add(two);101102assert(maybeFive.eq(five));103104p1 = p1.mul(k2);105p2 = p2.mul(k1);106107assert(p1.validate());108assert(p2.validate());109assert(p1.eq(p2));110});111112it('should correctly double the affine point on secp256k1', function() {113var bad = {114x: '026a2073b1ef6fab47ace18e60e728a05180a82755bbcec9a0abc08ad9f7a3d4',115y: '9cd8cb48c3281596139f147c1364a3ede88d3f310fdb0eb98c924e599ca1b3c9',116z: 'd78587ad45e4102f48b54b5d85598296e069ce6085002e169c6bad78ddc6d9bd'117};118119var good = {120x: 'e7789226739ac2eb3c7ccb2a9a910066beeed86cdb4e0f8a7fee8eeb29dc7016',121y: '4b76b191fd6d47d07828ea965e275b76d0e3e0196cd5056d38384fbb819f9fcb',122z: 'cbf8d99056618ba132d6145b904eee1ce566e0feedb9595139c45f84e90cfa7d'123};124125var curve = elliptic.curves.secp256k1.curve;126bad = curve.jpoint(bad.x, bad.y, bad.z);127good = curve.jpoint(good.x, good.y, good.z);128129// They are the same points130assert(bad.add(good.neg()).isInfinity());131132// But doubling borks them out133assert(bad.dbl().add(good.dbl().neg()).isInfinity());134});135136it('should store precomputed values correctly on negation', function() {137var curve = elliptic.curves.secp256k1.curve;138var p = curve.g.mul('2');139p.precompute();140var neg = p.neg(true);141var neg2 = neg.neg(true);142assert(p.eq(neg2));143});144});145146147