PHP WebShell

Текущая директория: /opt/BitGoJS/modules/unspents/dist/test/signedTx

Просмотр файла: inputWeights.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;
    };
})();
Object.defineProperty(exports, "__esModule", { value: true });
const assert = __importStar(require("assert"));
const utxolib = __importStar(require("@bitgo/utxo-lib"));
const utxo_lib_1 = require("@bitgo/utxo-lib");
const inputWeights_1 = require("../../src/inputWeights");
const scriptSizes_1 = require("../../src/scriptSizes");
const testutils_1 = require("../testutils");
describe('Input Script Sizes (Worst-Case)', function () {
    const keys = [1, 2, 3].map((v) => utxo_lib_1.bip32.fromSeed(Buffer.alloc(16, `test/${v}`)));
    const rootWalletKeys = new utxolib.bitgo.RootWalletKeys([keys[0], keys[1], keys[2]]);
    function getLargestInputWithType(inputType, signKeys, inputCount = 100) {
        const signerName = signKeys[0];
        const cosignerName = signKeys.length > 1 ? signKeys[1] : signerName;
        const inputScriptTypes = Array.from({ length: inputCount }).fill(inputType);
        const outputScriptTypes = [testutils_1.UnspentTypeScript2of3.p2sh];
        return (0, testutils_1.getSignedTransaction)(rootWalletKeys, signerName, cosignerName, inputScriptTypes, outputScriptTypes).ins.reduce((a, b) => ((0, inputWeights_1.getInputWeight)(a) > (0, inputWeights_1.getInputWeight)(b) ? a : b));
    }
    function getInputComponents(input) {
        const decompiled = utxolib.script.decompile(input.script);
        if (!decompiled) {
            throw new Error();
        }
        const script = decompiled.map((v) => {
            if (!Buffer.isBuffer(v)) {
                return { length: 1 };
            }
            return { length: v.length + (0, scriptSizes_1.pushdataEncodingLength)(v.length) };
        });
        const witness = (input.witness || []).map((v) => ({ length: v.length }));
        const scriptSize = script.reduce((a, b) => a + b.length, 0);
        assert.strictEqual(scriptSize, input.script.length, utxolib.script.toASM(decompiled));
        return {
            script: script.map((v) => v.length),
            witness: witness.map((v) => v.length),
        };
    }
    function runTestComponentSizes(inputType, signKeys) {
        const signKeysStr = signKeys.join(',');
        describe(`inputType=${inputType} signKeys=${signKeysStr}`, function () {
            it(`component sizes`, function () {
                this.timeout(10000);
                let expectedComponents;
                switch (inputType) {
                    case 'p2sh':
                        expectedComponents = inputWeights_1.inputComponentsP2sh;
                        break;
                    case 'p2shP2wsh':
                        expectedComponents = inputWeights_1.inputComponentsP2shP2wsh;
                        break;
                    case 'p2wsh':
                        expectedComponents = inputWeights_1.inputComponentsP2wsh;
                        break;
                    case 'p2shP2pk':
                        expectedComponents = inputWeights_1.inputComponentsP2shP2pk;
                        break;
                    case 'p2tr':
                        if (signKeys[1] === 'bitgo') {
                            expectedComponents = inputWeights_1.inputComponentsP2trScriptSpendLevel1;
                        }
                        else if (signKeys[1] === 'backup') {
                            expectedComponents = inputWeights_1.inputComponentsP2trScriptSpendLevel2;
                        }
                        else {
                            throw new Error(`unexpected cosigner`);
                        }
                        break;
                    case 'p2trMusig2':
                        // assumes only script path
                        expectedComponents = inputWeights_1.inputComponentsP2trScriptSpendLevel1;
                        break;
                    case 'taprootKeyPathSpend':
                        expectedComponents = inputWeights_1.inputComponentsP2trKeySpend;
                        break;
                    default:
                        throw new Error(`invalid inputType ${inputType}`);
                }
                const input = getLargestInputWithType(inputType, signKeys, inputType === 'p2tr' || inputType === 'p2trMusig2' || inputType === 'taprootKeyPathSpend' ? 10 : 100);
                const components = getInputComponents(input);
                assert.deepStrictEqual(components, expectedComponents);
                assert.strictEqual((0, inputWeights_1.getInputComponentsWeight)(components), (0, inputWeights_1.getInputWeight)(input));
            });
        });
    }
    (0, testutils_1.getInputScriptTypes)().forEach((inputType) => {
        if (inputType !== 'p2trMusig2') {
            runTestComponentSizes(inputType, inputType === 'p2shP2pk' ? ['user'] : ['user', 'bitgo']);
        }
        if (inputType !== 'p2shP2pk' && inputType !== 'taprootKeyPathSpend') {
            runTestComponentSizes(inputType, ['user', 'backup']);
        }
    });
});
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"inputWeights.js","sourceRoot":"","sources":["../../../test/signedTx/inputWeights.ts"],"names":[],"mappings":"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","sourcesContent":["import * as assert from 'assert';\n\nimport * as mocha from 'mocha';\nimport * as utxolib from '@bitgo/utxo-lib';\nimport { bip32, BIP32Interface } from '@bitgo/utxo-lib';\nimport {\n  getInputComponentsWeight,\n  getInputWeight,\n  InputComponents,\n  inputComponentsP2sh,\n  inputComponentsP2shP2pk,\n  inputComponentsP2shP2wsh,\n  inputComponentsP2trKeySpend,\n  inputComponentsP2trScriptSpendLevel1,\n  inputComponentsP2trScriptSpendLevel2,\n  inputComponentsP2wsh,\n} from '../../src/inputWeights';\nimport { pushdataEncodingLength } from '../../src/scriptSizes';\nimport {\n  getInputScriptTypes,\n  getSignedTransaction,\n  InputScriptType,\n  TestUnspentType,\n  UnspentTypeScript2of3,\n} from '../testutils';\n\ndescribe('Input Script Sizes (Worst-Case)', function () {\n  const keys = [1, 2, 3].map((v) => bip32.fromSeed(Buffer.alloc(16, `test/${v}`))) as BIP32Interface[];\n  const rootWalletKeys = new utxolib.bitgo.RootWalletKeys([keys[0], keys[1], keys[2]]);\n\n  function getLargestInputWithType(\n    inputType: string,\n    signKeys: utxolib.bitgo.KeyName[],\n    inputCount = 100\n  ): utxolib.TxInput {\n    const signerName = signKeys[0];\n    const cosignerName = signKeys.length > 1 ? signKeys[1] : signerName;\n    const inputScriptTypes = Array.from({ length: inputCount }).fill(inputType) as InputScriptType[];\n    const outputScriptTypes = [UnspentTypeScript2of3.p2sh] as TestUnspentType[];\n    return getSignedTransaction(\n      rootWalletKeys,\n      signerName,\n      cosignerName,\n      inputScriptTypes,\n      outputScriptTypes\n    ).ins.reduce((a, b) => (getInputWeight(a) > getInputWeight(b) ? a : b));\n  }\n\n  function getInputComponents(input: utxolib.TxInput): InputComponents {\n    const decompiled = utxolib.script.decompile(input.script);\n    if (!decompiled) {\n      throw new Error();\n    }\n\n    const script = decompiled.map((v) => {\n      if (!Buffer.isBuffer(v)) {\n        return { length: 1 };\n      }\n      return { length: v.length + pushdataEncodingLength(v.length) };\n    });\n    const witness = (input.witness || []).map((v) => ({ length: v.length }));\n\n    const scriptSize = script.reduce((a, b) => a + b.length, 0);\n    assert.strictEqual(scriptSize, input.script.length, utxolib.script.toASM(decompiled));\n\n    return {\n      script: script.map((v) => v.length),\n      witness: witness.map((v) => v.length),\n    };\n  }\n\n  function runTestComponentSizes(inputType: string, signKeys: utxolib.bitgo.KeyName[]) {\n    const signKeysStr = signKeys.join(',');\n\n    describe(`inputType=${inputType} signKeys=${signKeysStr}`, function () {\n      it(`component sizes`, function (this: mocha.Context) {\n        this.timeout(10_000);\n        let expectedComponents;\n        switch (inputType) {\n          case 'p2sh':\n            expectedComponents = inputComponentsP2sh;\n            break;\n          case 'p2shP2wsh':\n            expectedComponents = inputComponentsP2shP2wsh;\n            break;\n          case 'p2wsh':\n            expectedComponents = inputComponentsP2wsh;\n            break;\n          case 'p2shP2pk':\n            expectedComponents = inputComponentsP2shP2pk;\n            break;\n          case 'p2tr':\n            if (signKeys[1] === 'bitgo') {\n              expectedComponents = inputComponentsP2trScriptSpendLevel1;\n            } else if (signKeys[1] === 'backup') {\n              expectedComponents = inputComponentsP2trScriptSpendLevel2;\n            } else {\n              throw new Error(`unexpected cosigner`);\n            }\n            break;\n          case 'p2trMusig2':\n            // assumes only script path\n            expectedComponents = inputComponentsP2trScriptSpendLevel1;\n            break;\n          case 'taprootKeyPathSpend':\n            expectedComponents = inputComponentsP2trKeySpend;\n            break;\n          default:\n            throw new Error(`invalid inputType ${inputType}`);\n        }\n\n        const input = getLargestInputWithType(\n          inputType,\n          signKeys,\n          inputType === 'p2tr' || inputType === 'p2trMusig2' || inputType === 'taprootKeyPathSpend' ? 10 : 100\n        );\n        const components = getInputComponents(input);\n        assert.deepStrictEqual(components, expectedComponents);\n        assert.strictEqual(getInputComponentsWeight(components), getInputWeight(input));\n      });\n    });\n  }\n\n  getInputScriptTypes().forEach((inputType: string) => {\n    if (inputType !== 'p2trMusig2') {\n      runTestComponentSizes(inputType, inputType === 'p2shP2pk' ? ['user'] : ['user', 'bitgo']);\n    }\n    if (inputType !== 'p2shP2pk' && inputType !== 'taprootKeyPathSpend') {\n      runTestComponentSizes(inputType, ['user', 'backup']);\n    }\n  });\n});\n"]}

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


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