1
0
mirror of https://github.com/kremalicious/metamask-extension.git synced 2024-12-23 09:52:26 +01:00
metamask-extension/ui/pages/swaps/prepare-swap-page/view-quote-price-difference.test.js

151 lines
6.3 KiB
JavaScript
Raw Normal View History

2023-06-15 20:17:21 +02:00
import React from 'react';
import configureMockStore from 'redux-mock-store';
import { renderWithProvider } from '../../../../test/lib/render-helpers';
import { NETWORK_TYPES } from '../../../../shared/constants/network';
import { GasRecommendations } from '../../../../shared/constants/gas';
import ViewQuotePriceDifference from './view-quote-price-difference';
describe('View Price Quote Difference', () => {
const mockState = {
metamask: {
tokens: [],
providerConfig: { type: NETWORK_TYPES.RPC, nickname: '', rpcUrl: '' },
preferences: { showFiatInTestnets: true },
currentCurrency: 'usd',
conversionRate: 600.0,
},
};
const mockStore = configureMockStore()(mockState);
// Sample transaction is 1 ETH to ~42.880915 LINK.
const DEFAULT_PROPS = {
usedQuote: {
trade: {
data: '0x5f575529000000000000000000000000000000000000000000000000000000000000008000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000de0b6b3a764000000000000000000000000000000000000000000000000000000000000000000c00000000000000000000000000000000000000000000000000000000000000007756e69737761700000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000001600000000000000000000000000000000000000000000000000000000000000000000000000000000000000000514910771af9ca656af840dff83e8264ecf986ca0000000000000000000000000000000000000000000000000dc1a09f859b20000000000000000000000000000000000000000000000000024855454cb32d335f0000000000000000000000000000000000000000000000000000000000000120000000000000000000000000000000000000000000000000000000005fc7b7100000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000001f161421c8e0000000000000000000000000000000000000000000000000000000000000000002000000000000000000000000c02aaa39b223fe8d0a0e5c4f27ead9083c756cc2000000000000000000000000514910771af9ca656af840dff83e8264ecf986ca',
from: '0xd7440fdcb70a9fba55dfe06942ddbc17679c90ac',
value: '0xde0b6b3a7640000',
gas: '0xbbfd0',
to: '0x881D40237659C251811CEC9c364ef91dC08D300C',
},
sourceAmount: '1000000000000000000',
destinationAmount: '42947749216634160067',
error: null,
sourceToken: '0x0000000000000000000000000000000000000000',
destinationToken: '0x514910771af9ca656af840dff83e8264ecf986ca',
approvalNeeded: null,
maxGas: 770000,
averageGas: 210546,
estimatedRefund: 80000,
fetchTime: 647,
aggregator: 'uniswap',
aggType: 'DEX',
fee: 0.875,
gasMultiplier: 1.5,
priceSlippage: {
ratio: 1.007876641534847,
calculationError: '',
bucket: GasRecommendations.low,
sourceAmountInETH: 1,
destinationAmountInETH: 0.9921849150875727,
},
slippage: 2,
sourceTokenInfo: {
symbol: 'ETH',
name: 'Ether',
address: '0x0000000000000000000000000000000000000000',
decimals: 18,
iconUrl: 'images/black-eth-logo.svg',
},
destinationTokenInfo: {
address: '0x514910771af9ca656af840dff83e8264ecf986ca',
symbol: 'LINK',
decimals: 18,
occurances: 12,
iconUrl:
'https://cloudflare-ipfs.com/ipfs/QmQhZAdcZvW9T2tPm516yHqbGkfhyZwTZmLixW9MXJudTA',
},
ethFee: '0.011791',
ethValueOfTokens: '0.99220724791716534441',
overallValueOfQuote: '0.98041624791716534441',
metaMaskFeeInEth: '0.00875844985551091729',
isBestQuote: true,
savings: {
performance: '0.00207907025112527799',
fee: '0.005581',
metaMaskFee: '0.00875844985551091729',
total: '-0.0010983796043856393',
medianMetaMaskFee: '0.00874009740688812165',
},
},
sourceTokenValue: '1',
destinationTokenValue: '42.947749',
};
it('displays an error when in low bucket', () => {
const { getByText, getByTestId } = renderWithProvider(
<ViewQuotePriceDifference {...DEFAULT_PROPS} />,
mockStore,
);
expect(getByTestId('mm-banner-alert')).toHaveClass(
'mm-banner-alert--severity-warning',
);
expect(
getByText('You are about to swap 1 ETH (~) for 42.947749 LINK (~).'),
).toBeInTheDocument();
expect(getByText('Swap anyway')).toBeInTheDocument();
});
it('displays an error when in medium bucket', () => {
const props = { ...DEFAULT_PROPS };
props.usedQuote.priceSlippage.bucket = GasRecommendations.medium;
const { getByText, getByTestId } = renderWithProvider(
<ViewQuotePriceDifference {...props} />,
mockStore,
);
expect(getByTestId('mm-banner-alert')).toHaveClass(
'mm-banner-alert--severity-warning',
);
expect(
getByText('You are about to swap 1 ETH (~) for 42.947749 LINK (~).'),
).toBeInTheDocument();
expect(getByText('Swap anyway')).toBeInTheDocument();
});
it('displays an error when in high bucket', () => {
const props = { ...DEFAULT_PROPS };
props.usedQuote.priceSlippage.bucket = GasRecommendations.high;
const { getByText, getByTestId } = renderWithProvider(
<ViewQuotePriceDifference {...props} />,
mockStore,
);
expect(getByTestId('mm-banner-alert')).toHaveClass(
'mm-banner-alert--severity-danger',
);
expect(
getByText('You are about to swap 1 ETH (~) for 42.947749 LINK (~).'),
).toBeInTheDocument();
expect(getByText('Swap anyway')).toBeInTheDocument();
});
it('displays a fiat error when calculationError is present', () => {
const props = { ...DEFAULT_PROPS, priceSlippageUnknownFiatValue: true };
props.usedQuote.priceSlippage.calculationError =
'Could not determine price.';
const { getByText, getByTestId } = renderWithProvider(
<ViewQuotePriceDifference {...props} />,
mockStore,
);
expect(getByTestId('mm-banner-alert')).toHaveClass(
'mm-banner-alert--severity-danger',
);
expect(getByText('Check your rate before proceeding')).toBeInTheDocument();
expect(
getByText(
'Price impact could not be determined due to lack of market price data. Please confirm that you are comfortable with the amount of tokens you are about to receive before swapping.',
),
).toBeInTheDocument();
expect(getByText('Swap anyway')).toBeInTheDocument();
});
});