PHP WebShell

Текущая директория: /opt/BitGoJS/modules/bitgo/dist/test/v2/unit/coins/utxo

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

"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
/**
 * @prettier
 */
require("should");
const assert = require("assert");
const utxolib = require("@bitgo/utxo-lib");
const { chainCodes } = utxolib.bitgo;
const util_1 = require("./util");
// TODO (@rushilbg): Delete these tests because they are redundant (similar tests are in utxo-lib)
function isCompatibleAddress(a, b) {
    if (a === b) {
        return true;
    }
    switch (a.getChain()) {
        case 'btc':
        case 'bsv':
        case 'bch':
        case 'bcha':
            return ['btc', 'bsv', 'bch', 'bcha'].includes(b.getChain());
        case 'tbtc':
        case 'tbtcsig':
        case 'tbtc4':
        case 'tbtcbgsig':
        case 'tbsv':
        case 'tbch':
        case 'tdoge':
        case 'tbcha':
            return ['tbtc', 'tbtcsig', 'tbtc4', 'tbtcbgsig', 'tbsv', 'tbch', 'tbcha', 'tdoge'].includes(b.getChain());
        default:
            return false;
    }
}
function run(coin) {
    const keychains = util_1.keychains.map((k) => ({ pub: k.neutered().toBase58() }));
    function getParameters() {
        return [undefined, ...chainCodes].map((chain) => ({ keychains, chain }));
    }
    describe(`UTXO Addresses ${coin.getChain()}`, function () {
        it('address support', function () {
            const supportedAddressTypes = utxolib.bitgo.outputScripts.scriptTypes2Of3.filter((t) => coin.supportsAddressType(t));
            switch (coin.getChain()) {
                case 'btc':
                case 'tbtc':
                case 'tbtcsig':
                case 'tbtc4':
                case 'tbtcbgsig':
                    supportedAddressTypes.should.eql(['p2sh', 'p2shP2wsh', 'p2wsh', 'p2tr', 'p2trMusig2']);
                    break;
                case 'btg':
                case 'tbtg':
                case 'ltc':
                case 'tltc':
                    supportedAddressTypes.should.eql(['p2sh', 'p2shP2wsh', 'p2wsh']);
                    break;
                case 'bch':
                case 'tbch':
                case 'bcha':
                case 'tbcha':
                case 'bsv':
                case 'tbsv':
                case 'dash':
                case 'tdash':
                case 'doge':
                case 'tdoge':
                case 'zec':
                case 'tzec':
                    supportedAddressTypes.should.eql(['p2sh']);
                    break;
                default:
                    throw new Error(`unexpected coin ${coin.getChain()}`);
            }
        });
        it('generates address matching the fixtures', async function () {
            const addresses = getParameters().map((p) => {
                const label = { chain: p.chain === undefined ? 'default' : p.chain };
                try {
                    return [label, coin.generateAddress(p)];
                }
                catch (e) {
                    return [label, { error: e.message }];
                }
            });
            (0, util_1.shouldEqualJSON)(addresses, await (0, util_1.getFixture)(coin, 'addresses-by-chain', addresses));
        });
        it('validates and verifies generated addresses', function () {
            getParameters().forEach((p) => {
                if (p.chain && !coin.supportsAddressChain(p.chain)) {
                    assert.throws(() => coin.generateAddress(p));
                    return;
                }
                const a = coin.generateAddress(p);
                coin.isValidAddress(a.address).should.eql(true);
                if (a.address !== a.address.toUpperCase()) {
                    coin.isValidAddress(a.address.toUpperCase()).should.eql(false);
                }
                coin.verifyAddress({ ...a, keychains });
            });
        });
        it('defaults to canonical address', function () {
            getParameters().forEach((p) => {
                if (!p.chain || coin.supportsAddressChain(p.chain)) {
                    const address = coin.generateAddress(p).address;
                    coin.canonicalAddress(address).should.eql(address);
                }
            });
        });
        util_1.utxoCoins.forEach((otherCoin) => {
            it(`has expected address compatability with ${otherCoin.getChain()}`, async function () {
                getParameters().forEach((p) => {
                    if (p.chain && (!coin.supportsAddressChain(p.chain) || !otherCoin.supportsAddressChain(p.chain))) {
                        return;
                    }
                    const address = coin.generateAddress(p);
                    const otherAddress = otherCoin.generateAddress(p);
                    (address.address === otherAddress.address).should.eql(isCompatibleAddress(coin, otherCoin));
                    coin.isValidAddress(otherAddress.address).should.eql(isCompatibleAddress(coin, otherCoin));
                });
            });
        });
    });
}
util_1.utxoCoins.forEach((c) => run(c));
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"address.js","sourceRoot":"","sources":["../../../../../../test/v2/unit/coins/utxo/address.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @prettier\n */\nimport 'should';\nimport * as assert from 'assert';\nimport * as utxolib from '@bitgo/utxo-lib';\nconst { chainCodes } = utxolib.bitgo;\n\nimport { AbstractUtxoCoin, GenerateFixedScriptAddressOptions } from '@bitgo/abstract-utxo';\n\nimport { utxoCoins, keychains as keychainsBip32, getFixture, shouldEqualJSON } from './util';\n\n// TODO (@rushilbg): Delete these tests because they are redundant (similar tests are in utxo-lib)\nfunction isCompatibleAddress(a: AbstractUtxoCoin, b: AbstractUtxoCoin): boolean {\n  if (a === b) {\n    return true;\n  }\n  switch (a.getChain()) {\n    case 'btc':\n    case 'bsv':\n    case 'bch':\n    case 'bcha':\n      return ['btc', 'bsv', 'bch', 'bcha'].includes(b.getChain());\n    case 'tbtc':\n    case 'tbtcsig':\n    case 'tbtc4':\n    case 'tbtcbgsig':\n    case 'tbsv':\n    case 'tbch':\n    case 'tdoge':\n    case 'tbcha':\n      return ['tbtc', 'tbtcsig', 'tbtc4', 'tbtcbgsig', 'tbsv', 'tbch', 'tbcha', 'tdoge'].includes(b.getChain());\n    default:\n      return false;\n  }\n}\n\nfunction run(coin: AbstractUtxoCoin) {\n  const keychains = keychainsBip32.map((k) => ({ pub: k.neutered().toBase58() }));\n\n  function getParameters(): GenerateFixedScriptAddressOptions[] {\n    return [undefined, ...chainCodes].map((chain) => ({ keychains, chain }));\n  }\n\n  describe(`UTXO Addresses ${coin.getChain()}`, function () {\n    it('address support', function () {\n      const supportedAddressTypes = utxolib.bitgo.outputScripts.scriptTypes2Of3.filter((t) =>\n        coin.supportsAddressType(t)\n      );\n      switch (coin.getChain()) {\n        case 'btc':\n        case 'tbtc':\n        case 'tbtcsig':\n        case 'tbtc4':\n        case 'tbtcbgsig':\n          supportedAddressTypes.should.eql(['p2sh', 'p2shP2wsh', 'p2wsh', 'p2tr', 'p2trMusig2']);\n          break;\n        case 'btg':\n        case 'tbtg':\n        case 'ltc':\n        case 'tltc':\n          supportedAddressTypes.should.eql(['p2sh', 'p2shP2wsh', 'p2wsh']);\n          break;\n        case 'bch':\n        case 'tbch':\n        case 'bcha':\n        case 'tbcha':\n        case 'bsv':\n        case 'tbsv':\n        case 'dash':\n        case 'tdash':\n        case 'doge':\n        case 'tdoge':\n        case 'zec':\n        case 'tzec':\n          supportedAddressTypes.should.eql(['p2sh']);\n          break;\n        default:\n          throw new Error(`unexpected coin ${coin.getChain()}`);\n      }\n    });\n\n    it('generates address matching the fixtures', async function () {\n      const addresses = getParameters().map((p) => {\n        const label = { chain: p.chain === undefined ? 'default' : p.chain };\n        try {\n          return [label, coin.generateAddress(p)];\n        } catch (e) {\n          return [label, { error: e.message }];\n        }\n      });\n\n      shouldEqualJSON(addresses, await getFixture(coin, 'addresses-by-chain', addresses));\n    });\n\n    it('validates and verifies generated addresses', function () {\n      getParameters().forEach((p) => {\n        if (p.chain && !coin.supportsAddressChain(p.chain)) {\n          assert.throws(() => coin.generateAddress(p));\n          return;\n        }\n\n        const a = coin.generateAddress(p);\n        coin.isValidAddress(a.address).should.eql(true);\n        if (a.address !== a.address.toUpperCase()) {\n          coin.isValidAddress(a.address.toUpperCase()).should.eql(false);\n        }\n        coin.verifyAddress({ ...a, keychains });\n      });\n    });\n\n    it('defaults to canonical address', function () {\n      getParameters().forEach((p) => {\n        if (!p.chain || coin.supportsAddressChain(p.chain)) {\n          const address = coin.generateAddress(p).address;\n          coin.canonicalAddress(address).should.eql(address);\n        }\n      });\n    });\n\n    utxoCoins.forEach((otherCoin) => {\n      it(`has expected address compatability with ${otherCoin.getChain()}`, async function () {\n        getParameters().forEach((p) => {\n          if (p.chain && (!coin.supportsAddressChain(p.chain) || !otherCoin.supportsAddressChain(p.chain))) {\n            return;\n          }\n          const address = coin.generateAddress(p);\n          const otherAddress = otherCoin.generateAddress(p);\n          (address.address === otherAddress.address).should.eql(isCompatibleAddress(coin, otherCoin));\n          coin.isValidAddress(otherAddress.address).should.eql(isCompatibleAddress(coin, otherCoin));\n        });\n      });\n    });\n  });\n}\n\nutxoCoins.forEach((c) => run(c));\n"]}

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


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