mirror of
https://github.com/kremalicious/metamask-extension.git
synced 2024-12-23 09:52:26 +01:00
170 lines
5.5 KiB
JavaScript
170 lines
5.5 KiB
JavaScript
import * as reactRedux from 'react-redux';
|
|
import { renderHook } from '@testing-library/react-hooks';
|
|
import sinon from 'sinon';
|
|
import transactions from '../../test/data/transaction-data.json';
|
|
import { getConversionRate, getSelectedAccount } from '../selectors';
|
|
import { showModal } from '../store/actions';
|
|
import { increaseLastGasPrice } from '../helpers/utils/confirm-tx.util';
|
|
import * as actionConstants from '../store/actionConstants';
|
|
import { GAS_LIMITS } from '../../shared/constants/gas';
|
|
import { useCancelTransaction } from './useCancelTransaction';
|
|
|
|
describe('useCancelTransaction', function () {
|
|
let useSelector;
|
|
const dispatch = sinon.spy();
|
|
|
|
beforeAll(function () {
|
|
sinon.stub(reactRedux, 'useDispatch').returns(dispatch);
|
|
});
|
|
|
|
afterEach(function () {
|
|
dispatch.resetHistory();
|
|
});
|
|
|
|
afterAll(function () {
|
|
sinon.restore();
|
|
});
|
|
|
|
describe('when account has insufficient balance to cover gas', function () {
|
|
beforeAll(function () {
|
|
useSelector = sinon.stub(reactRedux, 'useSelector');
|
|
useSelector.callsFake((selector) => {
|
|
if (selector === getConversionRate) {
|
|
return 280.46;
|
|
} else if (selector === getSelectedAccount) {
|
|
return {
|
|
balance: '0x3',
|
|
};
|
|
}
|
|
return undefined;
|
|
});
|
|
});
|
|
afterAll(function () {
|
|
useSelector.restore();
|
|
});
|
|
transactions.forEach((transactionGroup) => {
|
|
const originalGasPrice =
|
|
transactionGroup.primaryTransaction.txParams?.gasPrice;
|
|
const gasPrice =
|
|
originalGasPrice && increaseLastGasPrice(originalGasPrice);
|
|
const transactionId = transactionGroup.initialTransaction.id;
|
|
it(`should indicate account has insufficient funds to cover ${gasPrice} gas price`, function () {
|
|
const { result } = renderHook(() =>
|
|
useCancelTransaction(transactionGroup),
|
|
);
|
|
expect(result.current[0]).toStrictEqual(false);
|
|
});
|
|
it(`should return a function that opens the gas sidebar onsubmit kicks off cancellation for id ${transactionId}`, function () {
|
|
const { result } = renderHook(() =>
|
|
useCancelTransaction(transactionGroup),
|
|
);
|
|
expect(typeof result.current[1]).toStrictEqual('function');
|
|
result.current[1]({
|
|
preventDefault: () => undefined,
|
|
stopPropagation: () => undefined,
|
|
});
|
|
const dispatchAction = dispatch.args;
|
|
|
|
// calls customize-gas sidebar
|
|
// also check type= customize-gas
|
|
expect(dispatchAction[dispatchAction.length - 1][0].type).toStrictEqual(
|
|
actionConstants.SIDEBAR_OPEN,
|
|
);
|
|
|
|
expect(
|
|
dispatchAction[dispatchAction.length - 1][0].value.props.transaction
|
|
.id,
|
|
).toStrictEqual(transactionId);
|
|
|
|
// call onSubmit myself
|
|
dispatchAction[dispatchAction.length - 1][0].value.props.onSubmit(
|
|
GAS_LIMITS.SIMPLE,
|
|
'0x1',
|
|
);
|
|
|
|
expect(
|
|
dispatch.calledWith(
|
|
showModal({
|
|
name: 'CANCEL_TRANSACTION',
|
|
transactionId,
|
|
newGasFee: GAS_LIMITS.SIMPLE,
|
|
defaultNewGasPrice: '0x1',
|
|
gasLimit: GAS_LIMITS.SIMPLE,
|
|
}),
|
|
),
|
|
).toStrictEqual(true);
|
|
});
|
|
});
|
|
});
|
|
|
|
describe('when account has sufficient balance to cover gas', function () {
|
|
beforeAll(function () {
|
|
useSelector = sinon.stub(reactRedux, 'useSelector');
|
|
useSelector.callsFake((selector) => {
|
|
if (selector === getConversionRate) {
|
|
return 280.46;
|
|
} else if (selector === getSelectedAccount) {
|
|
return {
|
|
balance: '0x9C2007651B2500000',
|
|
};
|
|
}
|
|
return undefined;
|
|
});
|
|
});
|
|
|
|
afterAll(function () {
|
|
useSelector.restore();
|
|
});
|
|
|
|
transactions.forEach((transactionGroup) => {
|
|
const originalGasPrice =
|
|
transactionGroup.primaryTransaction.txParams?.gasPrice;
|
|
const gasPrice =
|
|
originalGasPrice && increaseLastGasPrice(originalGasPrice);
|
|
const transactionId = transactionGroup.initialTransaction.id;
|
|
it(`should indicate account has funds to cover ${gasPrice} gas price`, function () {
|
|
const { result } = renderHook(() =>
|
|
useCancelTransaction(transactionGroup),
|
|
);
|
|
expect(result.current[0]).toStrictEqual(true);
|
|
});
|
|
it(`should return a function that opens the gas sidebar onsubmit kicks off cancellation for id ${transactionId}`, function () {
|
|
const { result } = renderHook(() =>
|
|
useCancelTransaction(transactionGroup),
|
|
);
|
|
expect(typeof result.current[1]).toStrictEqual('function');
|
|
result.current[1]({
|
|
preventDefault: () => undefined,
|
|
stopPropagation: () => undefined,
|
|
});
|
|
const dispatchAction = dispatch.args;
|
|
|
|
expect(dispatchAction[dispatchAction.length - 1][0].type).toStrictEqual(
|
|
actionConstants.SIDEBAR_OPEN,
|
|
);
|
|
expect(
|
|
dispatchAction[dispatchAction.length - 1][0].value.props.transaction
|
|
.id,
|
|
).toStrictEqual(transactionId);
|
|
|
|
dispatchAction[dispatchAction.length - 1][0].value.props.onSubmit(
|
|
GAS_LIMITS.SIMPLE,
|
|
'0x1',
|
|
);
|
|
|
|
expect(
|
|
dispatch.calledWith(
|
|
showModal({
|
|
name: 'CANCEL_TRANSACTION',
|
|
transactionId,
|
|
newGasFee: GAS_LIMITS.SIMPLE,
|
|
defaultNewGasPrice: '0x1',
|
|
gasLimit: GAS_LIMITS.SIMPLE,
|
|
}),
|
|
),
|
|
).toStrictEqual(true);
|
|
});
|
|
});
|
|
});
|
|
});
|