PHP WebShell

Текущая директория: /opt/BitGoJS/modules/utxo-lib/dist/test/integration_local_rpc

Просмотр файла: parse.js

"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
const assert = require("assert");
const mocha_1 = require("mocha");
const src_1 = require("../../src");
const testutil_1 = require("../../src/testutil");
const bitgo_1 = require("../../src/bitgo");
const outputScripts_1 = require("../../src/bitgo/outputScripts");
const outputScripts_util_1 = require("./generate/outputScripts.util");
const fixtures_1 = require("./generate/fixtures");
const transaction_util_1 = require("../transaction_util");
const compare_1 = require("./compare");
const testutil_2 = require("../testutil");
const fixtureTxTypes = ['deposit', 'spend'];
function getScriptTypes() {
    // FIXME(BG-66941): p2trMusig2 signing does not work in this test suite yet
    //  because the test suite is written with TransactionBuilder
    return outputScripts_util_1.scriptTypes.filter((scriptType) => scriptType !== 'p2trMusig2');
}
function runTestParse(protocol, txType, scriptType, amountType) {
    if (txType === 'deposit' && !(0, outputScripts_util_1.isSupportedDepositType)(protocol.network, scriptType)) {
        return;
    }
    if (txType === 'spend' && !(0, outputScripts_util_1.isSupportedSpendType)(protocol.network, scriptType)) {
        return;
    }
    const fixtureName = `${txType}_${scriptType}.json`;
    (0, mocha_1.describe)(`${fixtureName} amountType=${amountType}`, function () {
        let fixture;
        let txBuffer;
        let parsedTx;
        before(async function () {
            fixture = await (0, fixtures_1.readFixture)({
                network: protocol.network,
                version: protocol.version ?? (0, bitgo_1.getDefaultTransactionVersion)(protocol.network),
            }, fixtureName);
            txBuffer = Buffer.from(fixture.transaction.hex, 'hex');
            parsedTx = (0, bitgo_1.createTransactionFromBuffer)(txBuffer, protocol.network, {
                version: protocol.version,
                amountType,
            });
        });
        function getPrevOutput(input) {
            if (input.hash) {
                input = {
                    ...input,
                    ...(0, bitgo_1.getOutputIdForInput)(input),
                };
            }
            const inputTx = fixture.inputs.find((tx) => tx.txid === input.txid);
            if (!inputTx) {
                throw new Error(`could not find inputTx`);
            }
            const prevOutput = inputTx.vout[input.index];
            if (!prevOutput) {
                throw new Error(`could not prevOutput`);
            }
            return prevOutput;
        }
        function getPrevOutputValue(input) {
            return (0, testutil_2.decimalCoinsToSats)(getPrevOutput(input).value, amountType);
        }
        function getPrevOutputScript(input) {
            return Buffer.from(getPrevOutput(input).scriptPubKey.hex, 'hex');
        }
        function getPrevOutputs() {
            return parsedTx.ins.map((i) => ({
                ...(0, bitgo_1.getOutputIdForInput)(i),
                script: getPrevOutputScript(i),
                value: getPrevOutputValue(i),
                prevTx: txBuffer,
            }));
        }
        (0, mocha_1.it)(`round-trip`, function () {
            (0, transaction_util_1.parseTransactionRoundTrip)(Buffer.from(fixture.transaction.hex, 'hex'), protocol.network, {
                inputs: getPrevOutputs(),
                amountType,
                version: protocol.version,
                // FIXME: prevTx parsing for Zcash not working yet
                roundTripPsbt: txType === 'spend' && protocol.network !== src_1.networks.zcashTest,
            });
        });
        (0, mocha_1.it)(`round-trip (high-precision values)`, function () {
            if (amountType !== 'bigint') {
                return;
            }
            const tx = (0, bitgo_1.createTransactionFromBuffer)(Buffer.from(fixture.transaction.hex, 'hex'), protocol.network, {
                amountType,
            });
            tx.outs.forEach((o) => {
                o.value = (BigInt(1e16) + BigInt(1));
                assert.notStrictEqual(BigInt(Number(o.value)), o.value);
            });
            const txRoundTrip = (0, transaction_util_1.parseTransactionRoundTrip)(tx.toBuffer(), protocol.network, { amountType });
            assert.strictEqual(txRoundTrip.outs.length, tx.outs.length);
            txRoundTrip.outs.forEach((o, i) => {
                assert.deepStrictEqual(o, tx.outs[i]);
            });
        });
        (0, mocha_1.it)(`recreate from unsigned hex`, function () {
            if (txType === 'deposit') {
                return;
            }
            const txbUnsigned = (0, bitgo_1.createTransactionBuilderForNetwork)(protocol.network, { version: protocol.version });
            getPrevOutputs().forEach((o) => {
                txbUnsigned.addInput(o.txid, o.vout);
            });
            fixture.transaction.vout.forEach((o) => {
                txbUnsigned.addOutput(Buffer.from(o.scriptPubKey.hex, 'hex'), (0, testutil_2.decimalCoinsToSats)(o.value, amountType));
            });
            const tx = (0, bitgo_1.createTransactionFromBuffer)(txbUnsigned.buildIncomplete().toBuffer(), protocol.network, {
                version: protocol.version,
                amountType,
            });
            const txb = (0, bitgo_1.createTransactionBuilderFromTransaction)(tx, getPrevOutputs());
            const signKeys = [fixtures_1.fixtureKeys[0], fixtures_1.fixtureKeys[2]];
            const publicKeys = fixtures_1.fixtureKeys.map((k) => k.publicKey);
            getPrevOutputs().forEach(({ value }, vin) => {
                signKeys.forEach((key) => {
                    (0, bitgo_1.signInput2Of3)(txb, vin, scriptType, publicKeys, key, (0, testutil_1.getDefaultCosigner)(publicKeys, key.publicKey), value);
                });
            });
            assert.strictEqual(txb.build().version, tx.version);
            assert.strictEqual(txb.build().toBuffer().toString('hex'), fixture.transaction.hex);
        });
        (0, mocha_1.it)('compare against RPC data', function () {
            assert.deepStrictEqual((0, compare_1.normalizeRpcTransaction)(fixture.transaction, protocol.network), (0, compare_1.normalizeParsedTransaction)(parsedTx, protocol.network));
        });
        (0, mocha_1.it)(`parseSignatureScript`, function () {
            if (txType === 'deposit') {
                return;
            }
            parsedTx.ins.forEach((input, i) => {
                const result = (0, bitgo_1.parseSignatureScript)(input);
                assert.strict(result.publicKeys !== undefined);
                assert.strictEqual(result.publicKeys.length, scriptType === 'p2tr' ? 2 : 3);
            });
        });
        if (txType === 'deposit') {
            return;
        }
        (0, mocha_1.it)(`verifySignatures for original transaction`, function () {
            parsedTx.ins.forEach((input, i) => {
                const prevOutValue = getPrevOutputValue(input);
                const result = (0, bitgo_1.parseSignatureScript2Of3)(input);
                assert.ok(result.scriptType !== 'taprootKeyPathSpend');
                if (!result.publicKeys) {
                    throw new Error(`expected publicKeys`);
                }
                assert.strictEqual(result.publicKeys.length, scriptType === 'p2tr' ? 2 : 3);
                if (scriptType === 'p2tr') {
                    // TODO implement verifySignature for p2tr
                    this.skip();
                }
                result.publicKeys.forEach((publicKey, publicKeyIndex) => {
                    assert.strictEqual((0, bitgo_1.verifySignature)(parsedTx, i, prevOutValue, {
                        publicKey,
                    }), publicKeyIndex === 0 || publicKeyIndex === 2);
                });
                assert.strictEqual((0, bitgo_1.verifySignature)(parsedTx, i, prevOutValue), true);
            });
        });
        function getRebuiltTransaction(signKeys) {
            assert.strict(parsedTx.outs.length === 1);
            assert.strict((0, outputScripts_1.isScriptType2Of3)(scriptType));
            const recipientScript = parsedTx.outs[0].script;
            return (0, outputScripts_util_1.createSpendTransactionFromPrevOutputs)(fixtures_1.fixtureKeys, scriptType, getPrevOutputs(), recipientScript, protocol.network, { signKeys, version: protocol.version });
        }
        (0, mocha_1.it)(`verifySignatures with one or two signatures`, function () {
            fixtures_1.fixtureKeys.forEach((key1) => {
                const rebuiltTx = getRebuiltTransaction([key1]);
                const prevOutputs = rebuiltTx.ins.map((v) => ({
                    script: getPrevOutputScript(v),
                    value: getPrevOutputValue(v),
                }));
                rebuiltTx.ins.forEach((input, i) => {
                    assert.strict((0, bitgo_1.verifySignature)(rebuiltTx, i, getPrevOutputValue(input), {}, prevOutputs));
                });
                fixtures_1.fixtureKeys.forEach((key2) => {
                    if (key1 === key2) {
                        return;
                    }
                    if (scriptType === 'p2tr') {
                        const keypair = [fixtures_1.fixtureKeys[0], fixtures_1.fixtureKeys[2]];
                        if (!keypair.includes(key1) || !keypair.includes(key2)) {
                            return;
                        }
                    }
                    const rebuiltTx = getRebuiltTransaction([key1, key2]);
                    rebuiltTx.ins.forEach((input, i) => {
                        assert.strict((0, bitgo_1.verifySignature)(rebuiltTx, i, getPrevOutputValue(input), {}, prevOutputs));
                    });
                });
            });
        });
        (0, mocha_1.it)('createSpendTransaction match', function () {
            const rebuiltTx = getRebuiltTransaction();
            assert.strictEqual(rebuiltTx.toBuffer().toString('hex'), fixture.transaction.hex);
        });
    });
}
(0, mocha_1.describe)(`regtest fixtures`, function () {
    (0, src_1.getNetworkList)().forEach((network) => {
        if (!(0, src_1.isTestnet)(network)) {
            return;
        }
        const allVersions = (0, fixtures_1.getProtocolVersions)(network);
        (0, mocha_1.it)('tests default version', function () {
            // FIXME(BTC-1633): fix generating fixtures for version 455 NU6
            if (src_1.networks.zcashTest === network) {
                assert.strictEqual((0, bitgo_1.getDefaultTransactionVersion)(network), 455);
            }
            else {
                assert.strictEqual(allVersions.filter((v) => v === (0, bitgo_1.getDefaultTransactionVersion)(network)).length, 1);
            }
        });
        (0, fixtures_1.getProtocolVersions)(network).forEach((version) => {
            const isDefault = version === (0, bitgo_1.getDefaultTransactionVersion)(network);
            (0, mocha_1.describe)(`${(0, src_1.getNetworkName)(network)} fixtures (version=${version}, isDefault=${isDefault})`, function () {
                getScriptTypes().forEach((scriptType) => {
                    fixtureTxTypes.forEach((txType) => {
                        runTestParse({ network, version }, txType, scriptType, network === src_1.networks.dogecoinTest ? 'bigint' : 'number');
                    });
                });
            });
        });
    });
});
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"parse.js","sourceRoot":"","sources":["../../../test/integration_local_rpc/parse.ts"],"names":[],"mappings":"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","sourcesContent":["import * as assert from 'assert';\nimport { describe, it } from 'mocha';\nimport { BIP32Interface } from 'bip32';\n\nimport { isTestnet, TxOutput, getNetworkList, getNetworkName, networks } from '../../src';\nimport { getDefaultCosigner } from '../../src/testutil';\n\nimport {\n  createTransactionBuilderForNetwork,\n  createTransactionBuilderFromTransaction,\n  createTransactionFromBuffer,\n  getDefaultTransactionVersion,\n  getOutputIdForInput,\n  ParsedSignatureScriptP2ms,\n  parseSignatureScript,\n  parseSignatureScript2Of3,\n  signInput2Of3,\n  Triple,\n  TxOutPoint,\n  UtxoTransaction,\n  verifySignature,\n} from '../../src/bitgo';\nimport { isScriptType2Of3, ScriptType2Of3 } from '../../src/bitgo/outputScripts';\n\nimport {\n  createSpendTransactionFromPrevOutputs,\n  isSupportedDepositType,\n  isSupportedSpendType,\n  ScriptType,\n  scriptTypes,\n} from './generate/outputScripts.util';\nimport {\n  fixtureKeys,\n  getProtocolVersions,\n  Protocol,\n  readFixture,\n  TransactionFixtureWithInputs,\n} from './generate/fixtures';\nimport { parseTransactionRoundTrip } from '../transaction_util';\nimport { normalizeParsedTransaction, normalizeRpcTransaction } from './compare';\nimport { decimalCoinsToSats } from '../testutil';\n\nconst fixtureTxTypes = ['deposit', 'spend'] as const;\ntype FixtureTxType = (typeof fixtureTxTypes)[number];\n\nfunction getScriptTypes() {\n  // FIXME(BG-66941): p2trMusig2 signing does not work in this test suite yet\n  //  because the test suite is written with TransactionBuilder\n  return scriptTypes.filter((scriptType) => scriptType !== 'p2trMusig2');\n}\n\nfunction runTestParse<TNumber extends number | bigint>(\n  protocol: Protocol,\n  txType: FixtureTxType,\n  scriptType: ScriptType,\n  amountType: 'number' | 'bigint'\n) {\n  if (txType === 'deposit' && !isSupportedDepositType(protocol.network, scriptType)) {\n    return;\n  }\n\n  if (txType === 'spend' && !isSupportedSpendType(protocol.network, scriptType)) {\n    return;\n  }\n\n  const fixtureName = `${txType}_${scriptType}.json`;\n  describe(`${fixtureName} amountType=${amountType}`, function () {\n    let fixture: TransactionFixtureWithInputs;\n    let txBuffer: Buffer;\n    let parsedTx: UtxoTransaction<TNumber>;\n\n    before(async function () {\n      fixture = await readFixture(\n        {\n          network: protocol.network,\n          version: protocol.version ?? getDefaultTransactionVersion(protocol.network),\n        },\n        fixtureName\n      );\n      txBuffer = Buffer.from(fixture.transaction.hex, 'hex');\n      parsedTx = createTransactionFromBuffer<TNumber>(txBuffer, protocol.network, {\n        version: protocol.version,\n        amountType,\n      });\n    });\n\n    type InputLookup = { txid?: string; hash?: Buffer; index: number };\n\n    function getPrevOutput(input: InputLookup) {\n      if (input.hash) {\n        input = {\n          ...input,\n          ...getOutputIdForInput(input as { hash: Buffer; index: number }),\n        };\n      }\n\n      const inputTx = fixture.inputs.find((tx) => tx.txid === input.txid);\n      if (!inputTx) {\n        throw new Error(`could not find inputTx`);\n      }\n      const prevOutput = inputTx.vout[input.index];\n      if (!prevOutput) {\n        throw new Error(`could not prevOutput`);\n      }\n      return prevOutput;\n    }\n\n    function getPrevOutputValue(input: InputLookup): TNumber {\n      return decimalCoinsToSats<TNumber>(getPrevOutput(input).value, amountType);\n    }\n\n    function getPrevOutputScript(input: InputLookup): Buffer {\n      return Buffer.from(getPrevOutput(input).scriptPubKey.hex, 'hex');\n    }\n\n    function getPrevOutputs(): (TxOutPoint & TxOutput<TNumber>)[] {\n      return parsedTx.ins.map((i) => ({\n        ...getOutputIdForInput(i),\n        script: getPrevOutputScript(i),\n        value: getPrevOutputValue(i),\n        prevTx: txBuffer,\n      }));\n    }\n\n    it(`round-trip`, function () {\n      parseTransactionRoundTrip(Buffer.from(fixture.transaction.hex, 'hex'), protocol.network, {\n        inputs: getPrevOutputs(),\n        amountType,\n        version: protocol.version,\n        // FIXME: prevTx parsing for Zcash not working yet\n        roundTripPsbt: txType === 'spend' && protocol.network !== networks.zcashTest,\n      });\n    });\n\n    it(`round-trip (high-precision values)`, function () {\n      if (amountType !== 'bigint') {\n        return;\n      }\n      const tx = createTransactionFromBuffer<TNumber>(Buffer.from(fixture.transaction.hex, 'hex'), protocol.network, {\n        amountType,\n      });\n      tx.outs.forEach((o) => {\n        o.value = (BigInt(1e16) + BigInt(1)) as TNumber;\n        assert.notStrictEqual(BigInt(Number(o.value)), o.value);\n      });\n      const txRoundTrip = parseTransactionRoundTrip(tx.toBuffer(), protocol.network, { amountType });\n      assert.strictEqual(txRoundTrip.outs.length, tx.outs.length);\n      txRoundTrip.outs.forEach((o, i) => {\n        assert.deepStrictEqual(o, tx.outs[i]);\n      });\n    });\n\n    it(`recreate from unsigned hex`, function () {\n      if (txType === 'deposit') {\n        return;\n      }\n      const txbUnsigned = createTransactionBuilderForNetwork<TNumber>(protocol.network, { version: protocol.version });\n      getPrevOutputs().forEach((o) => {\n        txbUnsigned.addInput(o.txid, o.vout);\n      });\n      fixture.transaction.vout.forEach((o) => {\n        txbUnsigned.addOutput(Buffer.from(o.scriptPubKey.hex, 'hex'), decimalCoinsToSats<TNumber>(o.value, amountType));\n      });\n\n      const tx = createTransactionFromBuffer<TNumber>(txbUnsigned.buildIncomplete().toBuffer(), protocol.network, {\n        version: protocol.version,\n        amountType,\n      });\n      const txb = createTransactionBuilderFromTransaction(tx, getPrevOutputs());\n      const signKeys = [fixtureKeys[0], fixtureKeys[2]];\n      const publicKeys = fixtureKeys.map((k) => k.publicKey) as Triple<Buffer>;\n      getPrevOutputs().forEach(({ value }, vin) => {\n        signKeys.forEach((key) => {\n          signInput2Of3(\n            txb,\n            vin,\n            scriptType as ScriptType2Of3,\n            publicKeys,\n            key,\n            getDefaultCosigner(publicKeys, key.publicKey),\n            value\n          );\n        });\n      });\n\n      assert.strictEqual(txb.build().version, tx.version);\n\n      assert.strictEqual(txb.build().toBuffer().toString('hex'), fixture.transaction.hex);\n    });\n\n    it('compare against RPC data', function () {\n      assert.deepStrictEqual(\n        normalizeRpcTransaction(fixture.transaction, protocol.network),\n        normalizeParsedTransaction(parsedTx, protocol.network)\n      );\n    });\n\n    it(`parseSignatureScript`, function () {\n      if (txType === 'deposit') {\n        return;\n      }\n\n      parsedTx.ins.forEach((input, i) => {\n        const result = parseSignatureScript(input) as ParsedSignatureScriptP2ms;\n\n        assert.strict(result.publicKeys !== undefined);\n        assert.strictEqual(result.publicKeys.length, scriptType === 'p2tr' ? 2 : 3);\n      });\n    });\n\n    if (txType === 'deposit') {\n      return;\n    }\n\n    it(`verifySignatures for original transaction`, function () {\n      parsedTx.ins.forEach((input, i) => {\n        const prevOutValue = getPrevOutputValue(input);\n        const result = parseSignatureScript2Of3(input);\n        assert.ok(result.scriptType !== 'taprootKeyPathSpend');\n        if (!result.publicKeys) {\n          throw new Error(`expected publicKeys`);\n        }\n        assert.strictEqual(result.publicKeys.length, scriptType === 'p2tr' ? 2 : 3);\n\n        if (scriptType === 'p2tr') {\n          // TODO implement verifySignature for p2tr\n          this.skip();\n        }\n\n        result.publicKeys.forEach((publicKey, publicKeyIndex) => {\n          assert.strictEqual(\n            verifySignature(parsedTx, i, prevOutValue, {\n              publicKey,\n            }),\n            publicKeyIndex === 0 || publicKeyIndex === 2\n          );\n        });\n\n        assert.strictEqual(verifySignature(parsedTx, i, prevOutValue), true);\n      });\n    });\n\n    function getRebuiltTransaction(signKeys?: BIP32Interface[]) {\n      assert.strict(parsedTx.outs.length === 1);\n      assert.strict(isScriptType2Of3(scriptType));\n      const recipientScript = parsedTx.outs[0].script;\n      return createSpendTransactionFromPrevOutputs(\n        fixtureKeys,\n        scriptType,\n        getPrevOutputs(),\n        recipientScript,\n        protocol.network,\n        { signKeys, version: protocol.version }\n      );\n    }\n\n    it(`verifySignatures with one or two signatures`, function () {\n      fixtureKeys.forEach((key1) => {\n        const rebuiltTx = getRebuiltTransaction([key1]);\n        const prevOutputs = rebuiltTx.ins.map((v) => ({\n          script: getPrevOutputScript(v),\n          value: getPrevOutputValue(v),\n        }));\n        rebuiltTx.ins.forEach((input, i) => {\n          assert.strict(verifySignature(rebuiltTx, i, getPrevOutputValue(input), {}, prevOutputs));\n        });\n\n        fixtureKeys.forEach((key2) => {\n          if (key1 === key2) {\n            return;\n          }\n\n          if (scriptType === 'p2tr') {\n            const keypair = [fixtureKeys[0], fixtureKeys[2]];\n            if (!keypair.includes(key1) || !keypair.includes(key2)) {\n              return;\n            }\n          }\n\n          const rebuiltTx = getRebuiltTransaction([key1, key2]);\n          rebuiltTx.ins.forEach((input, i) => {\n            assert.strict(verifySignature(rebuiltTx, i, getPrevOutputValue(input), {}, prevOutputs));\n          });\n        });\n      });\n    });\n\n    it('createSpendTransaction match', function () {\n      const rebuiltTx = getRebuiltTransaction();\n      assert.strictEqual(rebuiltTx.toBuffer().toString('hex'), fixture.transaction.hex);\n    });\n  });\n}\n\ndescribe(`regtest fixtures`, function () {\n  getNetworkList().forEach((network) => {\n    if (!isTestnet(network)) {\n      return;\n    }\n\n    const allVersions = getProtocolVersions(network);\n    it('tests default version', function () {\n      // FIXME(BTC-1633): fix generating fixtures for version 455 NU6\n      if (networks.zcashTest === network) {\n        assert.strictEqual(getDefaultTransactionVersion(network), 455);\n      } else {\n        assert.strictEqual(allVersions.filter((v) => v === getDefaultTransactionVersion(network)).length, 1);\n      }\n    });\n\n    getProtocolVersions(network).forEach((version) => {\n      const isDefault = version === getDefaultTransactionVersion(network);\n      describe(`${getNetworkName(network)} fixtures (version=${version}, isDefault=${isDefault})`, function () {\n        getScriptTypes().forEach((scriptType) => {\n          fixtureTxTypes.forEach((txType) => {\n            runTestParse(\n              { network, version },\n              txType,\n              scriptType,\n              network === networks.dogecoinTest ? 'bigint' : 'number'\n            );\n          });\n        });\n      });\n    });\n  });\n});\n"]}

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


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