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/swaps-banner-alert/swaps-banner-alert.test.js

215 lines
7.2 KiB
JavaScript

import React from 'react';
import configureMockStore from 'redux-mock-store';
import thunk from 'redux-thunk';
import {
renderWithProvider,
createSwapsMockStore,
} from '../../../../test/jest';
import {
QUOTES_EXPIRED_ERROR,
SWAP_FAILED_ERROR,
ERROR_FETCHING_QUOTES,
QUOTES_NOT_AVAILABLE_ERROR,
CONTRACT_DATA_DISABLED_ERROR,
OFFLINE_FOR_MAINTENANCE,
SLIPPAGE_VERY_HIGH_ERROR,
SLIPPAGE_HIGH_ERROR,
SLIPPAGE_LOW_ERROR,
SLIPPAGE_NEGATIVE_ERROR,
} from '../../../../shared/constants/swaps';
import SwapsBannerAlert from './swaps-banner-alert';
const middleware = [thunk];
describe('SwapsBannerAlert', () => {
it('renders the component with the SLIPPAGE_VERY_HIGH_ERROR', () => {
const mockStore = createSwapsMockStore();
const store = configureMockStore(middleware)(mockStore);
const { getByText } = renderWithProvider(
<SwapsBannerAlert
swapsErrorKey={SLIPPAGE_VERY_HIGH_ERROR}
currentSlippage={16}
/>,
store,
);
expect(getByText('Very high slippage')).toBeInTheDocument();
expect(
getByText(
'Slippage tolerance must be 15% or less. Anything higher will result in a bad rate.',
),
).toBeInTheDocument();
expect(getByText('Adjust slippage')).toBeInTheDocument();
});
it('renders the component with the SLIPPAGE_HIGH_ERROR', () => {
const mockStore = createSwapsMockStore();
const store = configureMockStore(middleware)(mockStore);
const { getByText } = renderWithProvider(
<SwapsBannerAlert
swapsErrorKey={SLIPPAGE_HIGH_ERROR}
currentSlippage={5}
/>,
store,
);
expect(getByText('High slippage')).toBeInTheDocument();
expect(
getByText(
'The slippage entered (5%) is considered very high and may result in a bad rate',
),
).toBeInTheDocument();
});
it('renders the component with the SLIPPAGE_HIGH_ERROR with the "Adjust slippage" link', () => {
const mockStore = createSwapsMockStore();
const store = configureMockStore(middleware)(mockStore);
const { getByText } = renderWithProvider(
<SwapsBannerAlert
swapsErrorKey={SLIPPAGE_HIGH_ERROR}
showTransactionSettingsLink
currentSlippage={10}
/>,
store,
);
expect(getByText('High slippage')).toBeInTheDocument();
expect(
getByText(
'The slippage entered (10%) is considered very high and may result in a bad rate',
),
).toBeInTheDocument();
expect(getByText('Adjust slippage')).toBeInTheDocument();
});
it('renders the component with the SLIPPAGE_LOW_ERROR', () => {
const mockStore = createSwapsMockStore();
const store = configureMockStore(middleware)(mockStore);
const { getByText } = renderWithProvider(
<SwapsBannerAlert
swapsErrorKey={SLIPPAGE_LOW_ERROR}
currentSlippage={1}
/>,
store,
);
expect(getByText('Low slippage')).toBeInTheDocument();
expect(
getByText('A value this low (1%) may result in a failed swap'),
).toBeInTheDocument();
});
it('renders the component with the SLIPPAGE_LOW_ERROR with the "Adjust slippage" link', () => {
const mockStore = createSwapsMockStore();
const store = configureMockStore(middleware)(mockStore);
const { getByText } = renderWithProvider(
<SwapsBannerAlert
swapsErrorKey={SLIPPAGE_LOW_ERROR}
showTransactionSettingsLink
currentSlippage={1}
/>,
store,
);
expect(getByText('Low slippage')).toBeInTheDocument();
expect(
getByText('A value this low (1%) may result in a failed swap'),
).toBeInTheDocument();
expect(getByText('Adjust slippage')).toBeInTheDocument();
});
it('renders the component with the SLIPPAGE_NEGATIVE_ERROR', () => {
const mockStore = createSwapsMockStore();
const store = configureMockStore(middleware)(mockStore);
const { getByText } = renderWithProvider(
<SwapsBannerAlert swapsErrorKey={SLIPPAGE_NEGATIVE_ERROR} />,
store,
);
expect(getByText('Increase slippage to continue')).toBeInTheDocument();
expect(
getByText('Slippage must be greater or equal to zero'),
).toBeInTheDocument();
expect(getByText('Adjust slippage')).toBeInTheDocument();
});
it('renders the component with the QUOTES_NOT_AVAILABLE_ERROR', () => {
const mockStore = createSwapsMockStore();
const store = configureMockStore(middleware)(mockStore);
const { getByText } = renderWithProvider(
<SwapsBannerAlert swapsErrorKey={QUOTES_NOT_AVAILABLE_ERROR} />,
store,
);
expect(getByText('No quotes available')).toBeInTheDocument();
expect(
getByText('Reduce the size of your trade or use a different token.'),
).toBeInTheDocument();
expect(getByText('Learn more about Swaps')).toBeInTheDocument();
});
it('renders the component with the ERROR_FETCHING_QUOTES', () => {
const mockStore = createSwapsMockStore();
const store = configureMockStore(middleware)(mockStore);
const { getByText } = renderWithProvider(
<SwapsBannerAlert swapsErrorKey={ERROR_FETCHING_QUOTES} />,
store,
);
expect(getByText('Error fetching quotes')).toBeInTheDocument();
expect(
getByText(
'Hmmm... something went wrong. Try again, or if errors persist, contact customer support.',
),
).toBeInTheDocument();
});
it('renders the component with the CONTRACT_DATA_DISABLED_ERROR', () => {
const mockStore = createSwapsMockStore();
const store = configureMockStore(middleware)(mockStore);
const { getByText } = renderWithProvider(
<SwapsBannerAlert swapsErrorKey={CONTRACT_DATA_DISABLED_ERROR} />,
store,
);
expect(
getByText('Contract data is not enabled on your Ledger'),
).toBeInTheDocument();
expect(
getByText(
'In the Ethereum app on your Ledger, go to "Settings" and allow contract data. Then, try your swap again.',
),
).toBeInTheDocument();
});
it('renders the component with the QUOTES_EXPIRED_ERROR', () => {
const mockStore = createSwapsMockStore();
const store = configureMockStore(middleware)(mockStore);
const { getByText } = renderWithProvider(
<SwapsBannerAlert swapsErrorKey={QUOTES_EXPIRED_ERROR} />,
store,
);
expect(getByText('Quotes timeout')).toBeInTheDocument();
expect(
getByText('Please request new quotes to get the latest rates.'),
).toBeInTheDocument();
});
it('renders the component with the OFFLINE_FOR_MAINTENANCE', () => {
const mockStore = createSwapsMockStore();
const store = configureMockStore(middleware)(mockStore);
const { getByText } = renderWithProvider(
<SwapsBannerAlert swapsErrorKey={OFFLINE_FOR_MAINTENANCE} />,
store,
);
expect(getByText('Offline for maintenance')).toBeInTheDocument();
expect(
getByText(
'MetaMask Swaps is undergoing maintenance. Please check back later.',
),
).toBeInTheDocument();
});
it('renders the component with the SWAP_FAILED_ERROR', () => {
const mockStore = createSwapsMockStore();
const store = configureMockStore(middleware)(mockStore);
const { getByText } = renderWithProvider(
<SwapsBannerAlert swapsErrorKey={SWAP_FAILED_ERROR} />,
store,
);
expect(getByText('Swap failed')).toBeInTheDocument();
});
});