PHP WebShell
Текущая директория: /opt/BitGoJS/modules/sdk-coin-cspr/dist/test/unit/lib
Просмотр файла: transaction.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 statics_1 = require("@bitgo/statics");
const casper_js_sdk_1 = require("casper-js-sdk");
const transaction_1 = require("../../../src/lib/transaction");
const testData = __importStar(require("../../fixtures/resources"));
const lib_1 = require("../../../src/lib");
const constants_1 = require("../../../src/lib/constants");
const utils_1 = require("../../../src/lib/utils");
describe('Cspr Transaction', () => {
const coin = statics_1.coins.get('tcspr');
const factory = new lib_1.TransactionBuilderFactory(coin);
const owner1Address = new lib_1.KeyPair({ pub: testData.ACCOUNT_1.publicKey }).getAddress();
const owner2Address = new lib_1.KeyPair({ pub: testData.ACCOUNT_2.publicKey }).getAddress();
const owner3Address = new lib_1.KeyPair({ pub: testData.ACCOUNT_3.publicKey }).getAddress();
const sourceAddress = new lib_1.KeyPair({ pub: testData.ROOT_ACCOUNT.publicKey }).getAddress();
const getTransaction = () => {
return new transaction_1.Transaction(coin);
};
const getWalletInitTransaction = async () => {
const txBuilder = factory.getWalletInitializationBuilder();
txBuilder.fee(testData.FEE);
txBuilder.owner(owner1Address);
txBuilder.owner(owner2Address);
txBuilder.owner(owner3Address);
txBuilder.source({ address: sourceAddress });
txBuilder.sign({ key: testData.ROOT_ACCOUNT.privateKey });
return (await txBuilder.build());
};
const getWalletInitTransactionUsignExtendedKey = async () => {
const txBuilder = factory.getWalletInitializationBuilder();
txBuilder.fee(testData.FEE);
txBuilder.owner(owner1Address);
txBuilder.owner(owner2Address);
txBuilder.owner(owner3Address);
txBuilder.source({ address: sourceAddress });
txBuilder.sign({ key: testData.ROOT_ACCOUNT.xPrivateKey });
return (await txBuilder.build());
};
const getTransferTransaction = async () => {
const txBuilder = factory.getTransferBuilder();
txBuilder.fee({ gasLimit: testData.FEE.gasLimit, gasPrice: testData.FEE.gasPrice });
txBuilder.source({ address: sourceAddress });
txBuilder.to(owner2Address);
txBuilder.amount(testData.MIN_MOTES_AMOUNT);
txBuilder.transferId(255);
return (await txBuilder.build());
};
// Creates a deploy instance, required to test signing.
const getTransferDeploy = () => {
const gasPrice = testData.FEE.gasPrice ? parseInt(testData.FEE.gasPrice, 10) : undefined;
const sourcePublicKey = casper_js_sdk_1.CLPublicKey.fromHex(testData.SECP256K1_PREFIX + testData.ACCOUNT_1.publicKey);
const deployParams = new casper_js_sdk_1.DeployUtil.DeployParams(sourcePublicKey, constants_1.DEFAULT_CHAIN_NAMES.testnet, gasPrice);
const session = casper_js_sdk_1.DeployUtil.ExecutableDeployItem.newTransfer(1, sourcePublicKey, undefined, 123);
const payment = casper_js_sdk_1.DeployUtil.standardPayment(parseInt(testData.FEE.gasLimit, 10));
return casper_js_sdk_1.DeployUtil.makeDeploy(deployParams, session, payment);
};
it('should throw empty transaction', () => {
const tx = getTransaction();
assert_1.default.throws(() => {
tx.toJson();
});
assert_1.default.throws(() => {
tx.toBroadcastFormat();
});
});
describe('should sign if transaction is', () => {
it('valid', async () => {
const tx = getTransaction();
const transferDeploy = getTransferDeploy();
if (transferDeploy) {
tx.casperTx = transferDeploy;
}
const keypair = new lib_1.KeyPair({ prv: testData.ACCOUNT_1.privateKey });
should_1.default.doesNotThrow(() => tx.sign(keypair));
should_1.default.equal(tx.casperTx.approvals[0].signer, testData.SECP256K1_PREFIX + testData.ACCOUNT_1.publicKey);
should_1.default.equal((0, utils_1.isValidTransactionSignature)(tx.casperTx.approvals[0].signature, tx.casperTx.hash, Buffer.from(tx.casperTx.header.account.value()).toString('hex')), true);
should_1.default.doesNotThrow(() => (0, utils_1.verifySignature)(tx.casperTx.approvals[0].signature, tx.casperTx.hash, Buffer.from(tx.casperTx.header.account.value()).toString('hex')));
});
it('valid using extended key', async () => {
const tx = getTransaction();
const transferDeploy = getTransferDeploy();
if (transferDeploy) {
tx.casperTx = transferDeploy;
}
const keypair = new lib_1.KeyPair({ prv: testData.ACCOUNT_1.xPrivateKey });
should_1.default.doesNotThrow(() => tx.sign(keypair));
should_1.default.equal(tx.casperTx.approvals[0].signer, testData.SECP256K1_PREFIX + testData.ACCOUNT_1.publicKey);
should_1.default.equal((0, utils_1.isValidTransactionSignature)(tx.casperTx.approvals[0].signature, tx.casperTx.hash, Buffer.from(tx.casperTx.header.account.value()).toString('hex')), true);
should_1.default.doesNotThrow(() => (0, utils_1.verifySignature)(tx.casperTx.approvals[0].signature, tx.casperTx.hash, Buffer.from(tx.casperTx.header.account.value()).toString('hex')));
});
it('multiple valid', async () => {
const tx = getTransaction();
const transferDeploy = getTransferDeploy();
if (transferDeploy) {
tx.casperTx = transferDeploy;
}
const keypair = new lib_1.KeyPair({ prv: testData.ACCOUNT_1.privateKey });
const keypair2 = new lib_1.KeyPair({ prv: testData.ACCOUNT_2.privateKey });
should_1.default.doesNotThrow(() => tx.sign(keypair));
should_1.default.equal(tx.casperTx.approvals[0].signer, testData.SECP256K1_PREFIX + testData.ACCOUNT_1.publicKey);
should_1.default.equal((0, utils_1.isValidTransactionSignature)(tx.casperTx.approvals[0].signature, tx.casperTx.hash, testData.ACCOUNT_1.publicKey), true);
should_1.default.doesNotThrow(() => (0, utils_1.verifySignature)(tx.casperTx.approvals[0].signature, tx.casperTx.hash, testData.ACCOUNT_1.publicKey));
should_1.default.doesNotThrow(() => tx.sign(keypair2));
should_1.default.equal(tx.casperTx.approvals[0].signer, testData.SECP256K1_PREFIX + testData.ACCOUNT_1.publicKey);
should_1.default.equal(tx.casperTx.approvals[1].signer, testData.SECP256K1_PREFIX + testData.ACCOUNT_2.publicKey);
should_1.default.equal((0, utils_1.isValidTransactionSignature)(tx.casperTx.approvals[0].signature, tx.casperTx.hash, testData.ACCOUNT_1.publicKey), true);
should_1.default.equal((0, utils_1.isValidTransactionSignature)(tx.casperTx.approvals[1].signature, tx.casperTx.hash, testData.ACCOUNT_2.publicKey), true);
should_1.default.doesNotThrow(() => (0, utils_1.verifySignature)(tx.casperTx.approvals[0].signature, tx.casperTx.hash, testData.ACCOUNT_1.publicKey));
should_1.default.doesNotThrow(() => (0, utils_1.verifySignature)(tx.casperTx.approvals[1].signature, tx.casperTx.hash, testData.ACCOUNT_2.publicKey));
});
it('multiple valid using extended keys', async () => {
const tx = getTransaction();
const transferDeploy = getTransferDeploy();
if (transferDeploy) {
tx.casperTx = transferDeploy;
}
const keypair = new lib_1.KeyPair({ prv: testData.ACCOUNT_1.xPrivateKey });
const keypair2 = new lib_1.KeyPair({ prv: testData.ACCOUNT_2.xPrivateKey });
should_1.default.doesNotThrow(() => tx.sign(keypair));
should_1.default.equal(tx.casperTx.approvals[0].signer, testData.SECP256K1_PREFIX + testData.ACCOUNT_1.publicKey);
should_1.default.equal((0, utils_1.isValidTransactionSignature)(tx.casperTx.approvals[0].signature, tx.casperTx.hash, testData.ACCOUNT_1.publicKey), true);
should_1.default.doesNotThrow(() => (0, utils_1.verifySignature)(tx.casperTx.approvals[0].signature, tx.casperTx.hash, testData.ACCOUNT_1.publicKey));
should_1.default.doesNotThrow(() => tx.sign(keypair2));
should_1.default.equal(tx.casperTx.approvals[0].signer, testData.SECP256K1_PREFIX + testData.ACCOUNT_1.publicKey);
should_1.default.equal(tx.casperTx.approvals[1].signer, testData.SECP256K1_PREFIX + testData.ACCOUNT_2.publicKey);
should_1.default.equal((0, utils_1.isValidTransactionSignature)(tx.casperTx.approvals[0].signature, tx.casperTx.hash, testData.ACCOUNT_1.publicKey), true);
should_1.default.equal((0, utils_1.isValidTransactionSignature)(tx.casperTx.approvals[1].signature, tx.casperTx.hash, testData.ACCOUNT_2.publicKey), true);
should_1.default.doesNotThrow(() => (0, utils_1.verifySignature)(tx.casperTx.approvals[0].signature, tx.casperTx.hash, testData.ACCOUNT_1.publicKey));
should_1.default.doesNotThrow(() => (0, utils_1.verifySignature)(tx.casperTx.approvals[1].signature, tx.casperTx.hash, testData.ACCOUNT_2.publicKey));
});
it('multiple valid using one extended key', async () => {
const tx = getTransaction();
const transferDeploy = getTransferDeploy();
if (transferDeploy) {
tx.casperTx = transferDeploy;
}
const keypair = new lib_1.KeyPair({ prv: testData.ACCOUNT_1.xPrivateKey });
const keypair2 = new lib_1.KeyPair({ prv: testData.ACCOUNT_2.privateKey });
should_1.default.doesNotThrow(() => tx.sign(keypair));
should_1.default.equal(tx.casperTx.approvals[0].signer, testData.SECP256K1_PREFIX + testData.ACCOUNT_1.publicKey);
should_1.default.equal((0, utils_1.isValidTransactionSignature)(tx.casperTx.approvals[0].signature, tx.casperTx.hash, testData.ACCOUNT_1.publicKey), true);
should_1.default.doesNotThrow(() => (0, utils_1.verifySignature)(tx.casperTx.approvals[0].signature, tx.casperTx.hash, testData.ACCOUNT_1.publicKey));
should_1.default.doesNotThrow(() => tx.sign(keypair2));
should_1.default.equal(tx.casperTx.approvals[0].signer, testData.SECP256K1_PREFIX + testData.ACCOUNT_1.publicKey);
should_1.default.equal(tx.casperTx.approvals[1].signer, testData.SECP256K1_PREFIX + testData.ACCOUNT_2.publicKey);
should_1.default.equal((0, utils_1.isValidTransactionSignature)(tx.casperTx.approvals[0].signature, tx.casperTx.hash, testData.ACCOUNT_1.publicKey), true);
should_1.default.equal((0, utils_1.isValidTransactionSignature)(tx.casperTx.approvals[1].signature, tx.casperTx.hash, testData.ACCOUNT_2.publicKey), true);
should_1.default.doesNotThrow(() => (0, utils_1.verifySignature)(tx.casperTx.approvals[0].signature, tx.casperTx.hash, testData.ACCOUNT_1.publicKey));
should_1.default.doesNotThrow(() => (0, utils_1.verifySignature)(tx.casperTx.approvals[1].signature, tx.casperTx.hash, testData.ACCOUNT_2.publicKey));
});
});
describe('should reject sign if transaction signer is', () => {
it('invalid private key', function () {
const tx = getTransaction();
assert_1.default.throws(() => tx.sign(testData.INVALID_KEYPAIR_PRV));
});
it('public key', function () {
const tx = getTransaction();
const keypair = new lib_1.KeyPair({ pub: testData.ACCOUNT_1.publicKey });
assert_1.default.throws(() => tx.sign(keypair), (e) => e.message === testData.ERROR_MISSING_PRIVATE_KEY);
});
it('public extended key', function () {
const tx = getTransaction();
const keypair = new lib_1.KeyPair({ pub: testData.ACCOUNT_1.xPublicKey });
assert_1.default.throws(() => tx.sign(keypair), (e) => e.message === testData.ERROR_MISSING_PRIVATE_KEY);
});
});
describe('should return encoded tx', function () {
it('wallet initialization', async function () {
const walletInitTx = await getWalletInitTransaction();
const encodedTx = walletInitTx.toBroadcastFormat();
const walletInitJsonTx = JSON.parse(encodedTx);
const argName = 0;
const argValue = 1;
const owner0 = 0;
const owner1 = 1;
const owner2 = 2;
const ownersValues = new Map();
[owner0, owner1, owner2].forEach((index) => {
ownersValues.set(constants_1.OWNER_PREFIX + index, walletInitTx.casperTx.session.getArgByName(constants_1.OWNER_PREFIX + index).value());
});
const jsonOwnerArgs = walletInitJsonTx['deploy']['session']['ModuleBytes']['args'].filter((arg) => ownersValues.has(arg[argName]));
jsonOwnerArgs.length.should.equal(ownersValues.size);
jsonOwnerArgs.forEach((arg) => {
arg[argValue]['parsed'].should.be.equal(ownersValues.get(arg[argName]));
});
});
it('wallet initialization using extended key', async function () {
const walletInitTx = await getWalletInitTransactionUsignExtendedKey();
const encodedTx = walletInitTx.toBroadcastFormat();
const walletInitJsonTx = JSON.parse(encodedTx);
const argName = 0;
const argValue = 1;
const owner0 = 0;
const owner1 = 1;
const owner2 = 2;
const ownersValues = new Map();
[owner0, owner1, owner2].forEach((index) => {
ownersValues.set(constants_1.OWNER_PREFIX + index, walletInitTx.casperTx.session.getArgByName(constants_1.OWNER_PREFIX + index).value());
});
const jsonOwnerArgs = walletInitJsonTx['deploy']['session']['ModuleBytes']['args'].filter((arg) => ownersValues.has(arg[argName]));
jsonOwnerArgs.length.should.equal(ownersValues.size);
jsonOwnerArgs.forEach((arg) => {
arg[argValue]['parsed'].should.be.equal(ownersValues.get(arg[argName]));
});
});
it('transfer', async function () {
const transferTx = await getTransferTransaction();
const encodedTx = transferTx.toBroadcastFormat();
const transferJsonTx = JSON.parse(encodedTx);
const argName = 0;
const argValue = 1;
const transferValues = new Map();
transferValues.set('amount', (0, utils_1.getTransferAmount)(transferTx.casperTx.session));
transferValues.set('to_address', (0, utils_1.getTransferDestinationAddress)(transferTx.casperTx.session));
const transferId = (0, utils_1.getTransferId)(transferTx.casperTx.session);
if (transferId !== undefined) {
transferValues.set('id', transferId.toString());
}
const jsonOwnerArgs = transferJsonTx['deploy']['session']['Transfer']['args'].filter((arg) => transferValues.has(arg[argName]));
jsonOwnerArgs.length.should.equal(transferValues.size);
jsonOwnerArgs.forEach((arg) => {
arg[argValue]['parsed'].should.be.equal(transferValues.get(arg[argName]));
});
});
// TODO STLX-1174: get and decode encoded transaction
it('valid sign', function (done) {
done();
});
});
});
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"transaction.js","sourceRoot":"","sources":["../../../../test/unit/lib/transaction.ts"],"names":[],"mappings":"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","sourcesContent":["import assert from 'assert';\nimport should from 'should';\nimport { coins } from '@bitgo/statics';\nimport { CLString, DeployUtil, CLPublicKey as PublicKey } from 'casper-js-sdk';\nimport { Transaction } from '../../../src/lib/transaction';\nimport * as testData from '../../fixtures/resources';\nimport { KeyPair, TransactionBuilderFactory } from '../../../src/lib';\nimport { DEFAULT_CHAIN_NAMES, OWNER_PREFIX } from '../../../src/lib/constants';\nimport {\n  getTransferAmount,\n  getTransferDestinationAddress,\n  getTransferId,\n  isValidTransactionSignature,\n  verifySignature,\n} from '../../../src/lib/utils';\n\ndescribe('Cspr Transaction', () => {\n  const coin = coins.get('tcspr');\n  const factory = new TransactionBuilderFactory(coin);\n  const owner1Address = new KeyPair({ pub: testData.ACCOUNT_1.publicKey }).getAddress();\n  const owner2Address = new KeyPair({ pub: testData.ACCOUNT_2.publicKey }).getAddress();\n  const owner3Address = new KeyPair({ pub: testData.ACCOUNT_3.publicKey }).getAddress();\n  const sourceAddress = new KeyPair({ pub: testData.ROOT_ACCOUNT.publicKey }).getAddress();\n\n  const getTransaction = (): Transaction => {\n    return new Transaction(coin);\n  };\n\n  const getWalletInitTransaction = async (): Promise<Transaction> => {\n    const txBuilder = factory.getWalletInitializationBuilder();\n    txBuilder.fee(testData.FEE);\n    txBuilder.owner(owner1Address);\n    txBuilder.owner(owner2Address);\n    txBuilder.owner(owner3Address);\n    txBuilder.source({ address: sourceAddress });\n    txBuilder.sign({ key: testData.ROOT_ACCOUNT.privateKey });\n    return (await txBuilder.build()) as Transaction;\n  };\n\n  const getWalletInitTransactionUsignExtendedKey = async (): Promise<Transaction> => {\n    const txBuilder = factory.getWalletInitializationBuilder();\n    txBuilder.fee(testData.FEE);\n    txBuilder.owner(owner1Address);\n    txBuilder.owner(owner2Address);\n    txBuilder.owner(owner3Address);\n    txBuilder.source({ address: sourceAddress });\n    txBuilder.sign({ key: testData.ROOT_ACCOUNT.xPrivateKey });\n    return (await txBuilder.build()) as Transaction;\n  };\n\n  const getTransferTransaction = async (): Promise<Transaction> => {\n    const txBuilder = factory.getTransferBuilder();\n    txBuilder.fee({ gasLimit: testData.FEE.gasLimit, gasPrice: testData.FEE.gasPrice });\n    txBuilder.source({ address: sourceAddress });\n    txBuilder.to(owner2Address);\n    txBuilder.amount(testData.MIN_MOTES_AMOUNT);\n    txBuilder.transferId(255);\n    return (await txBuilder.build()) as Transaction;\n  };\n\n  // Creates a deploy instance, required to test signing.\n  const getTransferDeploy = (): DeployUtil.Deploy | undefined => {\n    const gasPrice = testData.FEE.gasPrice ? parseInt(testData.FEE.gasPrice, 10) : undefined;\n    const sourcePublicKey = PublicKey.fromHex(testData.SECP256K1_PREFIX + testData.ACCOUNT_1.publicKey);\n    const deployParams = new DeployUtil.DeployParams(sourcePublicKey, DEFAULT_CHAIN_NAMES.testnet, gasPrice);\n\n    const session = DeployUtil.ExecutableDeployItem.newTransfer(1, sourcePublicKey, undefined, 123);\n\n    const payment = DeployUtil.standardPayment(parseInt(testData.FEE.gasLimit, 10));\n\n    return DeployUtil.makeDeploy(deployParams, session, payment);\n  };\n\n  it('should throw empty transaction', () => {\n    const tx = getTransaction();\n    assert.throws(() => {\n      tx.toJson();\n    });\n    assert.throws(() => {\n      tx.toBroadcastFormat();\n    });\n  });\n\n  describe('should sign if transaction is', () => {\n    it('valid', async () => {\n      const tx = getTransaction();\n      const transferDeploy = getTransferDeploy();\n      if (transferDeploy) {\n        tx.casperTx = transferDeploy;\n      }\n      const keypair = new KeyPair({ prv: testData.ACCOUNT_1.privateKey });\n      should.doesNotThrow(() => tx.sign(keypair));\n      should.equal(tx.casperTx.approvals[0].signer, testData.SECP256K1_PREFIX + testData.ACCOUNT_1.publicKey);\n      should.equal(\n        isValidTransactionSignature(\n          tx.casperTx.approvals[0].signature,\n          tx.casperTx.hash,\n          Buffer.from(tx.casperTx.header.account.value()).toString('hex')\n        ),\n        true\n      );\n      should.doesNotThrow(() =>\n        verifySignature(\n          tx.casperTx.approvals[0].signature,\n          tx.casperTx.hash,\n          Buffer.from(tx.casperTx.header.account.value()).toString('hex')\n        )\n      );\n    });\n\n    it('valid using extended key', async () => {\n      const tx = getTransaction();\n      const transferDeploy = getTransferDeploy();\n      if (transferDeploy) {\n        tx.casperTx = transferDeploy;\n      }\n      const keypair = new KeyPair({ prv: testData.ACCOUNT_1.xPrivateKey });\n      should.doesNotThrow(() => tx.sign(keypair));\n      should.equal(tx.casperTx.approvals[0].signer, testData.SECP256K1_PREFIX + testData.ACCOUNT_1.publicKey);\n      should.equal(\n        isValidTransactionSignature(\n          tx.casperTx.approvals[0].signature,\n          tx.casperTx.hash,\n          Buffer.from(tx.casperTx.header.account.value()).toString('hex')\n        ),\n        true\n      );\n      should.doesNotThrow(() =>\n        verifySignature(\n          tx.casperTx.approvals[0].signature,\n          tx.casperTx.hash,\n          Buffer.from(tx.casperTx.header.account.value()).toString('hex')\n        )\n      );\n    });\n\n    it('multiple valid', async () => {\n      const tx = getTransaction();\n      const transferDeploy = getTransferDeploy();\n      if (transferDeploy) {\n        tx.casperTx = transferDeploy;\n      }\n      const keypair = new KeyPair({ prv: testData.ACCOUNT_1.privateKey });\n      const keypair2 = new KeyPair({ prv: testData.ACCOUNT_2.privateKey });\n      should.doesNotThrow(() => tx.sign(keypair));\n      should.equal(tx.casperTx.approvals[0].signer, testData.SECP256K1_PREFIX + testData.ACCOUNT_1.publicKey);\n      should.equal(\n        isValidTransactionSignature(tx.casperTx.approvals[0].signature, tx.casperTx.hash, testData.ACCOUNT_1.publicKey),\n        true\n      );\n      should.doesNotThrow(() =>\n        verifySignature(tx.casperTx.approvals[0].signature, tx.casperTx.hash, testData.ACCOUNT_1.publicKey)\n      );\n\n      should.doesNotThrow(() => tx.sign(keypair2));\n      should.equal(tx.casperTx.approvals[0].signer, testData.SECP256K1_PREFIX + testData.ACCOUNT_1.publicKey);\n      should.equal(tx.casperTx.approvals[1].signer, testData.SECP256K1_PREFIX + testData.ACCOUNT_2.publicKey);\n      should.equal(\n        isValidTransactionSignature(tx.casperTx.approvals[0].signature, tx.casperTx.hash, testData.ACCOUNT_1.publicKey),\n        true\n      );\n      should.equal(\n        isValidTransactionSignature(tx.casperTx.approvals[1].signature, tx.casperTx.hash, testData.ACCOUNT_2.publicKey),\n        true\n      );\n      should.doesNotThrow(() =>\n        verifySignature(tx.casperTx.approvals[0].signature, tx.casperTx.hash, testData.ACCOUNT_1.publicKey)\n      );\n      should.doesNotThrow(() =>\n        verifySignature(tx.casperTx.approvals[1].signature, tx.casperTx.hash, testData.ACCOUNT_2.publicKey)\n      );\n    });\n\n    it('multiple valid using extended keys', async () => {\n      const tx = getTransaction();\n      const transferDeploy = getTransferDeploy();\n      if (transferDeploy) {\n        tx.casperTx = transferDeploy;\n      }\n      const keypair = new KeyPair({ prv: testData.ACCOUNT_1.xPrivateKey });\n      const keypair2 = new KeyPair({ prv: testData.ACCOUNT_2.xPrivateKey });\n      should.doesNotThrow(() => tx.sign(keypair));\n      should.equal(tx.casperTx.approvals[0].signer, testData.SECP256K1_PREFIX + testData.ACCOUNT_1.publicKey);\n      should.equal(\n        isValidTransactionSignature(tx.casperTx.approvals[0].signature, tx.casperTx.hash, testData.ACCOUNT_1.publicKey),\n        true\n      );\n      should.doesNotThrow(() =>\n        verifySignature(tx.casperTx.approvals[0].signature, tx.casperTx.hash, testData.ACCOUNT_1.publicKey)\n      );\n\n      should.doesNotThrow(() => tx.sign(keypair2));\n      should.equal(tx.casperTx.approvals[0].signer, testData.SECP256K1_PREFIX + testData.ACCOUNT_1.publicKey);\n      should.equal(tx.casperTx.approvals[1].signer, testData.SECP256K1_PREFIX + testData.ACCOUNT_2.publicKey);\n      should.equal(\n        isValidTransactionSignature(tx.casperTx.approvals[0].signature, tx.casperTx.hash, testData.ACCOUNT_1.publicKey),\n        true\n      );\n      should.equal(\n        isValidTransactionSignature(tx.casperTx.approvals[1].signature, tx.casperTx.hash, testData.ACCOUNT_2.publicKey),\n        true\n      );\n      should.doesNotThrow(() =>\n        verifySignature(tx.casperTx.approvals[0].signature, tx.casperTx.hash, testData.ACCOUNT_1.publicKey)\n      );\n      should.doesNotThrow(() =>\n        verifySignature(tx.casperTx.approvals[1].signature, tx.casperTx.hash, testData.ACCOUNT_2.publicKey)\n      );\n    });\n\n    it('multiple valid using one extended key', async () => {\n      const tx = getTransaction();\n      const transferDeploy = getTransferDeploy();\n      if (transferDeploy) {\n        tx.casperTx = transferDeploy;\n      }\n      const keypair = new KeyPair({ prv: testData.ACCOUNT_1.xPrivateKey });\n      const keypair2 = new KeyPair({ prv: testData.ACCOUNT_2.privateKey });\n      should.doesNotThrow(() => tx.sign(keypair));\n      should.equal(tx.casperTx.approvals[0].signer, testData.SECP256K1_PREFIX + testData.ACCOUNT_1.publicKey);\n      should.equal(\n        isValidTransactionSignature(tx.casperTx.approvals[0].signature, tx.casperTx.hash, testData.ACCOUNT_1.publicKey),\n        true\n      );\n      should.doesNotThrow(() =>\n        verifySignature(tx.casperTx.approvals[0].signature, tx.casperTx.hash, testData.ACCOUNT_1.publicKey)\n      );\n\n      should.doesNotThrow(() => tx.sign(keypair2));\n      should.equal(tx.casperTx.approvals[0].signer, testData.SECP256K1_PREFIX + testData.ACCOUNT_1.publicKey);\n      should.equal(tx.casperTx.approvals[1].signer, testData.SECP256K1_PREFIX + testData.ACCOUNT_2.publicKey);\n      should.equal(\n        isValidTransactionSignature(tx.casperTx.approvals[0].signature, tx.casperTx.hash, testData.ACCOUNT_1.publicKey),\n        true\n      );\n      should.equal(\n        isValidTransactionSignature(tx.casperTx.approvals[1].signature, tx.casperTx.hash, testData.ACCOUNT_2.publicKey),\n        true\n      );\n      should.doesNotThrow(() =>\n        verifySignature(tx.casperTx.approvals[0].signature, tx.casperTx.hash, testData.ACCOUNT_1.publicKey)\n      );\n      should.doesNotThrow(() =>\n        verifySignature(tx.casperTx.approvals[1].signature, tx.casperTx.hash, testData.ACCOUNT_2.publicKey)\n      );\n    });\n  });\n\n  describe('should reject sign if transaction signer is', () => {\n    it('invalid private key', function () {\n      const tx = getTransaction();\n      assert.throws(() => tx.sign(testData.INVALID_KEYPAIR_PRV));\n    });\n\n    it('public key', function () {\n      const tx = getTransaction();\n      const keypair = new KeyPair({ pub: testData.ACCOUNT_1.publicKey });\n      assert.throws(\n        () => tx.sign(keypair),\n        (e: Error) => e.message === testData.ERROR_MISSING_PRIVATE_KEY\n      );\n    });\n\n    it('public extended key', function () {\n      const tx = getTransaction();\n      const keypair = new KeyPair({ pub: testData.ACCOUNT_1.xPublicKey });\n      assert.throws(\n        () => tx.sign(keypair),\n        (e: Error) => e.message === testData.ERROR_MISSING_PRIVATE_KEY\n      );\n    });\n  });\n\n  describe('should return encoded tx', function () {\n    it('wallet initialization', async function () {\n      const walletInitTx = await getWalletInitTransaction();\n      const encodedTx = walletInitTx.toBroadcastFormat();\n      const walletInitJsonTx = JSON.parse(encodedTx);\n\n      const argName = 0;\n      const argValue = 1;\n      const owner0 = 0;\n      const owner1 = 1;\n      const owner2 = 2;\n\n      const ownersValues = new Map();\n\n      [owner0, owner1, owner2].forEach((index) => {\n        ownersValues.set(\n          OWNER_PREFIX + index,\n          (walletInitTx.casperTx.session.getArgByName(OWNER_PREFIX + index) as CLString).value()\n        );\n      });\n\n      const jsonOwnerArgs = walletInitJsonTx['deploy']['session']['ModuleBytes']['args'].filter((arg) =>\n        ownersValues.has(arg[argName])\n      );\n      jsonOwnerArgs.length.should.equal(ownersValues.size);\n\n      jsonOwnerArgs.forEach((arg) => {\n        arg[argValue]['parsed'].should.be.equal(ownersValues.get(arg[argName]));\n      });\n    });\n\n    it('wallet initialization using extended key', async function () {\n      const walletInitTx = await getWalletInitTransactionUsignExtendedKey();\n      const encodedTx = walletInitTx.toBroadcastFormat();\n      const walletInitJsonTx = JSON.parse(encodedTx);\n\n      const argName = 0;\n      const argValue = 1;\n      const owner0 = 0;\n      const owner1 = 1;\n      const owner2 = 2;\n\n      const ownersValues = new Map();\n\n      [owner0, owner1, owner2].forEach((index) => {\n        ownersValues.set(\n          OWNER_PREFIX + index,\n          (walletInitTx.casperTx.session.getArgByName(OWNER_PREFIX + index) as CLString).value()\n        );\n      });\n\n      const jsonOwnerArgs = walletInitJsonTx['deploy']['session']['ModuleBytes']['args'].filter((arg) =>\n        ownersValues.has(arg[argName])\n      );\n      jsonOwnerArgs.length.should.equal(ownersValues.size);\n\n      jsonOwnerArgs.forEach((arg) => {\n        arg[argValue]['parsed'].should.be.equal(ownersValues.get(arg[argName]));\n      });\n    });\n\n    it('transfer', async function () {\n      const transferTx = await getTransferTransaction();\n      const encodedTx = transferTx.toBroadcastFormat();\n      const transferJsonTx = JSON.parse(encodedTx);\n\n      const argName = 0;\n      const argValue = 1;\n\n      const transferValues = new Map();\n\n      transferValues.set('amount', getTransferAmount(transferTx.casperTx.session));\n      transferValues.set('to_address', getTransferDestinationAddress(transferTx.casperTx.session));\n      const transferId = getTransferId(transferTx.casperTx.session);\n      if (transferId !== undefined) {\n        transferValues.set('id', transferId.toString());\n      }\n\n      const jsonOwnerArgs = transferJsonTx['deploy']['session']['Transfer']['args'].filter((arg) =>\n        transferValues.has(arg[argName])\n      );\n      jsonOwnerArgs.length.should.equal(transferValues.size);\n\n      jsonOwnerArgs.forEach((arg) => {\n        arg[argValue]['parsed'].should.be.equal(transferValues.get(arg[argName]));\n      });\n    });\n\n    // TODO STLX-1174: get and decode encoded transaction\n    it('valid sign', function (done) {\n      done();\n    });\n  });\n});\n"]}Выполнить команду
Для локальной разработки. Не используйте в интернете!