PHP WebShell

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

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

"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
const assert = require("assert");
const ecpair_1 = require("ecpair");
const src_1 = require("../src");
const taproot_1 = require("../src/taproot");
const ECPair = (0, ecpair_1.ECPairFactory)(src_1.ecc);
describe('taproot utils', () => {
    describe('musig key aggregation', () => {
        // Expected values for the test cases assertions below are derived from the
        // MuSig2 implementation example code in secp256k1-zkp.
        // https://github.com/jonasnick/secp256k1-zkp/blob/musig2/src/modules/musig/example.c
        it('aggregates 2 pubkeys', () => {
            const aggregatePubkey = src_1.taproot.aggregateMuSigPubkeys(src_1.ecc, [
                Buffer.from('b2eea3c2431bdda9003b30e385f6a59a74fddb39f4aa927f95ad7a6c147c9f6c', 'hex'),
                Buffer.from('d37c98a14d3a749e45a15bcc6836552a7458632f5bc46dca197011e031d6014f', 'hex'),
            ]);
            assert.strictEqual(Buffer.from(aggregatePubkey).toString('hex'), '0ae195f849375eb836fa9f11dd8a44643f424e2671df6e63a2ad9becb853a9fe');
        });
        it('aggregates 3 unsorted pubkeys', () => {
            const aggregatePubkey = src_1.taproot.aggregateMuSigPubkeys(src_1.ecc, [
                Buffer.from('c03b14ebd188344d78ed45a0e4857fc65c7e25f50e0c0d84938220ef37da63d6', 'hex'),
                Buffer.from('8f3bb821cf276d78199fc26f5b7d912e30326a2d21f856ee1c653a896f4e5334', 'hex'),
                Buffer.from('95f6fd0d52f4be09a076a99b77e34dc005eec62bb7cec50ade968dd2f597fc52', 'hex'),
            ]);
            assert.strictEqual(Buffer.from(aggregatePubkey).toString('hex'), '349740502d79dd7a1253235da3b203de6e7717f487a8d1807e683bdfe7bd17ec');
        });
        it('throws an error if no keys are provided', () => {
            assert.throws(() => src_1.taproot.aggregateMuSigPubkeys(src_1.ecc, []));
        });
        it('throws an error if a single key is provided', () => {
            assert.throws(() => src_1.taproot.aggregateMuSigPubkeys(src_1.ecc, [ECPair.makeRandom().publicKey]));
        });
    });
    describe('taptree construction', () => {
        // Expected values for test case assertions below are derived from code and
        // examples provided by the Bitcoin Optech taproot workshop exercises:
        // https://github.com/bitcoinops/taproot-workshop
        const internalPubKey = Buffer.from('af455f4989d122e9185f8c351dbaecd13adca3eef8a9d38ef8ffed6867e342e3', 'hex');
        it('serializes script size', () => {
            const u8 = Buffer.allocUnsafe(0x01);
            const u16 = Buffer.allocUnsafe(0x0101);
            const u32 = Buffer.allocUnsafe(0x010101);
            const u8SerSize = src_1.taproot.serializeScriptSize(u8);
            const u16SerSize = src_1.taproot.serializeScriptSize(u16);
            const u32SerSize = src_1.taproot.serializeScriptSize(u32);
            assert.strictEqual(u8SerSize.toString('hex'), '01');
            assert.strictEqual(u16SerSize.toString('hex'), 'fd0101');
            assert.strictEqual(u32SerSize.toString('hex'), 'fe01010100');
        });
        it('hashes a tap leaf', () => {
            const pubkey = Buffer.from('3627a049c3dd937b1ef01432a54f2e31642be754764f5a677c174576fb02571e', 'hex');
            const script = Buffer.concat([
                new Uint8Array([32]), // push 32 byte pub key
                pubkey,
                new Uint8Array([0xac]), // OP_CHECKSIG
            ]);
            const tapLeafHash = src_1.taproot.hashTapLeaf(script);
            assert.strictEqual(tapLeafHash.toString('hex'), '17e20b19dc7e8093c4278d3bf42447a2334546f874ba1693c9d7bc4d81db15c4');
        });
        it('hashes a tap branch', () => {
            const child1 = Buffer.from('f248f2fee0977d141e19e0fddae1cfcdcede1a34a77ebc53c8fe96f346c7f7fc', 'hex');
            const child2 = Buffer.from('72e4cc6e974cae355cf72476edeff8e9a2877ad67cfa4f12bad6f178c6918b9c', 'hex');
            const tapBranchHash = src_1.taproot.hashTapBranch(child1, child2);
            assert.strictEqual(tapBranchHash.toString('hex'), '3009565ab85ceb87d3dfdedc469ec205b2ea139a148af1dcbcc1addf8f1b68a4');
        });
        it('taptweaks a pubkey', () => {
            const taptreeRoot = Buffer.from('dde870346c0f5f1f1c2341041520baa4e252723474c6969f432c2af98251ac01', 'hex');
            const taprootPubkey = src_1.taproot.tapTweakPubkey(src_1.ecc, internalPubKey, taptreeRoot);
            assert.strictEqual(Buffer.from(taprootPubkey.xOnlyPubkey).toString('hex'), 'b23960be1cb56ed0f9044ded73d758f466493cf9e2a6ce139a04fac8d630a601');
            const outputScript = (0, taproot_1.createTaprootOutputScript)({ internalPubKey, taptreeRoot });
            const outputKey = (0, taproot_1.getTaprootOutputKey)(outputScript);
            assert.ok(outputKey.equals(taprootPubkey.xOnlyPubkey));
        });
        it('builds a weighted taptree from scripts and tweaks a pubkey with it', () => {
            const scriptA = Buffer.from('2052b319d011c12225b8f9c63349e7b0e78118a1cb7e406fc70e3e08862b49d10aac', 'hex');
            const scriptB = Buffer.from('20622e61f750f10e597b18a3bb4e5dea88548508b8cb37bfc0fb7af20f7a417d6aac', 'hex');
            const scriptC = Buffer.from('2092a7d17376802e183fc49fb93d4c9b0a4d1cf845c005debbcc9cd57550a6f617ac', 'hex');
            const tapTree = src_1.taproot.getHuffmanTaptree([scriptA, scriptB, scriptC], [1, 1, 2]);
            const tapTreeRoot = tapTree.root;
            const taprootPubkey = src_1.taproot.tapTweakPubkey(src_1.ecc, internalPubKey, tapTreeRoot);
            assert.strictEqual(Buffer.from(taprootPubkey.xOnlyPubkey).toString('hex'), '4c537b89b6763b2c415dee24f75a4c80b48bea926361fbf7636cbf9025c46128');
        });
    });
});
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"taproot.spec.js","sourceRoot":"","sources":["../../test/taproot.spec.ts"],"names":[],"mappings":"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","sourcesContent":["import * as assert from 'assert';\nimport { ECPairAPI, ECPairFactory } from 'ecpair';\nimport { ecc, taproot } from '../src';\nimport { createTaprootOutputScript, getTaprootOutputKey } from '../src/taproot';\n\nconst ECPair: ECPairAPI = ECPairFactory(ecc);\n\ndescribe('taproot utils', () => {\n  describe('musig key aggregation', () => {\n    // Expected values for the test cases assertions below are derived from the\n    // MuSig2 implementation example code in secp256k1-zkp.\n    // https://github.com/jonasnick/secp256k1-zkp/blob/musig2/src/modules/musig/example.c\n\n    it('aggregates 2 pubkeys', () => {\n      const aggregatePubkey = taproot.aggregateMuSigPubkeys(ecc, [\n        Buffer.from('b2eea3c2431bdda9003b30e385f6a59a74fddb39f4aa927f95ad7a6c147c9f6c', 'hex'),\n        Buffer.from('d37c98a14d3a749e45a15bcc6836552a7458632f5bc46dca197011e031d6014f', 'hex'),\n      ]);\n\n      assert.strictEqual(\n        Buffer.from(aggregatePubkey).toString('hex'),\n        '0ae195f849375eb836fa9f11dd8a44643f424e2671df6e63a2ad9becb853a9fe'\n      );\n    });\n\n    it('aggregates 3 unsorted pubkeys', () => {\n      const aggregatePubkey = taproot.aggregateMuSigPubkeys(ecc, [\n        Buffer.from('c03b14ebd188344d78ed45a0e4857fc65c7e25f50e0c0d84938220ef37da63d6', 'hex'),\n        Buffer.from('8f3bb821cf276d78199fc26f5b7d912e30326a2d21f856ee1c653a896f4e5334', 'hex'),\n        Buffer.from('95f6fd0d52f4be09a076a99b77e34dc005eec62bb7cec50ade968dd2f597fc52', 'hex'),\n      ]);\n\n      assert.strictEqual(\n        Buffer.from(aggregatePubkey).toString('hex'),\n        '349740502d79dd7a1253235da3b203de6e7717f487a8d1807e683bdfe7bd17ec'\n      );\n    });\n\n    it('throws an error if no keys are provided', () => {\n      assert.throws(() => taproot.aggregateMuSigPubkeys(ecc, []));\n    });\n\n    it('throws an error if a single key is provided', () => {\n      assert.throws(() => taproot.aggregateMuSigPubkeys(ecc, [ECPair.makeRandom().publicKey]));\n    });\n  });\n\n  describe('taptree construction', () => {\n    // Expected values for test case assertions below are derived from code and\n    // examples provided by the Bitcoin Optech taproot workshop exercises:\n    // https://github.com/bitcoinops/taproot-workshop\n\n    const internalPubKey = Buffer.from('af455f4989d122e9185f8c351dbaecd13adca3eef8a9d38ef8ffed6867e342e3', 'hex');\n\n    it('serializes script size', () => {\n      const u8 = Buffer.allocUnsafe(0x01);\n      const u16 = Buffer.allocUnsafe(0x0101);\n      const u32 = Buffer.allocUnsafe(0x010101);\n\n      const u8SerSize = taproot.serializeScriptSize(u8);\n      const u16SerSize = taproot.serializeScriptSize(u16);\n      const u32SerSize = taproot.serializeScriptSize(u32);\n\n      assert.strictEqual(u8SerSize.toString('hex'), '01');\n      assert.strictEqual(u16SerSize.toString('hex'), 'fd0101');\n      assert.strictEqual(u32SerSize.toString('hex'), 'fe01010100');\n    });\n\n    it('hashes a tap leaf', () => {\n      const pubkey = Buffer.from('3627a049c3dd937b1ef01432a54f2e31642be754764f5a677c174576fb02571e', 'hex');\n\n      const script = Buffer.concat([\n        new Uint8Array([32]), // push 32 byte pub key\n        pubkey,\n        new Uint8Array([0xac]), // OP_CHECKSIG\n      ]);\n\n      const tapLeafHash = taproot.hashTapLeaf(script);\n\n      assert.strictEqual(\n        tapLeafHash.toString('hex'),\n        '17e20b19dc7e8093c4278d3bf42447a2334546f874ba1693c9d7bc4d81db15c4'\n      );\n    });\n\n    it('hashes a tap branch', () => {\n      const child1 = Buffer.from('f248f2fee0977d141e19e0fddae1cfcdcede1a34a77ebc53c8fe96f346c7f7fc', 'hex');\n      const child2 = Buffer.from('72e4cc6e974cae355cf72476edeff8e9a2877ad67cfa4f12bad6f178c6918b9c', 'hex');\n\n      const tapBranchHash = taproot.hashTapBranch(child1, child2);\n\n      assert.strictEqual(\n        tapBranchHash.toString('hex'),\n        '3009565ab85ceb87d3dfdedc469ec205b2ea139a148af1dcbcc1addf8f1b68a4'\n      );\n    });\n\n    it('taptweaks a pubkey', () => {\n      const taptreeRoot = Buffer.from('dde870346c0f5f1f1c2341041520baa4e252723474c6969f432c2af98251ac01', 'hex');\n\n      const taprootPubkey = taproot.tapTweakPubkey(ecc, internalPubKey, taptreeRoot);\n\n      assert.strictEqual(\n        Buffer.from(taprootPubkey.xOnlyPubkey).toString('hex'),\n        'b23960be1cb56ed0f9044ded73d758f466493cf9e2a6ce139a04fac8d630a601'\n      );\n\n      const outputScript = createTaprootOutputScript({ internalPubKey, taptreeRoot });\n      const outputKey = getTaprootOutputKey(outputScript);\n      assert.ok(outputKey.equals(taprootPubkey.xOnlyPubkey));\n    });\n\n    it('builds a weighted taptree from scripts and tweaks a pubkey with it', () => {\n      const scriptA = Buffer.from('2052b319d011c12225b8f9c63349e7b0e78118a1cb7e406fc70e3e08862b49d10aac', 'hex');\n      const scriptB = Buffer.from('20622e61f750f10e597b18a3bb4e5dea88548508b8cb37bfc0fb7af20f7a417d6aac', 'hex');\n      const scriptC = Buffer.from('2092a7d17376802e183fc49fb93d4c9b0a4d1cf845c005debbcc9cd57550a6f617ac', 'hex');\n\n      const tapTree = taproot.getHuffmanTaptree([scriptA, scriptB, scriptC], [1, 1, 2]);\n      const tapTreeRoot = tapTree.root;\n\n      const taprootPubkey = taproot.tapTweakPubkey(ecc, internalPubKey, tapTreeRoot);\n\n      assert.strictEqual(\n        Buffer.from(taprootPubkey.xOnlyPubkey).toString('hex'),\n        '4c537b89b6763b2c415dee24f75a4c80b48bea926361fbf7636cbf9025c46128'\n      );\n    });\n  });\n});\n"]}

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


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