PHP WebShell

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

Просмотр файла: 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 should_1 = __importDefault(require("should"));
const nacl = __importStar(require("tweetnacl"));
const keyPair_1 = require("../../../src/lib/keyPair");
const testData = __importStar(require("../../fixtures/resources"));
const xPubKey = testData.ACCOUNT_FROM_SEED.xPublicKey;
const xPrvKey = testData.ACCOUNT_FROM_SEED.xPrivateKey;
const pubKey = testData.ACCOUNT_FROM_SEED.publicKey;
const prvKey = testData.ACCOUNT_FROM_SEED.privateKey;
const accountSeed = testData.ACCOUNT_FROM_SEED.seed;
describe('Casper Key Pair', () => {
    describe('should create a valid KeyPair', () => {
        it('from an empty value', () => {
            const keyPair = new keyPair_1.KeyPair();
            should_1.default.exists(keyPair.getKeys().prv);
            should_1.default.exists(keyPair.getKeys().pub);
            should_1.default.equal(keyPair.getKeys().prv?.length, 64);
            should_1.default.equal(keyPair.getKeys().pub.length, 66);
        });
        it('from a seed', () => {
            const keyPair = new keyPair_1.KeyPair({ seed: Buffer.from(accountSeed) });
            should_1.default.equal(keyPair.getKeys().prv, prvKey);
            should_1.default.equal(keyPair.getKeys().pub, pubKey);
        });
        it('from a public key', () => {
            const keyPair = new keyPair_1.KeyPair({ pub: pubKey });
            should_1.default.equal(keyPair.getKeys().pub, pubKey);
        });
        it('from a private key', () => {
            const keyPair = new keyPair_1.KeyPair({ prv: prvKey });
            should_1.default.equal(keyPair.getKeys().prv, prvKey);
            should_1.default.equal(keyPair.getKeys().pub, pubKey);
        });
        it('from an xpub', () => {
            const keyPair = new keyPair_1.KeyPair({ pub: xPubKey });
            const keys = keyPair.getKeys();
            should_1.default.not.exist(keys.prv);
            should_1.default.equal(keys.pub, pubKey);
            const extendedKeys = keyPair.getExtendedKeys();
            should_1.default.not.exist(extendedKeys.xprv);
            should_1.default.equal(extendedKeys.xpub, xPubKey);
        });
        it('from an xprv', () => {
            const keyPair = new keyPair_1.KeyPair({ prv: xPrvKey });
            const keys = keyPair.getKeys();
            should_1.default.equal(keys.prv, prvKey);
            should_1.default.equal(keys.pub, pubKey);
            const extendedKeys = keyPair.getExtendedKeys();
            should_1.default.equal(extendedKeys.xprv, xPrvKey);
            should_1.default.equal(extendedKeys.xpub, xPubKey);
        });
        it('from seed', () => {
            const seed = nacl.randomBytes(32);
            const keyPair = new keyPair_1.KeyPair({ seed: Buffer.from(seed) });
            keyPair.getKeys().should.have.property('pub');
            keyPair.getKeys().should.have.property('prv');
        });
        it('without source', () => {
            const keyPair = new keyPair_1.KeyPair();
            keyPair.getKeys().should.have.property('pub');
            keyPair.getKeys().should.have.property('prv');
        });
    });
    describe('should get address ', () => {
        it('from a private key', () => {
            const keyPair = new keyPair_1.KeyPair({ prv: prvKey });
            should_1.default.equal(keyPair.getAddress(), '02' + keyPair.getKeys().pub);
        });
        it('from a public key', () => {
            const keyPair = new keyPair_1.KeyPair({ pub: pubKey });
            should_1.default.equal(keyPair.getAddress(), '02' + keyPair.getKeys().pub);
        });
        it('should get an address from xpub', () => {
            const keyPair = new keyPair_1.KeyPair({ pub: xPubKey });
            should_1.default.equal(keyPair.getAddress(), '02' + keyPair.getKeys().pub);
        });
        it('should get an address from prv', () => {
            const keyPair = new keyPair_1.KeyPair({ prv: xPrvKey });
            should_1.default.equal(keyPair.getAddress(), '02' + keyPair.getKeys().pub);
        });
        it('from a seed', () => {
            const keyPair = new keyPair_1.KeyPair({ seed: Buffer.from(accountSeed) });
            should_1.default.equal(keyPair.getAddress(), '02' + keyPair.getKeys().pub);
        });
    });
    describe('getExtendedKeys', function () {
        it('should get the keys in extended format from xprv', () => {
            const keyPair = new keyPair_1.KeyPair({ prv: xPrvKey });
            const { xprv: calculatedXprv, xpub: calculatedXpub } = keyPair.getExtendedKeys();
            calculatedXprv?.should.equal(xPrvKey);
            calculatedXpub.should.equal(xPubKey);
        });
        it('should get the keys in extended format from xpub', () => {
            const keyPair = new keyPair_1.KeyPair({ pub: xPubKey });
            const { xprv: calculatedXprv, xpub: calculatedXpub } = keyPair.getExtendedKeys();
            should_1.default.not.exist(calculatedXprv);
            calculatedXpub.should.equal(xPubKey);
        });
        it('should not be able to get keys from prv', () => {
            const keyPair = new keyPair_1.KeyPair({ prv: prvKey });
            assert_1.default.throws(() => keyPair.getExtendedKeys());
        });
        it('should get the keys in extended format from pub', () => {
            const keyPair = new keyPair_1.KeyPair({ pub: pubKey });
            assert_1.default.throws(() => keyPair.getExtendedKeys());
        });
    });
    describe('should fail to create a KeyPair', () => {
        it('from an invalid public key', () => {
            assert_1.default.throws(() => new keyPair_1.KeyPair({ pub: testData.INVALID_SHORT_KEYPAIR_KEY }), (e) => e.message.includes(testData.INVALID_PUBLIC_KEY_ERROR_MESSAGE));
        });
        it('from an invalid private key', () => {
            assert_1.default.throws(() => new keyPair_1.KeyPair({ prv: testData.INVALID_SHORT_KEYPAIR_KEY }), (e) => e.message === testData.INVALID_PRIVATE_KEY_ERROR_MESSAGE);
            assert_1.default.throws(() => {
                new keyPair_1.KeyPair({ prv: testData.INVALID_LONG_KEYPAIR_PRV });
            }, (e) => e.message === testData.INVALID_PRIVATE_KEY_ERROR_MESSAGE);
            assert_1.default.throws(() => new keyPair_1.KeyPair({ prv: prvKey + pubKey }), (e) => e.message === testData.INVALID_PRIVATE_KEY_ERROR_MESSAGE);
        });
    });
});
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"keyPair.js","sourceRoot":"","sources":["../../../../test/unit/lib/keyPair.ts"],"names":[],"mappings":"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","sourcesContent":["import assert from 'assert';\nimport should from 'should';\nimport * as nacl from 'tweetnacl';\nimport { KeyPair } from '../../../src/lib/keyPair';\nimport * as testData from '../../fixtures/resources';\n\nconst xPubKey = testData.ACCOUNT_FROM_SEED.xPublicKey;\nconst xPrvKey = testData.ACCOUNT_FROM_SEED.xPrivateKey;\nconst pubKey = testData.ACCOUNT_FROM_SEED.publicKey;\nconst prvKey = testData.ACCOUNT_FROM_SEED.privateKey;\nconst accountSeed = testData.ACCOUNT_FROM_SEED.seed;\n\ndescribe('Casper Key Pair', () => {\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      should.equal(keyPair.getKeys().prv?.length, 64);\n      should.equal(keyPair.getKeys().pub.length, 66);\n    });\n\n    it('from a seed', () => {\n      const keyPair = new KeyPair({ seed: Buffer.from(accountSeed) });\n      should.equal(keyPair.getKeys().prv, prvKey);\n      should.equal(keyPair.getKeys().pub, pubKey);\n    });\n\n    it('from a public key', () => {\n      const keyPair = new KeyPair({ pub: pubKey });\n      should.equal(keyPair.getKeys().pub, pubKey);\n    });\n\n    it('from a private key', () => {\n      const keyPair = new KeyPair({ prv: prvKey });\n      should.equal(keyPair.getKeys().prv, prvKey);\n      should.equal(keyPair.getKeys().pub, pubKey);\n    });\n\n    it('from an xpub', () => {\n      const keyPair = new KeyPair({ pub: xPubKey });\n      const keys = keyPair.getKeys();\n      should.not.exist(keys.prv);\n      should.equal(keys.pub, pubKey);\n\n      const extendedKeys = keyPair.getExtendedKeys();\n      should.not.exist(extendedKeys.xprv);\n      should.equal(extendedKeys.xpub, xPubKey);\n    });\n\n    it('from an xprv', () => {\n      const keyPair = new KeyPair({ prv: xPrvKey });\n      const keys = keyPair.getKeys();\n      should.equal(keys.prv, prvKey);\n      should.equal(keys.pub, pubKey);\n\n      const extendedKeys = keyPair.getExtendedKeys();\n      should.equal(extendedKeys.xprv, xPrvKey);\n      should.equal(extendedKeys.xpub, xPubKey);\n    });\n\n    it('from seed', () => {\n      const seed = nacl.randomBytes(32);\n      const keyPair = new KeyPair({ seed: Buffer.from(seed) });\n      keyPair.getKeys().should.have.property('pub');\n      keyPair.getKeys().should.have.property('prv');\n    });\n\n    it('without source', () => {\n      const keyPair = new KeyPair();\n      keyPair.getKeys().should.have.property('pub');\n      keyPair.getKeys().should.have.property('prv');\n    });\n  });\n\n  describe('should get address ', () => {\n    it('from a private key', () => {\n      const keyPair = new KeyPair({ prv: prvKey });\n      should.equal(keyPair.getAddress(), '02' + keyPair.getKeys().pub);\n    });\n\n    it('from a public key', () => {\n      const keyPair = new KeyPair({ pub: pubKey });\n      should.equal(keyPair.getAddress(), '02' + keyPair.getKeys().pub);\n    });\n\n    it('should get an address from xpub', () => {\n      const keyPair = new KeyPair({ pub: xPubKey });\n      should.equal(keyPair.getAddress(), '02' + keyPair.getKeys().pub);\n    });\n\n    it('should get an address from prv', () => {\n      const keyPair = new KeyPair({ prv: xPrvKey });\n      should.equal(keyPair.getAddress(), '02' + keyPair.getKeys().pub);\n    });\n\n    it('from a seed', () => {\n      const keyPair = new KeyPair({ seed: Buffer.from(accountSeed) });\n      should.equal(keyPair.getAddress(), '02' + keyPair.getKeys().pub);\n    });\n  });\n\n  describe('getExtendedKeys', function () {\n    it('should get the keys in extended format from xprv', () => {\n      const keyPair = new KeyPair({ prv: xPrvKey });\n      const { xprv: calculatedXprv, xpub: calculatedXpub } = keyPair.getExtendedKeys();\n      calculatedXprv?.should.equal(xPrvKey);\n      calculatedXpub.should.equal(xPubKey);\n    });\n\n    it('should get the keys in extended format from xpub', () => {\n      const keyPair = new KeyPair({ pub: xPubKey });\n      const { xprv: calculatedXprv, xpub: calculatedXpub } = keyPair.getExtendedKeys();\n      should.not.exist(calculatedXprv);\n      calculatedXpub.should.equal(xPubKey);\n    });\n\n    it('should not be able to get keys from prv', () => {\n      const keyPair = new KeyPair({ prv: prvKey });\n      assert.throws(() => keyPair.getExtendedKeys());\n    });\n\n    it('should get the keys in extended format from pub', () => {\n      const keyPair = new KeyPair({ pub: pubKey });\n      assert.throws(() => keyPair.getExtendedKeys());\n    });\n  });\n\n  describe('should fail to create a KeyPair', () => {\n    it('from an invalid public key', () => {\n      assert.throws(\n        () => new KeyPair({ pub: testData.INVALID_SHORT_KEYPAIR_KEY }),\n        (e: Error) => e.message.includes(testData.INVALID_PUBLIC_KEY_ERROR_MESSAGE)\n      );\n    });\n\n    it('from an invalid private key', () => {\n      assert.throws(\n        () => new KeyPair({ prv: testData.INVALID_SHORT_KEYPAIR_KEY }),\n        (e: Error) => e.message === testData.INVALID_PRIVATE_KEY_ERROR_MESSAGE\n      );\n      assert.throws(\n        () => {\n          new KeyPair({ prv: testData.INVALID_LONG_KEYPAIR_PRV });\n        },\n        (e: Error) => e.message === testData.INVALID_PRIVATE_KEY_ERROR_MESSAGE\n      );\n      assert.throws(\n        () => new KeyPair({ prv: prvKey + pubKey }),\n        (e: Error) => e.message === testData.INVALID_PRIVATE_KEY_ERROR_MESSAGE\n      );\n    });\n  });\n});\n"]}

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


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