Increase Jest unit test coverage for the Swaps feature to ~25% (#10900)
* Swaps: Show a network name dynamically in a tooltip
* Replace “Ethereum” with “$1”, change “Test” to “Testnet”
* Replace 이더리움 with $1
* Translate network names, use ‘Ethereum’ by default if a translation is not available yet
* Reorder messages to resolve ESLint issues
* Add a snapshot test for the FeeCard component, increase Jest threshold
* Enable snapshot testing into external .snap files in ESLint
* Add the “networkNameEthereum” key in ko/messages.json, remove default “Ethereum” value
* Throw an error if chain ID is not supported by the Swaps feature
* Use string literals when calling the `t` fn,
* Watch Jest tests silently (no React warnings in terminal, only errors)
* Add @testing-library/jest-dom, import it before running Jest tests
* Add snapshot testing of Swaps’ React components for happy paths, increase minimum threshold for Jest
* Add the test/jest folder for Jest setup and shared functions, use it in Swaps Jest tests
* Fix ESLint issues, update linting config
* Enable ESLint for .snap files (Jest snapshots), throw an error if a snapshot is bigger than 50 lines
* Don’t run lint:fix for .snap files
* Move `createProps` outside of `describe` blocks, move store creation inside tests
* Use translations instead of keys, update a rendering function to load translations
* Make sure all Jest snapshots are shorter than 50 lines (default limit)
* Add / update props for Swaps tests
* Fix React warnings when running tests for Swaps
2021-04-21 21:34:35 +02:00
|
|
|
import React, { useMemo } from 'react';
|
|
|
|
import { Provider } from 'react-redux';
|
|
|
|
import { render } from '@testing-library/react';
|
|
|
|
import { MemoryRouter } from 'react-router-dom';
|
|
|
|
import PropTypes from 'prop-types';
|
|
|
|
|
2021-04-28 21:53:59 +02:00
|
|
|
import { I18nContext, LegacyI18nProvider } from '../../ui/contexts/i18n';
|
|
|
|
import { getMessage } from '../../ui/helpers/utils/i18n-helper';
|
Increase Jest unit test coverage for the Swaps feature to ~25% (#10900)
* Swaps: Show a network name dynamically in a tooltip
* Replace “Ethereum” with “$1”, change “Test” to “Testnet”
* Replace 이더리움 with $1
* Translate network names, use ‘Ethereum’ by default if a translation is not available yet
* Reorder messages to resolve ESLint issues
* Add a snapshot test for the FeeCard component, increase Jest threshold
* Enable snapshot testing into external .snap files in ESLint
* Add the “networkNameEthereum” key in ko/messages.json, remove default “Ethereum” value
* Throw an error if chain ID is not supported by the Swaps feature
* Use string literals when calling the `t` fn,
* Watch Jest tests silently (no React warnings in terminal, only errors)
* Add @testing-library/jest-dom, import it before running Jest tests
* Add snapshot testing of Swaps’ React components for happy paths, increase minimum threshold for Jest
* Add the test/jest folder for Jest setup and shared functions, use it in Swaps Jest tests
* Fix ESLint issues, update linting config
* Enable ESLint for .snap files (Jest snapshots), throw an error if a snapshot is bigger than 50 lines
* Don’t run lint:fix for .snap files
* Move `createProps` outside of `describe` blocks, move store creation inside tests
* Use translations instead of keys, update a rendering function to load translations
* Make sure all Jest snapshots are shorter than 50 lines (default limit)
* Add / update props for Swaps tests
* Fix React warnings when running tests for Swaps
2021-04-21 21:34:35 +02:00
|
|
|
import * as en from '../../app/_locales/en/messages.json';
|
|
|
|
|
|
|
|
export const I18nProvider = (props) => {
|
|
|
|
const { currentLocale, current, en: eng } = props;
|
|
|
|
|
|
|
|
const t = useMemo(() => {
|
|
|
|
return (key, ...args) =>
|
|
|
|
getMessage(currentLocale, current, key, ...args) ||
|
|
|
|
getMessage(currentLocale, eng, key, ...args);
|
|
|
|
}, [currentLocale, current, eng]);
|
|
|
|
|
|
|
|
return (
|
|
|
|
<I18nContext.Provider value={t}>{props.children}</I18nContext.Provider>
|
|
|
|
);
|
|
|
|
};
|
|
|
|
|
|
|
|
I18nProvider.propTypes = {
|
|
|
|
currentLocale: PropTypes.string,
|
|
|
|
current: PropTypes.object,
|
|
|
|
en: PropTypes.object,
|
|
|
|
children: PropTypes.node,
|
|
|
|
};
|
|
|
|
|
|
|
|
I18nProvider.defaultProps = {
|
|
|
|
children: undefined,
|
|
|
|
};
|
|
|
|
|
|
|
|
export function renderWithProvider(component, store) {
|
|
|
|
const Wrapper = ({ children }) => {
|
|
|
|
const WithoutStore = () => (
|
|
|
|
<MemoryRouter initialEntries={['/']} initialIndex={0}>
|
|
|
|
<I18nProvider currentLocale="en" current={en} en={en}>
|
|
|
|
<LegacyI18nProvider>{children}</LegacyI18nProvider>
|
|
|
|
</I18nProvider>
|
|
|
|
</MemoryRouter>
|
|
|
|
);
|
|
|
|
return store ? (
|
|
|
|
<Provider store={store}>
|
|
|
|
<WithoutStore></WithoutStore>
|
|
|
|
</Provider>
|
|
|
|
) : (
|
|
|
|
<WithoutStore></WithoutStore>
|
|
|
|
);
|
|
|
|
};
|
|
|
|
|
|
|
|
Wrapper.propTypes = {
|
|
|
|
children: PropTypes.node,
|
|
|
|
};
|
|
|
|
|
|
|
|
return render(component, { wrapper: Wrapper });
|
|
|
|
}
|