/* * Copyright (C) 2018 The ontology Authors * This file is part of The ontology library. * * The ontology is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * The ontology is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public License * along with The ontology. If not, see . */ import { Address, PrivateKey, } from '../../src/crypto'; import * as utils from '../../src/utils'; import { bigIntFromBytes, bigIntToBytes, randomBytes } from '../../src/utils'; // tslint:disable : no-console describe('test core', () => { let privateKey: PrivateKey; let wifKey: string; beforeAll(() => { privateKey = PrivateKey.random(); }); test('test getWIFFromPrivateKey', () => { const pri = new PrivateKey('e467a2a9c9f56b012c71cf2270df42843a9d7ff181934068b4a62bcdd570e8be'); wifKey = pri.serializeWIF(); // expect(wifKey).toBeDefined(); expect(wifKey).toEqual('L4shZ7B4NFQw2eqKncuUViJdFRq6uk1QUb6HjiuedxN4Q2CaRQKW'); }); test('test getPrivateKeyFromWIF', () => { const wif = 'L4shZ7B4NFQw2eqKncuUViJdFRq6uk1QUb6HjiuedxN4Q2CaRQKW'; const key = PrivateKey.deserializeWIF(wif); expect(key.key).toEqual('e467a2a9c9f56b012c71cf2270df42843a9d7ff181934068b4a62bcdd570e8be'); }); test('get public key', () => { const pk = privateKey.getPublicKey().serializeHex(); console.log('get pk: ' + pk); expect(pk).toBeDefined(); }); test('encrypt private key', () => { // tslint:disable-next-line:no-shadowed-variable const privateKey = new PrivateKey('b02304dcb35bc9a055147f07b2a3291db4ac52f664ec38b436470c98db4200d9'); const address = Address.fromPubKey(privateKey.getPublicKey()); const encrypt = privateKey.encrypt('123456', address, randomBytes(16)); console.log('encrypt: ' + encrypt.key); }); test('sign and verify', () => { // tslint:disable-next-line:no-shadowed-variable const privateKey = new PrivateKey('7c47df9664e7db85c1308c080f398400cb24283f5d922e76b478b5429e821b95'); const msg = utils.str2hexstr('helloworld'); console.log('msg: ' + msg); const signed = privateKey.sign(msg); console.log('signed: ' + signed.serializeHex()); console.log('base64: ' + new Buffer(signed.serializeHex(), 'hex').toString('base64')); const pk = privateKey.getPublicKey(); console.log('pub: ' + pk.serializeHex()); const verifyResult = pk.verify(msg, signed); console.log('verifyResult: ' + verifyResult); expect(verifyResult).toBeTruthy(); }); const BIG_INT_AND_HEX = [ ['0', ''], ['-1', 'ff'], ['-9175052165852779861', 'abaaaaaaaaaaab80'], ['1', '01'], ['120', '78'], ['128', '8000'], ['255', 'ff00'], ['-255', '01ff'], ['9223372036854775807', 'ffffffffffffff7f'], ['90123123981293054321', '71e975a9c4a7b5e204'], ['9175052165852779861', '555555555555547f'], ['-9223372036854775808', '0000000000000080'] ]; test('bigint to bytes', () => { BIG_INT_AND_HEX.forEach((testCase) => { expect(bigIntToBytes(testCase[0])).toEqual(testCase[1]); }); }); test('bigint from bytes', () => { BIG_INT_AND_HEX.forEach((testCase) => { expect(bigIntFromBytes(testCase[1])).toEqual(testCase[0]); }); }); });