PHP WebShell
Текущая директория: /opt/BitGoJS/modules/sdk-coin-ada/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 src_1 = require("../../src");
const resources_1 = require("../resources/");
const cardano_serialization_lib_nodejs_1 = require("@emurgo/cardano-serialization-lib-nodejs");
const sdk_core_1 = require("@bitgo/sdk-core");
describe('Ada Keypair', () => {
const defaultSeed = { seed: Buffer.alloc(32) };
describe('Keypair creation', () => {
it('initial state', () => {
const keyPair = new src_1.KeyPair();
should_1.default.exists(keyPair.getKeys().prv);
should_1.default.exists(keyPair.getKeys().prv);
});
it('initialization from private key', () => {
let keyPair = new src_1.KeyPair({
prv: resources_1.enterpriseAccounts.account1.secretKey,
});
should_1.default.equal(keyPair.getKeys().prv, (0, sdk_core_1.toHex)(cardano_serialization_lib_nodejs_1.PrivateKey.from_bech32(resources_1.enterpriseAccounts.account1.secretKey).as_bytes()));
should_1.default.equal(keyPair.getKeys().pub, resources_1.enterpriseAccounts.account1.hexPublic);
keyPair = new src_1.KeyPair({
prv: resources_1.enterpriseAccounts.account2.secretKey,
});
should_1.default.equal(keyPair.getKeys().prv, (0, sdk_core_1.toHex)(cardano_serialization_lib_nodejs_1.PrivateKey.from_bech32(resources_1.enterpriseAccounts.account2.secretKey).as_bytes()));
should_1.default.equal(keyPair.getKeys().pub, resources_1.enterpriseAccounts.account2.hexPublic);
});
it('initialization from public key', () => {
let keyPair = new src_1.KeyPair({ pub: resources_1.enterpriseAccounts.account1.publicKey });
should_1.default.equal(keyPair.getKeys().pub, (0, sdk_core_1.toHex)(cardano_serialization_lib_nodejs_1.PublicKey.from_bech32(resources_1.enterpriseAccounts.account1.publicKey).as_bytes()));
keyPair = new src_1.KeyPair({ pub: resources_1.enterpriseAccounts.account2.publicKey });
should_1.default.equal(keyPair.getAddress(sdk_core_1.AddressFormat.testnet), resources_1.enterpriseAccounts.account2.baseAddress);
keyPair = new src_1.KeyPair({ pub: resources_1.enterpriseAccounts.account4.publicKeyHex });
should_1.default.equal(keyPair.getKeys().pub, resources_1.enterpriseAccounts.account4.publicKeyHex);
});
});
describe('KeyPair validation', () => {
it('should fail to create from an invalid seed', () => {
const seed = { seed: Buffer.alloc(8) }; // Seed should be 512 bits (64 bytes)
should_1.default.throws(() => new src_1.KeyPair(seed), 'bad seed size');
});
it('should fail to create from an invalid public key', () => {
const source = {
pub: '01D63D',
};
should_1.default.throws(() => new src_1.KeyPair(source), 'address seems to be malformed');
});
it('should fail to create from an invalid private key', () => {
const source = {
prv: '82A34',
};
should_1.default.throws(() => new src_1.KeyPair(source), 'Invalid base32 characters');
});
});
describe('getAddress', () => {
it('should get an address', () => {
let keyPair = new src_1.KeyPair({ prv: resources_1.enterpriseAccounts.account1.secretKey });
let address = keyPair.getAddress(sdk_core_1.AddressFormat.testnet);
address.should.equal(resources_1.enterpriseAccounts.account1.baseAddress);
keyPair = new src_1.KeyPair({ prv: resources_1.enterpriseAccounts.account3.secretKey });
address = keyPair.getAddress(sdk_core_1.AddressFormat.testnet);
address.should.equal(resources_1.enterpriseAccounts.account3.baseAddress);
keyPair = new src_1.KeyPair({ pub: resources_1.enterpriseAccounts.account4.publicKeyHex });
address = keyPair.getAddress(sdk_core_1.AddressFormat.testnet);
address.should.equal(resources_1.enterpriseAccounts.account4.baseAddress);
});
});
describe('getKeys', () => {
it('should get private and public keys in the protocol default format', () => {
const keyPair = new src_1.KeyPair(defaultSeed);
const { prv, pub } = keyPair.getKeys();
prv.should.equal(prv);
pub.should.equal(pub);
const address = keyPair.getAddress(sdk_core_1.AddressFormat.testnet);
address.should.equal(resources_1.enterpriseAccounts.seedAccount.enterpriseAddress);
});
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);
});
});
});
//# 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';\nimport { enterpriseAccounts } from '../resources/';\nimport { PrivateKey, PublicKey } from '@emurgo/cardano-serialization-lib-nodejs';\nimport { AddressFormat, toHex } from '@bitgo/sdk-core';\n\ndescribe('Ada Keypair', () => {\n  const defaultSeed = { seed: Buffer.alloc(32) };\n\n  describe('Keypair creation', () => {\n    it('initial state', () => {\n      const keyPair = new KeyPair();\n      should.exists(keyPair.getKeys().prv);\n      should.exists(keyPair.getKeys().prv);\n    });\n\n    it('initialization from private key', () => {\n      let keyPair = new KeyPair({\n        prv: enterpriseAccounts.account1.secretKey,\n      });\n\n      should.equal(\n        keyPair.getKeys().prv,\n        toHex(PrivateKey.from_bech32(enterpriseAccounts.account1.secretKey).as_bytes())\n      );\n\n      should.equal(keyPair.getKeys().pub, enterpriseAccounts.account1.hexPublic);\n\n      keyPair = new KeyPair({\n        prv: enterpriseAccounts.account2.secretKey,\n      });\n\n      should.equal(\n        keyPair.getKeys().prv,\n        toHex(PrivateKey.from_bech32(enterpriseAccounts.account2.secretKey).as_bytes())\n      );\n      should.equal(keyPair.getKeys().pub, enterpriseAccounts.account2.hexPublic);\n    });\n\n    it('initialization from public key', () => {\n      let keyPair = new KeyPair({ pub: enterpriseAccounts.account1.publicKey });\n\n      should.equal(\n        keyPair.getKeys().pub,\n        toHex(PublicKey.from_bech32(enterpriseAccounts.account1.publicKey).as_bytes())\n      );\n\n      keyPair = new KeyPair({ pub: enterpriseAccounts.account2.publicKey });\n      should.equal(keyPair.getAddress(AddressFormat.testnet), enterpriseAccounts.account2.baseAddress);\n\n      keyPair = new KeyPair({ pub: enterpriseAccounts.account4.publicKeyHex });\n      should.equal(keyPair.getKeys().pub, enterpriseAccounts.account4.publicKeyHex);\n    });\n  });\n\n  describe('KeyPair validation', () => {\n    it('should fail to create from an invalid seed', () => {\n      const seed = { seed: Buffer.alloc(8) }; //  Seed should be 512 bits (64 bytes)\n      should.throws(() => new KeyPair(seed), 'bad seed size');\n    });\n\n    it('should fail to create from an invalid public key', () => {\n      const source = {\n        pub: '01D63D',\n      };\n      should.throws(() => new KeyPair(source), 'address seems to be malformed');\n    });\n\n    it('should fail to create from an invalid private key', () => {\n      const source = {\n        prv: '82A34',\n      };\n      should.throws(() => new KeyPair(source), 'Invalid base32 characters');\n    });\n  });\n\n  describe('getAddress', () => {\n    it('should get an address', () => {\n      let keyPair = new KeyPair({ prv: enterpriseAccounts.account1.secretKey });\n      let address = keyPair.getAddress(AddressFormat.testnet);\n      address.should.equal(enterpriseAccounts.account1.baseAddress);\n\n      keyPair = new KeyPair({ prv: enterpriseAccounts.account3.secretKey });\n      address = keyPair.getAddress(AddressFormat.testnet);\n      address.should.equal(enterpriseAccounts.account3.baseAddress);\n\n      keyPair = new KeyPair({ pub: enterpriseAccounts.account4.publicKeyHex });\n      address = keyPair.getAddress(AddressFormat.testnet);\n      address.should.equal(enterpriseAccounts.account4.baseAddress);\n    });\n  });\n\n  describe('getKeys', () => {\n    it('should get private and public keys in the protocol default format', () => {\n      const keyPair = new KeyPair(defaultSeed);\n      const { prv, pub } = keyPair.getKeys();\n\n      prv!.should.equal(prv);\n      pub.should.equal(pub);\n      const address = keyPair.getAddress(AddressFormat.testnet);\n      address.should.equal(enterpriseAccounts.seedAccount.enterpriseAddress);\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"]}Выполнить команду
Для локальной разработки. Не используйте в интернете!