mirror of
https://github.com/kremalicious/metamask-extension.git
synced 2024-12-23 09:52:26 +01:00
215 lines
7.2 KiB
JavaScript
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();
|
|
});
|
|
});
|