PHP WebShell

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

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

"use strict";
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
    if (k2 === undefined) k2 = k;
    var desc = Object.getOwnPropertyDescriptor(m, k);
    if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
      desc = { enumerable: true, get: function() { return m[k]; } };
    }
    Object.defineProperty(o, k2, desc);
}) : (function(o, m, k, k2) {
    if (k2 === undefined) k2 = k;
    o[k2] = m[k];
}));
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
    Object.defineProperty(o, "default", { enumerable: true, value: v });
}) : function(o, v) {
    o["default"] = v;
});
var __importStar = (this && this.__importStar) || (function () {
    var ownKeys = function(o) {
        ownKeys = Object.getOwnPropertyNames || function (o) {
            var ar = [];
            for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
            return ar;
        };
        return ownKeys(o);
    };
    return function (mod) {
        if (mod && mod.__esModule) return mod;
        var result = {};
        if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
        __setModuleDefault(result, mod);
        return result;
    };
})();
var __importDefault = (this && this.__importDefault) || function (mod) {
    return (mod && mod.__esModule) ? mod : { "default": mod };
};
Object.defineProperty(exports, "__esModule", { value: true });
const assert_1 = __importDefault(require("assert"));
const src_1 = require("../../src");
const should_1 = __importDefault(require("should"));
const testData = __importStar(require("../resources/sol"));
const utils_1 = require("../../src/lib/utils");
describe('Sol KeyPair', function () {
    const defaultSeed = { seed: testData.accountWithSeed.seed };
    describe('should create a valid KeyPair', () => {
        it('from an empty value', () => {
            const keyPair = new src_1.KeyPair();
            should_1.default.exists(keyPair.getKeys().prv);
            should_1.default.exists(keyPair.getKeys().pub);
            keyPair.getKeys().prv?.length.should.be.belowOrEqual(88);
            keyPair.getKeys().prv?.length.should.be.aboveOrEqual(76);
            keyPair.getKeys().pub.length.should.be.belowOrEqual(44);
            keyPair.getKeys().pub.length.should.be.aboveOrEqual(32);
        });
        it('from a private key', () => {
            const keyPair = new src_1.KeyPair({ prv: testData.accountWithSeed.privateKey.base58 });
            should_1.default.equal(keyPair.getKeys().pub, testData.accountWithSeed.publicKey);
            should_1.default.equal(keyPair.getKeys().prv, testData.accountWithSeed.privateKey.base58);
            should_1.default.equal(keyPair.getKeys(true).pub, testData.accountWithSeed.publicKey);
            should_1.default.deepEqual(keyPair.getKeys(true).prv, testData.accountWithSeed.privateKey.uint8Array);
        });
        it('from an public key', () => {
            const keyPair = new src_1.KeyPair({ pub: testData.accountWithSeed.publicKey });
            should_1.default.equal(keyPair.getKeys().pub, testData.accountWithSeed.publicKey);
        });
        it('should always generate and regenerate valid key pairs', () => {
            for (let i = 0; i < 50; i++) {
                const keyPair = new src_1.KeyPair();
                (0, utils_1.isValidPublicKey)(keyPair.getKeys().pub).should.be.true();
                (0, utils_1.isValidAddress)(keyPair.getAddress()).should.be.true();
                const prv = keyPair.getKeys().prv;
                should_1.default.exist(prv);
                // verify key pair can be re-generated from private portion
                const regeneratedKeyPairFromPrv = new src_1.KeyPair({ prv: prv });
                regeneratedKeyPairFromPrv.getKeys().should.deepEqual(keyPair.getKeys());
                regeneratedKeyPairFromPrv.getAddress().should.equal(keyPair.getAddress());
                regeneratedKeyPairFromPrv.should.deepEqual(keyPair);
                should_1.default.exist(regeneratedKeyPairFromPrv.getKeys().prv);
                // verify key pair can be re-generated from public portion
                const pub = keyPair.getKeys().pub;
                const regeneratedKeyPairFromPub = new src_1.KeyPair({ pub: pub });
                regeneratedKeyPairFromPub.getKeys().pub.should.deepEqual(keyPair.getKeys().pub);
                regeneratedKeyPairFromPub.getAddress().should.equal(keyPair.getAddress());
                should_1.default.not.exist(regeneratedKeyPairFromPub.getKeys().prv);
            }
        });
    });
    describe('should fail to create a KeyPair', function () {
        it('from invalid options', () => {
            // @ts-expect-error Testing for an params, should throw error
            (0, should_1.default)(() => new src_1.KeyPair({ random: 'random' })).throwError('Invalid key pair options');
        });
        it('from an invalid seed', () => {
            const seed = { seed: Buffer.alloc(8) }; //  Seed should be 512 bits (64 bytes)
            assert_1.default.throws(() => new src_1.KeyPair(seed));
        });
        it('from an invalid public key', () => {
            const source = {
                pub: '01D63D',
            };
            assert_1.default.throws(() => new src_1.KeyPair(source));
        });
        it('from an invalid private key', () => {
            const source = {
                prv: '82A34E',
            };
            assert_1.default.throws(() => new src_1.KeyPair(source));
        });
    });
    describe('getAddress', function () {
        it('should get an address', () => {
            const keyPair = new src_1.KeyPair(defaultSeed);
            const address = keyPair.getAddress();
            address.should.equal(testData.accountWithSeed.publicKey);
        });
    });
    describe('getKeys', function () {
        it('should get public keys in base58 and private in Uint8Array', () => {
            const keyPair = new src_1.KeyPair(defaultSeed);
            const { prv, pub } = keyPair.getKeys(true);
            prv?.should.deepEqual(testData.accountWithSeed.privateKey.uint8Array);
            pub.should.equal(testData.accountWithSeed.publicKey);
        });
        it('should get private and public keys base58', () => {
            const keyPair = new src_1.KeyPair(defaultSeed);
            const { prv, pub } = keyPair.getKeys();
            prv?.should.equal(testData.accountWithSeed.privateKey.base58);
            pub.should.equal(testData.accountWithSeed.publicKey);
        });
        it('should get private and public keys for a random seed', () => {
            const keyPair = new src_1.KeyPair();
            const { prv, pub } = keyPair.getKeys();
            should_1.default.exist(prv);
            should_1.default.exist(pub);
        });
    });
    describe('signMessage and verifySignature', function () {
        const message = 'test message pls ignore';
        it('should succeed to sign a msg ', () => {
            const keyPair = new src_1.KeyPair({ prv: testData.accountWithSeed.privateKey.base58 });
            const signedMessage = keyPair.signMessage(message);
            signedMessage.should.deepEqual(testData.SIGNED_MESSAGE_SIGNATURE);
        });
        it('should fail to sign a msg if prv key is missing', () => {
            const keyPair = new src_1.KeyPair({ pub: testData.pubKeys.validPubKeys[0] });
            (0, should_1.default)(() => keyPair.signMessage(message)).throwError('Missing private key');
        });
    });
    describe('verifySignature', function () {
        it('should succeed to verify a signature', () => {
            const keyPair = new src_1.KeyPair({ prv: testData.accountWithSeed.privateKey.base58 });
            const signature = testData.SIGNED_MESSAGE_SIGNATURE;
            const message = 'test message pls ignore';
            keyPair.verifySignature(message, signature).should.equal(true);
        });
        it('should succeed to verify a signature if the msg is a UInt8Array', () => {
            const keyPair = new src_1.KeyPair({ prv: testData.accountWithSeed.privateKey.base58 });
            const signature = testData.SIGNED_MESSAGE_SIGNATURE;
            const message = new Uint8Array(Buffer.from('test message pls ignore'));
            keyPair.verifySignature(message, signature).should.equal(true);
        });
        it('should fail to verify a signature if the prv key is not correct', () => {
            const keyPair = new src_1.KeyPair({ prv: testData.extraAccounts.prv1 });
            const signature = testData.SIGNED_MESSAGE_SIGNATURE;
            const message = 'test message pls ignore';
            keyPair.verifySignature(message, signature).should.equal(false);
        });
        it('should fail to verify a signature if the message is not correct', () => {
            const keyPair = new src_1.KeyPair({ prv: testData.accountWithSeed.privateKey.base58 });
            const signature = testData.SIGNED_MESSAGE_SIGNATURE;
            const message = 'incorrect msg';
            keyPair.verifySignature(message, signature).should.equal(false);
        });
    });
});
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"keyPair.js","sourceRoot":"","sources":["../../../test/unit/keyPair.ts"],"names":[],"mappings":"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","sourcesContent":["import assert from 'assert';\nimport { KeyPair } from '../../src';\nimport should from 'should';\nimport * as testData from '../resources/sol';\nimport { isValidPublicKey, isValidAddress } from '../../src/lib/utils';\n\ndescribe('Sol KeyPair', function () {\n  const defaultSeed = { seed: testData.accountWithSeed.seed };\n\n  describe('should create a valid KeyPair', () => {\n    it('from an empty value', () => {\n      const keyPair = new KeyPair();\n      should.exists(keyPair.getKeys().prv);\n      should.exists(keyPair.getKeys().pub);\n      keyPair.getKeys().prv?.length.should.be.belowOrEqual(88);\n      keyPair.getKeys().prv?.length.should.be.aboveOrEqual(76);\n      keyPair.getKeys().pub.length.should.be.belowOrEqual(44);\n      keyPair.getKeys().pub.length.should.be.aboveOrEqual(32);\n    });\n\n    it('from a private key', () => {\n      const keyPair = new KeyPair({ prv: testData.accountWithSeed.privateKey.base58 });\n      should.equal(keyPair.getKeys().pub, testData.accountWithSeed.publicKey);\n      should.equal(keyPair.getKeys().prv, testData.accountWithSeed.privateKey.base58);\n      should.equal(keyPair.getKeys(true).pub, testData.accountWithSeed.publicKey);\n      should.deepEqual(keyPair.getKeys(true).prv, testData.accountWithSeed.privateKey.uint8Array);\n    });\n\n    it('from an public key', () => {\n      const keyPair = new KeyPair({ pub: testData.accountWithSeed.publicKey });\n      should.equal(keyPair.getKeys().pub, testData.accountWithSeed.publicKey);\n    });\n\n    it('should always generate and regenerate valid key pairs', () => {\n      for (let i = 0; i < 50; i++) {\n        const keyPair = new KeyPair();\n        isValidPublicKey(keyPair.getKeys().pub).should.be.true();\n        isValidAddress(keyPair.getAddress()).should.be.true();\n\n        const prv = keyPair.getKeys().prv as string;\n        should.exist(prv);\n\n        // verify key pair can be re-generated from private portion\n        const regeneratedKeyPairFromPrv = new KeyPair({ prv: prv });\n        regeneratedKeyPairFromPrv.getKeys().should.deepEqual(keyPair.getKeys());\n        regeneratedKeyPairFromPrv.getAddress().should.equal(keyPair.getAddress());\n        regeneratedKeyPairFromPrv.should.deepEqual(keyPair);\n        should.exist(regeneratedKeyPairFromPrv.getKeys().prv);\n\n        // verify key pair can be re-generated from public portion\n        const pub = keyPair.getKeys().pub;\n        const regeneratedKeyPairFromPub = new KeyPair({ pub: pub });\n        regeneratedKeyPairFromPub.getKeys().pub.should.deepEqual(keyPair.getKeys().pub);\n        regeneratedKeyPairFromPub.getAddress().should.equal(keyPair.getAddress());\n        should.not.exist(regeneratedKeyPairFromPub.getKeys().prv);\n      }\n    });\n  });\n\n  describe('should fail to create a KeyPair', function () {\n    it('from invalid options', () => {\n      // @ts-expect-error Testing for an params, should throw error\n      should(() => new KeyPair({ random: 'random' })).throwError('Invalid key pair options');\n    });\n\n    it('from an invalid seed', () => {\n      const seed = { seed: Buffer.alloc(8) }; //  Seed should be 512 bits (64 bytes)\n      assert.throws(() => new KeyPair(seed));\n    });\n\n    it('from an invalid public key', () => {\n      const source = {\n        pub: '01D63D',\n      };\n      assert.throws(() => new KeyPair(source));\n    });\n\n    it('from an invalid private key', () => {\n      const source = {\n        prv: '82A34E',\n      };\n      assert.throws(() => new KeyPair(source));\n    });\n  });\n\n  describe('getAddress', function () {\n    it('should get an address', () => {\n      const keyPair = new KeyPair(defaultSeed);\n      const address = keyPair.getAddress();\n      address.should.equal(testData.accountWithSeed.publicKey);\n    });\n  });\n\n  describe('getKeys', function () {\n    it('should get public keys in base58 and private in Uint8Array', () => {\n      const keyPair = new KeyPair(defaultSeed);\n      const { prv, pub } = keyPair.getKeys(true);\n      prv?.should.deepEqual(testData.accountWithSeed.privateKey.uint8Array);\n      pub.should.equal(testData.accountWithSeed.publicKey);\n    });\n\n    it('should get private and public keys base58', () => {\n      const keyPair = new KeyPair(defaultSeed);\n      const { prv, pub } = keyPair.getKeys();\n      prv?.should.equal(testData.accountWithSeed.privateKey.base58);\n      pub.should.equal(testData.accountWithSeed.publicKey);\n    });\n\n    it('should get private and public keys for a random seed', () => {\n      const keyPair = new KeyPair();\n      const { prv, pub } = keyPair.getKeys();\n      should.exist(prv);\n      should.exist(pub);\n    });\n  });\n\n  describe('signMessage and verifySignature', function () {\n    const message = 'test message pls ignore';\n\n    it('should succeed to sign a msg ', () => {\n      const keyPair = new KeyPair({ prv: testData.accountWithSeed.privateKey.base58 });\n      const signedMessage = keyPair.signMessage(message);\n      signedMessage.should.deepEqual(testData.SIGNED_MESSAGE_SIGNATURE);\n    });\n\n    it('should fail to sign a msg if prv key is missing', () => {\n      const keyPair = new KeyPair({ pub: testData.pubKeys.validPubKeys[0] });\n      should(() => keyPair.signMessage(message)).throwError('Missing private key');\n    });\n  });\n\n  describe('verifySignature', function () {\n    it('should succeed to verify a signature', () => {\n      const keyPair = new KeyPair({ prv: testData.accountWithSeed.privateKey.base58 });\n      const signature = testData.SIGNED_MESSAGE_SIGNATURE;\n      const message = 'test message pls ignore';\n      keyPair.verifySignature(message, signature).should.equal(true);\n    });\n\n    it('should succeed to verify a signature if the msg is a UInt8Array', () => {\n      const keyPair = new KeyPair({ prv: testData.accountWithSeed.privateKey.base58 });\n      const signature = testData.SIGNED_MESSAGE_SIGNATURE;\n      const message = new Uint8Array(Buffer.from('test message pls ignore'));\n      keyPair.verifySignature(message, signature).should.equal(true);\n    });\n\n    it('should fail to verify a signature if the prv key is not correct', () => {\n      const keyPair = new KeyPair({ prv: testData.extraAccounts.prv1 });\n      const signature = testData.SIGNED_MESSAGE_SIGNATURE;\n      const message = 'test message pls ignore';\n      keyPair.verifySignature(message, signature).should.equal(false);\n    });\n\n    it('should fail to verify a signature if the message is not correct', () => {\n      const keyPair = new KeyPair({ prv: testData.accountWithSeed.privateKey.base58 });\n      const signature = testData.SIGNED_MESSAGE_SIGNATURE;\n      const message = 'incorrect msg';\n      keyPair.verifySignature(message, signature).should.equal(false);\n    });\n  });\n});\n"]}

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


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