PHP WebShell
Текущая директория: /opt/BitGoJS/modules/unspents/dist/test/signedTx
Просмотр файла: txCombinations.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 should_1 = __importDefault(require("should"));
const src_1 = require("../../src");
const testutils_1 = require("../testutils");
const txGen_1 = require("./txGen");
const utxolib = __importStar(require("@bitgo/utxo-lib"));
const keys = [1, 2, 3].map((v) => utxolib.bip32.fromSeed(Buffer.alloc(16, `test/2/${v}`), utxolib.networks.bitcoin));
const rootWalletKeys = new utxolib.bitgo.RootWalletKeys([keys[0], keys[1], keys[2]]);
const testDimensionsFromTx = (txCombo) => {
const { inputTypes, outputTypes, expectedDims } = txCombo;
describe(`Combination inputs=${inputTypes}; outputs=${outputTypes}`, function () {
const nInputs = inputTypes.length;
const outputDims = src_1.Dimensions.sum(...outputTypes.map(testutils_1.getOutputDimensionsForUnspentType));
it(`calculates dimensions from unsigned transaction`, function () {
const unsignedTx = txCombo.getUnsignedTx();
// does not work for unsigned transactions
should_1.default.throws(() => src_1.Dimensions.fromTransaction(unsignedTx));
// unless explicitly allowed
src_1.Dimensions.fromTransaction(unsignedTx, { assumeUnsigned: src_1.Dimensions.ASSUME_P2SH }).should.eql(src_1.Dimensions.sum({ nP2shInputs: nInputs }, outputDims));
src_1.Dimensions.fromTransaction(unsignedTx, { assumeUnsigned: src_1.Dimensions.ASSUME_P2SH_P2WSH }).should.eql(src_1.Dimensions.sum({ nP2shP2wshInputs: nInputs }, outputDims));
src_1.Dimensions.fromTransaction(unsignedTx, { assumeUnsigned: src_1.Dimensions.ASSUME_P2WSH }).should.eql(src_1.Dimensions.sum({ nP2wshInputs: nInputs }, outputDims));
});
it(`calculates dimensions for signed transaction`, function () {
const dimensions = src_1.Dimensions.fromTransaction(txCombo.getSignedTx());
dimensions.should.eql(expectedDims);
});
it(`calculates dimensions for signed input of transaction`, function () {
const signedTx = txCombo.getSignedTx();
// test Dimensions.fromInput()
inputTypes.forEach((input, i) => src_1.Dimensions.fromInput(signedTx.ins[i]).should.eql(src_1.Dimensions.sum((0, testutils_1.getInputDimensionsForUnspentType)(input))));
});
});
};
const testDimensionsFromPsbt = (keys, inputTypes, outputTypes, expectedDims) => {
describe(`Psbt Combination inputs=${inputTypes}; outputs=${outputTypes}`, function () {
['unsigned', 'halfsigned', 'fullysigned'].forEach((s) => {
it(`calculates dimensions from ${s} psbt`, function () {
const dimensions = src_1.Dimensions.fromPsbt((0, testutils_1.constructPsbt)(keys, inputTypes, outputTypes, s));
dimensions.should.eql(expectedDims);
});
});
it(`calculates dimensions for signed input of psbt`, function () {
const signedPsbt = (0, testutils_1.constructPsbt)(keys, inputTypes, outputTypes, 'fullysigned');
inputTypes.forEach((input, i) => src_1.Dimensions.fromPsbtInput(signedPsbt.data.inputs[i]).should.eql(src_1.Dimensions.sum((0, testutils_1.getInputDimensionsForUnspentType)(input))));
});
});
};
describe(`Dimensions for transaction combinations`, function () {
// p2trMusig2 is supported only with PSBT
const scriptTypes = utxolib.bitgo.outputScripts.scriptTypes2Of3.filter((t) => t !== 'p2trMusig2');
const params = {
inputTypes: [...scriptTypes, testutils_1.UnspentTypeP2shP2pk],
maxNInputs: 2,
outputTypes: [...scriptTypes, ...Object.keys(testutils_1.UnspentTypePubKeyHash)],
maxNOutputs: 2,
};
(0, txGen_1.runCombinations)(params, (inputTypeCombo, outputTypeCombo) => {
const expectedInputDims = src_1.Dimensions.sum(...inputTypeCombo.map(testutils_1.getInputDimensionsForUnspentType));
const expectedOutputDims = src_1.Dimensions.sum(...outputTypeCombo.map(testutils_1.getOutputDimensionsForUnspentType));
testDimensionsFromTx(new txGen_1.TxCombo(keys, inputTypeCombo, outputTypeCombo, expectedInputDims.plus(expectedOutputDims)));
// Doubling the inputs should yield twice the input dims
testDimensionsFromTx(new txGen_1.TxCombo(keys, [...inputTypeCombo, ...inputTypeCombo], outputTypeCombo, expectedInputDims.plus(expectedInputDims).plus(expectedOutputDims)));
// Same for outputs
testDimensionsFromTx(new txGen_1.TxCombo(keys, inputTypeCombo, [...outputTypeCombo, ...outputTypeCombo], expectedInputDims.plus(expectedOutputDims).plus(expectedOutputDims)));
});
});
describe(`Dimensions for PSBT combinations`, function () {
const params = {
inputTypes: [
...utxolib.bitgo.outputScripts.scriptTypes2Of3,
utxolib.bitgo.outputScripts.scriptTypeP2shP2pk,
'taprootKeyPathSpend',
],
maxNInputs: 1,
outputTypes: [...Object.keys(testutils_1.UnspentTypeScript2of3), ...Object.keys(testutils_1.UnspentTypePubKeyHash)],
maxNOutputs: 1,
};
it(`does not work for unknown psbt input`, function () {
const psbt = utxolib.bitgo.createPsbtForNetwork({ network: utxolib.networks.bitcoin });
psbt.addInput({ hash: Buffer.alloc(32), index: 0 });
should_1.default.throws(() => src_1.Dimensions.fromPsbt(psbt));
});
(0, txGen_1.runCombinations)(params, (inputTypeCombo, outputTypeCombo) => {
const expectedInputDims = src_1.Dimensions.sum(...inputTypeCombo.map(testutils_1.getInputDimensionsForUnspentType));
const expectedOutputDims = src_1.Dimensions.sum(...outputTypeCombo.map(testutils_1.getOutputDimensionsForUnspentType));
testDimensionsFromPsbt(rootWalletKeys, inputTypeCombo, outputTypeCombo, expectedInputDims.plus(expectedOutputDims));
// Doubling the inputs should yield twice the input dims
testDimensionsFromPsbt(rootWalletKeys, [...inputTypeCombo, ...inputTypeCombo], outputTypeCombo, expectedInputDims.plus(expectedInputDims).plus(expectedOutputDims));
// Same for outputs
testDimensionsFromPsbt(rootWalletKeys, inputTypeCombo, [...outputTypeCombo, ...outputTypeCombo], expectedInputDims.plus(expectedOutputDims).plus(expectedOutputDims));
});
});
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"txCombinations.js","sourceRoot":"","sources":["../../../test/signedTx/txCombinations.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,oDAA4B;AAC5B,mCAAuC;AAEvC,4CAQsB;AAEtB,mCAAmD;AACnD,yDAA2C;AAI3C,MAAM,IAAI,GAAG,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAC/B,OAAO,CAAC,KAAK,CAAC,QAAQ,CAAC,MAAM,CAAC,KAAK,CAAC,EAAE,EAAE,UAAU,CAAC,EAAE,CAAC,EAAE,OAAO,CAAC,QAAQ,CAAC,OAAO,CAAC,CACtD,CAAC;AAE9B,MAAM,cAAc,GAAG,IAAI,OAAO,CAAC,KAAK,CAAC,cAAc,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,IAAI,CAAC,CAAC,CAAC,EAAE,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;AAErF,MAAM,oBAAoB,GAAG,CAAC,OAAY,EAAE,EAAE;IAC5C,MAAM,EAAE,UAAU,EAAE,WAAW,EAAE,YAAY,EAAE,GAAG,OAAO,CAAC;IAE1D,QAAQ,CAAC,sBAAsB,UAAU,aAAa,WAAW,EAAE,EAAE;QACnE,MAAM,OAAO,GAAG,UAAU,CAAC,MAAM,CAAC;QAClC,MAAM,UAAU,GAAG,gBAAU,CAAC,GAAG,CAAC,GAAG,WAAW,CAAC,GAAG,CAAC,6CAAiC,CAAC,CAAC,CAAC;QAEzF,EAAE,CAAC,iDAAiD,EAAE;YACpD,MAAM,UAAU,GAAG,OAAO,CAAC,aAAa,EAAE,CAAC;YAE3C,0CAA0C;YAC1C,gBAAM,CAAC,MAAM,CAAC,GAAG,EAAE,CAAC,gBAAU,CAAC,eAAe,CAAC,UAAU,CAAC,CAAC,CAAC;YAE5D,4BAA4B;YAC5B,gBAAU,CAAC,eAAe,CAAC,UAAU,EAAE,EAAE,cAAc,EAAE,gBAAU,CAAC,WAAW,EAAE,CAAC,CAAC,MAAM,CAAC,GAAG,CAC3F,gBAAU,CAAC,GAAG,CAAC,EAAE,WAAW,EAAE,OAAO,EAAE,EAAE,UAAU,CAAC,CACrD,CAAC;YAEF,gBAAU,CAAC,eAAe,CAAC,UAAU,EAAE,EAAE,cAAc,EAAE,gBAAU,CAAC,iBAAiB,EAAE,CAAC,CAAC,MAAM,CAAC,GAAG,CACjG,gBAAU,CAAC,GAAG,CAAC,EAAE,gBAAgB,EAAE,OAAO,EAAE,EAAE,UAAU,CAAC,CAC1D,CAAC;YAEF,gBAAU,CAAC,eAAe,CAAC,UAAU,EAAE,EAAE,cAAc,EAAE,gBAAU,CAAC,YAAY,EAAE,CAAC,CAAC,MAAM,CAAC,GAAG,CAC5F,gBAAU,CAAC,GAAG,CAAC,EAAE,YAAY,EAAE,OAAO,EAAE,EAAE,UAAU,CAAC,CACtD,CAAC;QACJ,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,8CAA8C,EAAE;YACjD,MAAM,UAAU,GAAG,gBAAU,CAAC,eAAe,CAAC,OAAO,CAAC,WAAW,EAAE,CAAC,CAAC;YACrE,UAAU,CAAC,MAAM,CAAC,GAAG,CAAC,YAAY,CAAC,CAAC;QACtC,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,uDAAuD,EAAE;YAC1D,MAAM,QAAQ,GAAG,OAAO,CAAC,WAAW,EAAE,CAAC;YAEvC,8BAA8B;YAC9B,UAAU,CAAC,OAAO,CAAC,CAAC,KAAU,EAAE,CAAS,EAAE,EAAE,CAC3C,gBAAU,CAAC,SAAS,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,GAAG,CAAC,gBAAU,CAAC,GAAG,CAAC,IAAA,4CAAgC,EAAC,KAAK,CAAC,CAAC,CAAC,CAC1G,CAAC;QACJ,CAAC,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;AACL,CAAC,CAAC;AAEF,MAAM,sBAAsB,GAAG,CAC7B,IAAkC,EAClC,UAA6B,EAC7B,WAA8B,EAC9B,YAAwB,EACxB,EAAE;IACF,QAAQ,CAAC,2BAA2B,UAAU,aAAa,WAAW,EAAE,EAAE;QACvE,CAAC,UAAU,EAAE,YAAY,EAAE,aAAa,CAAW,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,EAAE;YACjE,EAAE,CAAC,8BAA8B,CAAC,OAAO,EAAE;gBACzC,MAAM,UAAU,GAAG,gBAAU,CAAC,QAAQ,CAAC,IAAA,yBAAa,EAAC,IAAI,EAAE,UAAU,EAAE,WAAW,EAAE,CAAC,CAAC,CAAC,CAAC;gBACxF,UAAU,CAAC,MAAM,CAAC,GAAG,CAAC,YAAY,CAAC,CAAC;YACtC,CAAC,CAAC,CAAC;QACL,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,gDAAgD,EAAE;YACnD,MAAM,UAAU,GAAG,IAAA,yBAAa,EAAC,IAAI,EAAE,UAAU,EAAE,WAAW,EAAE,aAAa,CAAC,CAAC;YAE/E,UAAU,CAAC,OAAO,CAAC,CAAC,KAAU,EAAE,CAAS,EAAE,EAAE,CAC3C,gBAAU,CAAC,aAAa,CAAC,UAAU,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,GAAG,CAC5D,gBAAU,CAAC,GAAG,CAAC,IAAA,4CAAgC,EAAC,KAAK,CAAC,CAAC,CACxD,CACF,CAAC;QACJ,CAAC,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;AACL,CAAC,CAAC;AAEF,QAAQ,CAAC,yCAAyC,EAAE;IAClD,yCAAyC;IACzC,MAAM,WAAW,GAAG,OAAO,CAAC,KAAK,CAAC,aAAa,CAAC,eAAe,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,KAAK,YAAY,CAAC,CAAC;IAClG,MAAM,MAAM,GAAG;QACb,UAAU,EAAE,CAAC,GAAG,WAAW,EAAE,+BAAmB,CAAsB;QACtE,UAAU,EAAE,CAAC;QACb,WAAW,EAAE,CAAC,GAAG,WAAW,EAAE,GAAG,MAAM,CAAC,IAAI,CAAC,iCAAqB,CAAC,CAAsB;QACzF,WAAW,EAAE,CAAC;KACf,CAAC;IAEF,IAAA,uBAAe,EAAC,MAAM,EAAE,CAAC,cAAiC,EAAE,eAAkC,EAAE,EAAE;QAChG,MAAM,iBAAiB,GAAG,gBAAU,CAAC,GAAG,CAAC,GAAG,cAAc,CAAC,GAAG,CAAC,4CAAgC,CAAC,CAAC,CAAC;QAClG,MAAM,kBAAkB,GAAG,gBAAU,CAAC,GAAG,CAAC,GAAG,eAAe,CAAC,GAAG,CAAC,6CAAiC,CAAC,CAAC,CAAC;QAErG,oBAAoB,CAClB,IAAI,eAAO,CAAC,IAAI,EAAE,cAAc,EAAE,eAAe,EAAE,iBAAiB,CAAC,IAAI,CAAC,kBAAkB,CAAC,CAAC,CAC/F,CAAC;QAEF,wDAAwD;QACxD,oBAAoB,CAClB,IAAI,eAAO,CACT,IAAI,EACJ,CAAC,GAAG,cAAc,EAAE,GAAG,cAAc,CAAC,EACtC,eAAe,EACf,iBAAiB,CAAC,IAAI,CAAC,iBAAiB,CAAC,CAAC,IAAI,CAAC,kBAAkB,CAAC,CACnE,CACF,CAAC;QAEF,mBAAmB;QACnB,oBAAoB,CAClB,IAAI,eAAO,CACT,IAAI,EACJ,cAAc,EACd,CAAC,GAAG,eAAe,EAAE,GAAG,eAAe,CAAC,EACxC,iBAAiB,CAAC,IAAI,CAAC,kBAAkB,CAAC,CAAC,IAAI,CAAC,kBAAkB,CAAC,CACpE,CACF,CAAC;IACJ,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC;AAEH,QAAQ,CAAC,kCAAkC,EAAE;IAC3C,MAAM,MAAM,GAAG;QACb,UAAU,EAAE;YACV,GAAG,OAAO,CAAC,KAAK,CAAC,aAAa,CAAC,eAAe;YAC9C,OAAO,CAAC,KAAK,CAAC,aAAa,CAAC,kBAAkB;YAC9C,qBAAqB;SACD;QACtB,UAAU,EAAE,CAAC;QACb,WAAW,EAAE,CAAC,GAAG,MAAM,CAAC,IAAI,CAAC,iCAAqB,CAAC,EAAE,GAAG,MAAM,CAAC,IAAI,CAAC,iCAAqB,CAAC,CAAC;QAC3F,WAAW,EAAE,CAAC;KACf,CAAC;IAEF,EAAE,CAAC,sCAAsC,EAAE;QACzC,MAAM,IAAI,GAAG,OAAO,CAAC,KAAK,CAAC,oBAAoB,CAAC,EAAE,OAAO,EAAE,OAAO,CAAC,QAAQ,CAAC,OAAO,EAAE,CAAC,CAAC;QACvF,IAAI,CAAC,QAAQ,CAAC,EAAE,IAAI,EAAE,MAAM,CAAC,KAAK,CAAC,EAAE,CAAC,EAAE,KAAK,EAAE,CAAC,EAAE,CAAC,CAAC;QACpD,gBAAM,CAAC,MAAM,CAAC,GAAG,EAAE,CAAC,gBAAU,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC,CAAC;IACjD,CAAC,CAAC,CAAC;IAEH,IAAA,uBAAe,EAAC,MAAM,EAAE,CAAC,cAAiC,EAAE,eAAkC,EAAE,EAAE;QAChG,MAAM,iBAAiB,GAAG,gBAAU,CAAC,GAAG,CAAC,GAAG,cAAc,CAAC,GAAG,CAAC,4CAAgC,CAAC,CAAC,CAAC;QAClG,MAAM,kBAAkB,GAAG,gBAAU,CAAC,GAAG,CAAC,GAAG,eAAe,CAAC,GAAG,CAAC,6CAAiC,CAAC,CAAC,CAAC;QAErG,sBAAsB,CAAC,cAAc,EAAE,cAAc,EAAE,eAAe,EAAE,iBAAiB,CAAC,IAAI,CAAC,kBAAkB,CAAC,CAAC,CAAC;QAEpH,wDAAwD;QACxD,sBAAsB,CACpB,cAAc,EACd,CAAC,GAAG,cAAc,EAAE,GAAG,cAAc,CAAC,EACtC,eAAe,EACf,iBAAiB,CAAC,IAAI,CAAC,iBAAiB,CAAC,CAAC,IAAI,CAAC,kBAAkB,CAAC,CACnE,CAAC;QAEF,mBAAmB;QACnB,sBAAsB,CACpB,cAAc,EACd,cAAc,EACd,CAAC,GAAG,eAAe,EAAE,GAAG,eAAe,CAAC,EACxC,iBAAiB,CAAC,IAAI,CAAC,kBAAkB,CAAC,CAAC,IAAI,CAAC,kBAAkB,CAAC,CACpE,CAAC;IACJ,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC","sourcesContent":["import should from 'should';\nimport { Dimensions } from '../../src';\n\nimport {\n  constructPsbt,\n  getInputDimensionsForUnspentType,\n  getOutputDimensionsForUnspentType,\n  TestUnspentType,\n  UnspentTypeP2shP2pk,\n  UnspentTypePubKeyHash,\n  UnspentTypeScript2of3,\n} from '../testutils';\n\nimport { runCombinations, TxCombo } from './txGen';\nimport * as utxolib from '@bitgo/utxo-lib';\n\nexport type InputScriptType = utxolib.bitgo.outputScripts.ScriptType | 'taprootKeyPathSpend';\n\nconst keys = [1, 2, 3].map((v) =>\n  utxolib.bip32.fromSeed(Buffer.alloc(16, `test/2/${v}`), utxolib.networks.bitcoin)\n) as utxolib.BIP32Interface[];\n\nconst rootWalletKeys = new utxolib.bitgo.RootWalletKeys([keys[0], keys[1], keys[2]]);\n\nconst testDimensionsFromTx = (txCombo: any) => {\n  const { inputTypes, outputTypes, expectedDims } = txCombo;\n\n  describe(`Combination inputs=${inputTypes}; outputs=${outputTypes}`, function () {\n    const nInputs = inputTypes.length;\n    const outputDims = Dimensions.sum(...outputTypes.map(getOutputDimensionsForUnspentType));\n\n    it(`calculates dimensions from unsigned transaction`, function () {\n      const unsignedTx = txCombo.getUnsignedTx();\n\n      // does not work for unsigned transactions\n      should.throws(() => Dimensions.fromTransaction(unsignedTx));\n\n      // unless explicitly allowed\n      Dimensions.fromTransaction(unsignedTx, { assumeUnsigned: Dimensions.ASSUME_P2SH }).should.eql(\n        Dimensions.sum({ nP2shInputs: nInputs }, outputDims)\n      );\n\n      Dimensions.fromTransaction(unsignedTx, { assumeUnsigned: Dimensions.ASSUME_P2SH_P2WSH }).should.eql(\n        Dimensions.sum({ nP2shP2wshInputs: nInputs }, outputDims)\n      );\n\n      Dimensions.fromTransaction(unsignedTx, { assumeUnsigned: Dimensions.ASSUME_P2WSH }).should.eql(\n        Dimensions.sum({ nP2wshInputs: nInputs }, outputDims)\n      );\n    });\n\n    it(`calculates dimensions for signed transaction`, function () {\n      const dimensions = Dimensions.fromTransaction(txCombo.getSignedTx());\n      dimensions.should.eql(expectedDims);\n    });\n\n    it(`calculates dimensions for signed input of transaction`, function () {\n      const signedTx = txCombo.getSignedTx();\n\n      // test Dimensions.fromInput()\n      inputTypes.forEach((input: any, i: number) =>\n        Dimensions.fromInput(signedTx.ins[i]).should.eql(Dimensions.sum(getInputDimensionsForUnspentType(input)))\n      );\n    });\n  });\n};\n\nconst testDimensionsFromPsbt = (\n  keys: utxolib.bitgo.RootWalletKeys,\n  inputTypes: InputScriptType[],\n  outputTypes: TestUnspentType[],\n  expectedDims: Dimensions\n) => {\n  describe(`Psbt Combination inputs=${inputTypes}; outputs=${outputTypes}`, function () {\n    (['unsigned', 'halfsigned', 'fullysigned'] as const).forEach((s) => {\n      it(`calculates dimensions from ${s} psbt`, function () {\n        const dimensions = Dimensions.fromPsbt(constructPsbt(keys, inputTypes, outputTypes, s));\n        dimensions.should.eql(expectedDims);\n      });\n    });\n\n    it(`calculates dimensions for signed input of psbt`, function () {\n      const signedPsbt = constructPsbt(keys, inputTypes, outputTypes, 'fullysigned');\n\n      inputTypes.forEach((input: any, i: number) =>\n        Dimensions.fromPsbtInput(signedPsbt.data.inputs[i]).should.eql(\n          Dimensions.sum(getInputDimensionsForUnspentType(input))\n        )\n      );\n    });\n  });\n};\n\ndescribe(`Dimensions for transaction combinations`, function () {\n  // p2trMusig2 is supported only with PSBT\n  const scriptTypes = utxolib.bitgo.outputScripts.scriptTypes2Of3.filter((t) => t !== 'p2trMusig2');\n  const params = {\n    inputTypes: [...scriptTypes, UnspentTypeP2shP2pk] as InputScriptType[],\n    maxNInputs: 2,\n    outputTypes: [...scriptTypes, ...Object.keys(UnspentTypePubKeyHash)] as TestUnspentType[],\n    maxNOutputs: 2,\n  };\n\n  runCombinations(params, (inputTypeCombo: InputScriptType[], outputTypeCombo: TestUnspentType[]) => {\n    const expectedInputDims = Dimensions.sum(...inputTypeCombo.map(getInputDimensionsForUnspentType));\n    const expectedOutputDims = Dimensions.sum(...outputTypeCombo.map(getOutputDimensionsForUnspentType));\n\n    testDimensionsFromTx(\n      new TxCombo(keys, inputTypeCombo, outputTypeCombo, expectedInputDims.plus(expectedOutputDims))\n    );\n\n    // Doubling the inputs should yield twice the input dims\n    testDimensionsFromTx(\n      new TxCombo(\n        keys,\n        [...inputTypeCombo, ...inputTypeCombo],\n        outputTypeCombo,\n        expectedInputDims.plus(expectedInputDims).plus(expectedOutputDims)\n      )\n    );\n\n    // Same for outputs\n    testDimensionsFromTx(\n      new TxCombo(\n        keys,\n        inputTypeCombo,\n        [...outputTypeCombo, ...outputTypeCombo],\n        expectedInputDims.plus(expectedOutputDims).plus(expectedOutputDims)\n      )\n    );\n  });\n});\n\ndescribe(`Dimensions for PSBT combinations`, function () {\n  const params = {\n    inputTypes: [\n      ...utxolib.bitgo.outputScripts.scriptTypes2Of3,\n      utxolib.bitgo.outputScripts.scriptTypeP2shP2pk,\n      'taprootKeyPathSpend',\n    ] as InputScriptType[],\n    maxNInputs: 1,\n    outputTypes: [...Object.keys(UnspentTypeScript2of3), ...Object.keys(UnspentTypePubKeyHash)],\n    maxNOutputs: 1,\n  };\n\n  it(`does not work for unknown psbt input`, function () {\n    const psbt = utxolib.bitgo.createPsbtForNetwork({ network: utxolib.networks.bitcoin });\n    psbt.addInput({ hash: Buffer.alloc(32), index: 0 });\n    should.throws(() => Dimensions.fromPsbt(psbt));\n  });\n\n  runCombinations(params, (inputTypeCombo: InputScriptType[], outputTypeCombo: TestUnspentType[]) => {\n    const expectedInputDims = Dimensions.sum(...inputTypeCombo.map(getInputDimensionsForUnspentType));\n    const expectedOutputDims = Dimensions.sum(...outputTypeCombo.map(getOutputDimensionsForUnspentType));\n\n    testDimensionsFromPsbt(rootWalletKeys, inputTypeCombo, outputTypeCombo, expectedInputDims.plus(expectedOutputDims));\n\n    // Doubling the inputs should yield twice the input dims\n    testDimensionsFromPsbt(\n      rootWalletKeys,\n      [...inputTypeCombo, ...inputTypeCombo],\n      outputTypeCombo,\n      expectedInputDims.plus(expectedInputDims).plus(expectedOutputDims)\n    );\n\n    // Same for outputs\n    testDimensionsFromPsbt(\n      rootWalletKeys,\n      inputTypeCombo,\n      [...outputTypeCombo, ...outputTypeCombo],\n      expectedInputDims.plus(expectedOutputDims).plus(expectedOutputDims)\n    );\n  });\n});\n"]}Выполнить команду
Для локальной разработки. Не используйте в интернете!