PHP WebShell

Текущая директория: /opt/BitGoJS/modules/sdk-coin-icp/dist/test/unit/transactionBuilder

Просмотр файла: transactionRecover.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 testData = __importStar(require("../../resources/icp"));
const getBuilderFactory_1 = require("../getBuilderFactory");
const sinon_1 = __importDefault(require("sinon"));
const sdk_test_1 = require("@bitgo/sdk-test");
const sdk_api_1 = require("@bitgo/sdk-api");
const nock_1 = __importDefault(require("nock"));
const index_1 = require("../../../src/index");
const iface_1 = require("../../../src/lib/iface");
const principal_1 = require("@dfinity/principal");
describe('ICP transaction recovery', async () => {
    let bitgo;
    let recoveryParams;
    let icp;
    let broadcastEndpoint;
    let broadcastResponse;
    let nodeUrl;
    let rosettaNodeUrl;
    let txBuilder;
    const factory = (0, getBuilderFactory_1.getBuilderFactory)('ticp');
    before(function () {
        bitgo = sdk_test_1.TestBitGo.decorate(sdk_api_1.BitGoAPI, { env: 'test' });
        bitgo.safeRegister('icp', index_1.Icp.createInstance);
        bitgo.initializeTestVars();
        recoveryParams = {
            userKey: testData.WRWRecovery.userKey,
            backupKey: testData.WRWRecovery.backupKey,
            walletPassphrase: testData.WRWRecovery.walletPassphrase,
            recoveryDestination: testData.Accounts.account2.address,
        };
        icp = bitgo.coin('icp');
        rosettaNodeUrl = icp.getRosettaNodeUrl();
        nodeUrl = icp.getPublicNodeUrl();
        const principal = principal_1.Principal.fromUint8Array(iface_1.LEDGER_CANISTER_ID);
        const canisterIdHex = principal.toText();
        broadcastEndpoint = `/api/v3/canister/${canisterIdHex}/call`;
        broadcastResponse = Buffer.from(testData.PublicNodeApiBroadcastResponse, 'hex');
    });
    afterEach(function () {
        recoveryParams = {
            userKey: testData.WRWRecovery.userKey,
            backupKey: testData.WRWRecovery.backupKey,
            walletPassphrase: testData.WRWRecovery.walletPassphrase,
            recoveryDestination: testData.Accounts.account2.address,
        };
        nock_1.default.cleanAll();
        sinon_1.default.restore();
    });
    it('should recover a transaction with default memo successfully', async () => {
        txBuilder = factory.getTransferBuilder();
        // Stub the getTransferBuilder to return our txBuilder
        //TODO need to have a better way for test cases WithDefault mocking these functions. TIcket: https://bitgoinc.atlassian.net/browse/WIN-5158
        sinon_1.default.stub(icp, 'getBuilderFactory').returns(factory);
        sinon_1.default.stub(factory, 'getTransferBuilder').returns(txBuilder);
        sinon_1.default.stub(icp, 'signatures').returns(testData.RecoverTransactionSignatureWithDefaultMemo);
        sinon_1.default.stub(txBuilder._utils, 'getMetaData').returns({
            metaData: testData.MetaDataWithDefaultMemo,
            ingressEndTime: testData.MetaDataWithDefaultMemo.ingress_end,
        });
        const body = testData.RecoverySignedTransactionWithDefaultMemo;
        (0, nock_1.default)(rosettaNodeUrl).post(`${iface_1.ACCOUNT_BALANCE_ENDPOINT}`).reply(200, testData.GetAccountBalanceResponse);
        (0, nock_1.default)(nodeUrl).post(broadcastEndpoint, body).reply(200, broadcastResponse);
        const txnId = await icp.recover(recoveryParams);
        txnId.should.be.a.String();
        should_1.default.equal(txnId, testData.TxnId);
    });
    it('should recover a transaction with memo successfully', async () => {
        txBuilder = factory.getTransferBuilder();
        // Stub the getTransferBuilder to return our txBuilder
        sinon_1.default.stub(icp, 'getBuilderFactory').returns(factory);
        sinon_1.default.stub(factory, 'getTransferBuilder').returns(txBuilder);
        sinon_1.default.stub(icp, 'signatures').returns(testData.RecoverTransactionSignatureWithMemo);
        sinon_1.default.stub(txBuilder._utils, 'getMetaData').returns({
            metaData: testData.MetaDataWithMemo,
            ingressEndTime: testData.MetaDataWithMemo.ingress_end,
        });
        const body = testData.RecoverySignedTransactionWithMemo;
        (0, nock_1.default)(rosettaNodeUrl).post(`${iface_1.ACCOUNT_BALANCE_ENDPOINT}`).reply(200, testData.GetAccountBalanceResponse);
        (0, nock_1.default)(nodeUrl).post(broadcastEndpoint, body).reply(200, broadcastResponse);
        recoveryParams.memo = testData.MetaDataWithMemo.memo;
        const txnId = await icp.recover(recoveryParams);
        txnId.should.be.a.String();
        should_1.default.equal(txnId, testData.TxnId);
    });
    it('should fail to recover if broadcast API fails', async () => {
        (0, nock_1.default)(rosettaNodeUrl).post(`${iface_1.ACCOUNT_BALANCE_ENDPOINT}`).reply(200, testData.GetAccountBalanceResponse);
        (0, nock_1.default)(nodeUrl).post(broadcastEndpoint).reply(500, 'Internal Server Error');
        recoveryParams.memo = 0;
        await icp
            .recover(recoveryParams)
            .should.rejectedWith('Transaction broadcast error: Request failed with status code 500');
    });
    it('should fail to recover txn if balance is low', async () => {
        testData.GetAccountBalanceResponse.balances[0].value = '0';
        (0, nock_1.default)(rosettaNodeUrl).post(`${iface_1.ACCOUNT_BALANCE_ENDPOINT}`).reply(200, testData.GetAccountBalanceResponse);
        (0, nock_1.default)(nodeUrl).post(broadcastEndpoint).reply(200, broadcastResponse);
        await icp.recover(recoveryParams).should.rejectedWith('Did not have enough funds to recover');
    });
    it('should fail to recover txn if userKey is not provided', async () => {
        (0, nock_1.default)(rosettaNodeUrl).post(`${iface_1.ACCOUNT_BALANCE_ENDPOINT}`).reply(200, testData.GetAccountBalanceResponse);
        recoveryParams.userKey = '';
        await icp.recover(recoveryParams).should.rejectedWith('missing userKey');
    });
    it('should fail to recover txn if backupKey is not provided', async () => {
        (0, nock_1.default)(rosettaNodeUrl).post(`${iface_1.ACCOUNT_BALANCE_ENDPOINT}`).reply(200, testData.GetAccountBalanceResponse);
        recoveryParams.backupKey = '';
        await icp.recover(recoveryParams).should.rejectedWith('missing backupKey');
    });
    it('should fail to recover txn if wallet passphrase is not provided', async () => {
        (0, nock_1.default)(rosettaNodeUrl).post(`${iface_1.ACCOUNT_BALANCE_ENDPOINT}`).reply(200, testData.GetAccountBalanceResponse);
        recoveryParams.walletPassphrase = '';
        await icp.recover(recoveryParams).should.rejectedWith('missing wallet passphrase');
    });
});
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"transactionRecover.js","sourceRoot":"","sources":["../../../../test/unit/transactionBuilder/transactionRecover.ts"],"names":[],"mappings":"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","sourcesContent":["import should from 'should';\nimport * as testData from '../../resources/icp';\nimport { getBuilderFactory } from '../getBuilderFactory';\nimport sinon from 'sinon';\nimport { TestBitGo } from '@bitgo/sdk-test';\nimport { BitGoAPI } from '@bitgo/sdk-api';\nimport nock from 'nock';\nimport { Icp } from '../../../src/index';\nimport { RecoveryOptions, ACCOUNT_BALANCE_ENDPOINT, LEDGER_CANISTER_ID } from '../../../src/lib/iface';\nimport { Principal } from '@dfinity/principal';\n\ndescribe('ICP transaction recovery', async () => {\n  let bitgo;\n  let recoveryParams: RecoveryOptions;\n  let icp;\n  let broadcastEndpoint: string;\n  let broadcastResponse: Buffer;\n  let nodeUrl: string;\n  let rosettaNodeUrl: string;\n  let txBuilder: any;\n  const factory = getBuilderFactory('ticp');\n\n  before(function () {\n    bitgo = TestBitGo.decorate(BitGoAPI, { env: 'test' });\n    bitgo.safeRegister('icp', Icp.createInstance);\n    bitgo.initializeTestVars();\n    recoveryParams = {\n      userKey: testData.WRWRecovery.userKey,\n      backupKey: testData.WRWRecovery.backupKey,\n      walletPassphrase: testData.WRWRecovery.walletPassphrase,\n      recoveryDestination: testData.Accounts.account2.address,\n    };\n\n    icp = bitgo.coin('icp');\n    rosettaNodeUrl = icp.getRosettaNodeUrl();\n    nodeUrl = icp.getPublicNodeUrl();\n    const principal = Principal.fromUint8Array(LEDGER_CANISTER_ID);\n    const canisterIdHex = principal.toText();\n    broadcastEndpoint = `/api/v3/canister/${canisterIdHex}/call`;\n    broadcastResponse = Buffer.from(testData.PublicNodeApiBroadcastResponse, 'hex');\n  });\n\n  afterEach(function () {\n    recoveryParams = {\n      userKey: testData.WRWRecovery.userKey,\n      backupKey: testData.WRWRecovery.backupKey,\n      walletPassphrase: testData.WRWRecovery.walletPassphrase,\n      recoveryDestination: testData.Accounts.account2.address,\n    };\n    nock.cleanAll();\n    sinon.restore();\n  });\n\n  it('should recover a transaction with default memo successfully', async () => {\n    txBuilder = factory.getTransferBuilder();\n\n    // Stub the getTransferBuilder to return our txBuilder\n    //TODO need to have a better way for test cases WithDefault mocking these functions. TIcket: https://bitgoinc.atlassian.net/browse/WIN-5158\n    sinon.stub(icp, 'getBuilderFactory').returns(factory);\n    sinon.stub(factory, 'getTransferBuilder').returns(txBuilder);\n    sinon.stub(icp, 'signatures').returns(testData.RecoverTransactionSignatureWithDefaultMemo);\n\n    sinon.stub(txBuilder._utils, 'getMetaData').returns({\n      metaData: testData.MetaDataWithDefaultMemo,\n      ingressEndTime: testData.MetaDataWithDefaultMemo.ingress_end,\n    });\n\n    const body = testData.RecoverySignedTransactionWithDefaultMemo;\n    nock(rosettaNodeUrl).post(`${ACCOUNT_BALANCE_ENDPOINT}`).reply(200, testData.GetAccountBalanceResponse);\n    nock(nodeUrl).post(broadcastEndpoint, body).reply(200, broadcastResponse);\n    const txnId = await icp.recover(recoveryParams);\n    txnId.should.be.a.String();\n    should.equal(txnId, testData.TxnId);\n  });\n\n  it('should recover a transaction with memo successfully', async () => {\n    txBuilder = factory.getTransferBuilder();\n\n    // Stub the getTransferBuilder to return our txBuilder\n    sinon.stub(icp, 'getBuilderFactory').returns(factory);\n    sinon.stub(factory, 'getTransferBuilder').returns(txBuilder);\n    sinon.stub(icp, 'signatures').returns(testData.RecoverTransactionSignatureWithMemo);\n\n    sinon.stub(txBuilder._utils, 'getMetaData').returns({\n      metaData: testData.MetaDataWithMemo,\n      ingressEndTime: testData.MetaDataWithMemo.ingress_end,\n    });\n\n    const body = testData.RecoverySignedTransactionWithMemo;\n    nock(rosettaNodeUrl).post(`${ACCOUNT_BALANCE_ENDPOINT}`).reply(200, testData.GetAccountBalanceResponse);\n    nock(nodeUrl).post(broadcastEndpoint, body).reply(200, broadcastResponse);\n    recoveryParams.memo = testData.MetaDataWithMemo.memo;\n    const txnId = await icp.recover(recoveryParams);\n    txnId.should.be.a.String();\n    should.equal(txnId, testData.TxnId);\n  });\n\n  it('should fail to recover if broadcast API fails', async () => {\n    nock(rosettaNodeUrl).post(`${ACCOUNT_BALANCE_ENDPOINT}`).reply(200, testData.GetAccountBalanceResponse);\n    nock(nodeUrl).post(broadcastEndpoint).reply(500, 'Internal Server Error');\n    recoveryParams.memo = 0;\n    await icp\n      .recover(recoveryParams)\n      .should.rejectedWith('Transaction broadcast error: Request failed with status code 500');\n  });\n\n  it('should fail to recover txn if balance is low', async () => {\n    testData.GetAccountBalanceResponse.balances[0].value = '0';\n    nock(rosettaNodeUrl).post(`${ACCOUNT_BALANCE_ENDPOINT}`).reply(200, testData.GetAccountBalanceResponse);\n    nock(nodeUrl).post(broadcastEndpoint).reply(200, broadcastResponse);\n    await icp.recover(recoveryParams).should.rejectedWith('Did not have enough funds to recover');\n  });\n\n  it('should fail to recover txn if userKey is not provided', async () => {\n    nock(rosettaNodeUrl).post(`${ACCOUNT_BALANCE_ENDPOINT}`).reply(200, testData.GetAccountBalanceResponse);\n\n    recoveryParams.userKey = '';\n    await icp.recover(recoveryParams).should.rejectedWith('missing userKey');\n  });\n\n  it('should fail to recover txn if backupKey is not provided', async () => {\n    nock(rosettaNodeUrl).post(`${ACCOUNT_BALANCE_ENDPOINT}`).reply(200, testData.GetAccountBalanceResponse);\n\n    recoveryParams.backupKey = '';\n    await icp.recover(recoveryParams).should.rejectedWith('missing backupKey');\n  });\n\n  it('should fail to recover txn if wallet passphrase is not provided', async () => {\n    nock(rosettaNodeUrl).post(`${ACCOUNT_BALANCE_ENDPOINT}`).reply(200, testData.GetAccountBalanceResponse);\n\n    recoveryParams.walletPassphrase = '';\n    await icp.recover(recoveryParams).should.rejectedWith('missing wallet passphrase');\n  });\n});\n"]}

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


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