react / wstein / node_modules / browserify / node_modules / crypto-browserify / node_modules / browserify-sign / node_modules / elliptic / test / ecdsa-test.js
80559 viewsvar assert = require('assert');1var elliptic = require('../');2var hash = require('hash.js');34describe('ECDSA', function() {5function test(name) {6it('should work with ' + name + ' curve', function() {7var curve = elliptic.curves[name];8assert(curve);910var ecdsa = new elliptic.ec(curve);11var keys = ecdsa.genKeyPair({12entropy: [131, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20,1421, 22, 23, 24, 2515]16});17var msg = 'deadbeef';1819// Get keys out of pair20assert(keys.getPublic().x && keys.getPublic().y);21assert(keys.getPrivate().length > 0);22assert.equal(keys.getPrivate('hex').length, 64);23assert(keys.getPublic('hex').length > 0);24assert(keys.getPrivate('hex').length > 0);25assert(keys.validate().result);2627// Sign and verify28var signature = ecdsa.sign(msg, keys);29assert(ecdsa.verify(msg, signature, keys), 'Normal verify');3031// Sign and verify on key32var signature = keys.sign(msg);33assert(keys.verify(msg, signature), 'On-key verify');3435// Load private key from hex36var keys = ecdsa.keyFromPrivate(keys.getPrivate('hex'), 'hex');37var signature = ecdsa.sign(msg, keys);38assert(ecdsa.verify(msg, signature, keys), 'hex-private verify');3940// Load public key from compact hex41var keys = ecdsa.keyFromPublic(keys.getPublic(true, 'hex'), 'hex');4243// Load public key from hex44var keys = ecdsa.keyFromPublic(keys.getPublic('hex'), 'hex');4546// DER encoding47var dsign = signature.toDER('hex');48assert(ecdsa.verify(msg, dsign, keys), 'hex-DER encoded verify');49var dsign = signature.toDER();50assert(ecdsa.verify(msg, dsign, keys), 'DER encoded verify');5152// Wrong public key53var keys = ecdsa.genKeyPair();54assert(!ecdsa.verify(msg, signature, keys), 'Wrong key verify');5556// Invalid private key57var keys = ecdsa.keyFromPrivate(keys.getPrivate('hex') +58keys.getPrivate('hex'));59assert(!ecdsa.verify(msg, signature, keys), 'Wrong key verify');60});61}62test('secp256k1');63test('ed25519');6465describe('RFC6979 vector', function() {66function test(opt) {67opt.cases.forEach(function(c) {68var ecdsa = elliptic.ec({69curve: opt.curve,70hash: c.hash71});72var descr = 'should not fail on "' + opt.name + '" ' +73'and hash ' + c.hash.name + ' on "' + c.message + '"';74it(descr, function() {75var dgst = c.hash().update(c.message).digest();76var sign = ecdsa.sign(dgst, opt.key);77assert.equal(sign.r.toString(16), c.r);78assert.equal(sign.s.toString(16), c.s);79assert.ok(ecdsa.keyFromPublic(opt.pub).validate().result,80'Invalid public key');81assert.ok(ecdsa.verify(dgst, sign, opt.pub),82'Invalid signature');83});84});85}8687test({88name: 'ECDSA, 192 Bits (Prime Field)',89curve: elliptic.curves.p192,90key: '6fab034934e4c0fc9ae67f5b5659a9d7d1fefd187ee09fd4',91pub: {92x: 'ac2c77f529f91689fea0ea5efec7f210d8eea0b9e047ed56',93y: '3bc723e57670bd4887ebc732c523063d0a7c957bc97c1c43'94},95cases: [96{97message: 'sample',98hash: hash.sha224,99r: 'a1f00dad97aeec91c95585f36200c65f3c01812aa60378f5',100s: 'e07ec1304c7c6c9debbe980b9692668f81d4de7922a0f97a'101},102{103message: 'sample',104hash: hash.sha256,105r: '4b0b8ce98a92866a2820e20aa6b75b56382e0f9bfd5ecb55',106s: 'ccdb006926ea9565cbadc840829d8c384e06de1f1e381b85'107},108{109message: 'test',110hash: hash.sha224,111r: '6945a1c1d1b2206b8145548f633bb61cef04891baf26ed34',112s: 'b7fb7fdfc339c0b9bd61a9f5a8eaf9be58fc5cba2cb15293'113},114{115message: 'test',116hash: hash.sha256,117r: '3a718bd8b4926c3b52ee6bbe67ef79b18cb6eb62b1ad97ae',118s: '5662e6848a4a19b1f1ae2f72acd4b8bbe50f1eac65d9124f'119}120],121});122123test({124name: 'ECDSA, 224 Bits (Prime Field)',125curve: elliptic.curves.p224,126key: 'f220266e1105bfe3083e03ec7a3a654651f45e37167e88600bf257c1',127pub: {128x: '00cf08da5ad719e42707fa431292dea11244d64fc51610d94b130d6c',129y: 'eeab6f3debe455e3dbf85416f7030cbd94f34f2d6f232c69f3c1385a'130},131cases: [132{133message: 'sample',134hash: hash.sha224,135r: '1cdfe6662dde1e4a1ec4cdedf6a1f5a2fb7fbd9145c12113e6abfd3e',136s: 'a6694fd7718a21053f225d3f46197ca699d45006c06f871808f43ebc'137},138{139message: 'sample',140hash: hash.sha256,141r: '61aa3da010e8e8406c656bc477a7a7189895e7e840cdfe8ff42307ba',142s: 'bc814050dab5d23770879494f9e0a680dc1af7161991bde692b10101'143},144{145message: 'test',146hash: hash.sha224,147r: 'c441ce8e261ded634e4cf84910e4c5d1d22c5cf3b732bb204dbef019',148s: '902f42847a63bdc5f6046ada114953120f99442d76510150f372a3f4'149},150{151message: 'test',152hash: hash.sha256,153r: 'ad04dde87b84747a243a631ea47a1ba6d1faa059149ad2440de6fba6',154s: '178d49b1ae90e3d8b629be3db5683915f4e8c99fdf6e666cf37adcfd'155}156],157});158159test({160name: 'ECDSA, 256 Bits (Prime Field)',161curve: elliptic.curves.p256,162key: 'c9afa9d845ba75166b5c215767b1d6934e50c3db36e89b127b8a622b120f6721',163pub: {164x: '60fed4ba255a9d31c961eb74c6356d68c049b8923b61fa6ce669622e60f29fb6',165y: '7903fe1008b8bc99a41ae9e95628bc64f2f1b20c2d7e9f5177a3c294d4462299'166},167cases: [168{169message: 'sample',170hash: hash.sha224,171r: '53b2fff5d1752b2c689df257c04c40a587fababb3f6fc2702f1343af7ca9aa3f',172s: 'b9afb64fdc03dc1a131c7d2386d11e349f070aa432a4acc918bea988bf75c74c'173},174{175message: 'sample',176hash: hash.sha256,177r: 'efd48b2aacb6a8fd1140dd9cd45e81d69d2c877b56aaf991c34d0ea84eaf3716',178s: 'f7cb1c942d657c41d436c7a1b6e29f65f3e900dbb9aff4064dc4ab2f843acda8'179},180{181message: 'test',182hash: hash.sha224,183r: 'c37edb6f0ae79d47c3c27e962fa269bb4f441770357e114ee511f662ec34a692',184s: 'c820053a05791e521fcaad6042d40aea1d6b1a540138558f47d0719800e18f2d'185},186{187message: 'test',188hash: hash.sha256,189r: 'f1abb023518351cd71d881567b1ea663ed3efcf6c5132b354f28d3b0b7d38367',190s: '19f4113742a2b14bd25926b49c649155f267e60d3814b4c0cc84250e46f0083'191}192],193});194});195196it('should deterministically generate private key', function() {197var curve = elliptic.curves.secp256k1;198assert(curve);199200var ecdsa = new elliptic.ec(curve);201var keys = ecdsa.genKeyPair({202pers: 'my.pers.string',203entropy: hash.sha256().update('hello world').digest()204});205assert.equal(206keys.getPrivate('hex'),207'6160edb2b218b7f1394b9ca8eb65a72831032a1f2f3dc2d99291c2f7950ed887');208});209});210211212