PHP WebShell

Текущая директория: /opt/BitGoJS/modules/sdk-coin-icp/dist/test/unit

Просмотр файла: keyPair.js

"use strict";
var __importDefault = (this && this.__importDefault) || function (mod) {
    return (mod && mod.__esModule) ? mod : { "default": mod };
};
Object.defineProperty(exports, "__esModule", { value: true });
const should_1 = __importDefault(require("should"));
const keyPair_1 = require("../../src/lib/keyPair");
const crypto_1 = require("crypto");
describe('ICP KeyPair', () => {
    describe('constructor', () => {
        it('should generate a key pair with a random seed when no source is provided', () => {
            const keyPair = new keyPair_1.KeyPair();
            should_1.default.exist(keyPair);
            const publicKey = keyPair.getKeys().pub;
            const privateKey = keyPair.getKeys().prv;
            should_1.default.exist(publicKey);
            should_1.default.exist(privateKey);
            publicKey.should.be.a.String();
            if (privateKey) {
                privateKey.should.be.a.String();
            }
        });
        it('should generate a key pair from a given seed', () => {
            const seed = (0, crypto_1.randomBytes)(32);
            const keyPair = new keyPair_1.KeyPair({ seed });
            should_1.default.exist(keyPair);
            const publicKey = keyPair.getKeys().pub;
            const privateKey = keyPair.getKeys().prv;
            should_1.default.exist(publicKey);
            should_1.default.exist(privateKey);
            publicKey.should.be.a.String();
            if (privateKey) {
                privateKey.should.be.a.String();
            }
        });
        it('should generate a key pair from a public key', () => {
            const tempKeyPair = new keyPair_1.KeyPair();
            const publicKey = tempKeyPair.getKeys().pub;
            const keyPair = new keyPair_1.KeyPair({ pub: publicKey });
            should_1.default.exist(keyPair);
            should_1.default.exist(keyPair.getKeys().pub);
            should_1.default.equal(keyPair.getKeys().pub, publicKey);
        });
        it('should generate different key pairs for different seeds', () => {
            const seed1 = (0, crypto_1.randomBytes)(32);
            const seed2 = (0, crypto_1.randomBytes)(32);
            const keyPair1 = new keyPair_1.KeyPair({ seed: seed1 });
            const keyPair2 = new keyPair_1.KeyPair({ seed: seed2 });
            should_1.default.notEqual(keyPair1.getKeys().pub, keyPair2.getKeys().pub);
            should_1.default.notEqual(keyPair1.getKeys().prv, keyPair2.getKeys().prv);
        });
        it('should generate the same key pair for the same seed', () => {
            const seed = (0, crypto_1.randomBytes)(32);
            const keyPair1 = new keyPair_1.KeyPair({ seed });
            const keyPair2 = new keyPair_1.KeyPair({ seed });
            should_1.default.equal(keyPair1.getKeys().pub, keyPair2.getKeys().pub);
            should_1.default.equal(keyPair1.getKeys().prv, keyPair2.getKeys().prv);
        });
    });
    describe('KeyPair getKeys()', () => {
        it('should return valid public and private keys for a randomly generated key pair', () => {
            const keyPair = new keyPair_1.KeyPair();
            const keys = keyPair.getKeys();
            should_1.default.exist(keys);
            should_1.default.exist(keys.pub);
            should_1.default.exist(keys.prv);
            keys.pub.should.be.a.String();
            keys.pub.length.should.be.greaterThan(0);
            if (keys.prv) {
                keys.prv.should.be.a.String();
                keys.prv.length.should.be.greaterThan(0);
            }
        });
        it('should return valid public and private keys for a key pair generated with a seed', () => {
            const seed = (0, crypto_1.randomBytes)(32);
            const keyPair = new keyPair_1.KeyPair({ seed });
            const keys = keyPair.getKeys();
            should_1.default.exist(keys);
            should_1.default.exist(keys.pub);
            should_1.default.exist(keys.prv);
            keys.pub.should.be.a.String();
            if (keys.prv) {
                keys.prv.should.be.a.String();
            }
        });
        it('should return only a public key when a key pair is generated from a public key', () => {
            const tempKeyPair = new keyPair_1.KeyPair();
            const publicKey = tempKeyPair.getKeys().pub;
            const keyPair = new keyPair_1.KeyPair({ pub: publicKey });
            const keys = keyPair.getKeys();
            should_1.default.exist(keys);
            should_1.default.exist(keys.pub);
            should_1.default.equal(keys.pub, publicKey);
            should_1.default.not.exist(keys.prv);
        });
        it('should generate consistent keys for the same seed', () => {
            const seed = (0, crypto_1.randomBytes)(32);
            const keyPair1 = new keyPair_1.KeyPair({ seed });
            const keyPair2 = new keyPair_1.KeyPair({ seed });
            const keys1 = keyPair1.getKeys();
            const keys2 = keyPair2.getKeys();
            should_1.default.equal(keys1.pub, keys2.pub);
            should_1.default.equal(keys1.prv, keys2.prv);
        });
    });
});
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"keyPair.js","sourceRoot":"","sources":["../../../test/unit/keyPair.ts"],"names":[],"mappings":"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","sourcesContent":["import should from 'should';\nimport { KeyPair } from '../../src/lib/keyPair';\nimport { randomBytes } from 'crypto';\n\ndescribe('ICP KeyPair', () => {\n  describe('constructor', () => {\n    it('should generate a key pair with a random seed when no source is provided', () => {\n      const keyPair = new KeyPair();\n      should.exist(keyPair);\n      const publicKey = keyPair.getKeys().pub;\n      const privateKey = keyPair.getKeys().prv;\n      should.exist(publicKey);\n      should.exist(privateKey);\n      publicKey.should.be.a.String();\n      if (privateKey) {\n        privateKey.should.be.a.String();\n      }\n    });\n\n    it('should generate a key pair from a given seed', () => {\n      const seed = randomBytes(32);\n      const keyPair = new KeyPair({ seed });\n      should.exist(keyPair);\n      const publicKey = keyPair.getKeys().pub;\n      const privateKey = keyPair.getKeys().prv;\n      should.exist(publicKey);\n      should.exist(privateKey);\n      publicKey.should.be.a.String();\n      if (privateKey) {\n        privateKey.should.be.a.String();\n      }\n    });\n\n    it('should generate a key pair from a public key', () => {\n      const tempKeyPair = new KeyPair();\n      const publicKey = tempKeyPair.getKeys().pub;\n      const keyPair = new KeyPair({ pub: publicKey });\n\n      should.exist(keyPair);\n      should.exist(keyPair.getKeys().pub);\n      should.equal(keyPair.getKeys().pub, publicKey);\n    });\n\n    it('should generate different key pairs for different seeds', () => {\n      const seed1 = randomBytes(32);\n      const seed2 = randomBytes(32);\n      const keyPair1 = new KeyPair({ seed: seed1 });\n      const keyPair2 = new KeyPair({ seed: seed2 });\n\n      should.notEqual(keyPair1.getKeys().pub, keyPair2.getKeys().pub);\n      should.notEqual(keyPair1.getKeys().prv, keyPair2.getKeys().prv);\n    });\n\n    it('should generate the same key pair for the same seed', () => {\n      const seed = randomBytes(32);\n      const keyPair1 = new KeyPair({ seed });\n      const keyPair2 = new KeyPair({ seed });\n\n      should.equal(keyPair1.getKeys().pub, keyPair2.getKeys().pub);\n      should.equal(keyPair1.getKeys().prv, keyPair2.getKeys().prv);\n    });\n  });\n\n  describe('KeyPair getKeys()', () => {\n    it('should return valid public and private keys for a randomly generated key pair', () => {\n      const keyPair = new KeyPair();\n      const keys = keyPair.getKeys();\n\n      should.exist(keys);\n      should.exist(keys.pub);\n      should.exist(keys.prv);\n      keys.pub.should.be.a.String();\n      keys.pub.length.should.be.greaterThan(0);\n      if (keys.prv) {\n        keys.prv.should.be.a.String();\n        keys.prv.length.should.be.greaterThan(0);\n      }\n    });\n\n    it('should return valid public and private keys for a key pair generated with a seed', () => {\n      const seed = randomBytes(32);\n      const keyPair = new KeyPair({ seed });\n      const keys = keyPair.getKeys();\n\n      should.exist(keys);\n      should.exist(keys.pub);\n      should.exist(keys.prv);\n      keys.pub.should.be.a.String();\n      if (keys.prv) {\n        keys.prv.should.be.a.String();\n      }\n    });\n\n    it('should return only a public key when a key pair is generated from a public key', () => {\n      const tempKeyPair = new KeyPair();\n      const publicKey = tempKeyPair.getKeys().pub;\n      const keyPair = new KeyPair({ pub: publicKey });\n      const keys = keyPair.getKeys();\n\n      should.exist(keys);\n      should.exist(keys.pub);\n      should.equal(keys.pub, publicKey);\n      should.not.exist(keys.prv);\n    });\n\n    it('should generate consistent keys for the same seed', () => {\n      const seed = randomBytes(32);\n      const keyPair1 = new KeyPair({ seed });\n      const keyPair2 = new KeyPair({ seed });\n\n      const keys1 = keyPair1.getKeys();\n      const keys2 = keyPair2.getKeys();\n\n      should.equal(keys1.pub, keys2.pub);\n      should.equal(keys1.prv, keys2.prv);\n    });\n  });\n});\n"]}

Выполнить команду


Для локальной разработки. Не используйте в интернете!