diff --git a/.eslintrc.js b/.eslintrc.js index b764ad39caf6..8b9f27b12161 100644 --- a/.eslintrc.js +++ b/.eslintrc.js @@ -130,6 +130,7 @@ module.exports = { rules: { 'jest/no-restricted-matchers': 'off', 'import/unambiguous': 'off', + 'import/named': 'off', }, }, { diff --git a/jest.config.js b/jest.config.js index 9b3dc4459f2a..df0558fcfd6a 100644 --- a/jest.config.js +++ b/jest.config.js @@ -1,12 +1,14 @@ module.exports = { restoreMocks: true, coverageDirectory: 'jest-coverage/', + collectCoverageFrom: ['/ui/app/**/swaps/**'], + coveragePathIgnorePatterns: ['.stories.js', '.snap'], coverageThreshold: { global: { - branches: 21.24, - functions: 23.01, - lines: 27.19, - statements: 27.07, + branches: 32.75, + functions: 43.31, + lines: 43.12, + statements: 43.67, }, }, setupFiles: ['./test/setup.js', './test/env.js'], diff --git a/package.json b/package.json index 2046db71aa4a..bd6f7e1f4995 100644 --- a/package.json +++ b/package.json @@ -33,7 +33,7 @@ "test:e2e:firefox": "SELENIUM_BROWSER=firefox test/e2e/run-all.sh", "test:e2e:firefox:metrics": "SELENIUM_BROWSER=firefox mocha test/e2e/metrics.spec.js", "test:coverage": "nyc --silent --check-coverage yarn test:unit:strict && nyc --silent --no-clean yarn test:unit:lax && nyc report --reporter=text --reporter=html", - "test:coverage:jest": "jest --coverage --maxWorkers=2 --collectCoverageFrom=**/ui/app/**/swaps/**", + "test:coverage:jest": "jest --coverage --maxWorkers=2", "test:coverage:strict": "nyc --check-coverage yarn test:unit:strict", "test:coverage:path": "nyc --check-coverage yarn test:unit:path", "ganache:start": "./development/run-ganache.sh", diff --git a/test/jest/background.js b/test/jest/background.js new file mode 100644 index 000000000000..49a6bdf8f6d5 --- /dev/null +++ b/test/jest/background.js @@ -0,0 +1,5 @@ +import * as actions from '../../ui/app/store/actions'; + +export const setBackgroundConnection = (backgroundConnection = {}) => { + actions._setBackgroundConnection(backgroundConnection); +}; diff --git a/test/jest/constants.js b/test/jest/constants.js new file mode 100644 index 000000000000..2ed360574d46 --- /dev/null +++ b/test/jest/constants.js @@ -0,0 +1 @@ +export const METASWAP_BASE_URL = 'https://api.metaswap.codefi.network'; diff --git a/test/jest/index.js b/test/jest/index.js index be8cd13bf094..098877489808 100644 --- a/test/jest/index.js +++ b/test/jest/index.js @@ -1,4 +1,5 @@ -import { createSwapsMockStore } from './mock-store'; -import { renderWithProvider } from './rendering'; - -export { createSwapsMockStore, renderWithProvider }; +export { createSwapsMockStore } from './mock-store'; +export { renderWithProvider } from './rendering'; +export { setBackgroundConnection } from './background'; +export * as MOCKS from './mocks'; +export * as CONSTANTS from './constants'; diff --git a/test/jest/mock-store.js b/test/jest/mock-store.js index a90ada6d71f9..88d4861930ab 100644 --- a/test/jest/mock-store.js +++ b/test/jest/mock-store.js @@ -6,6 +6,7 @@ export const createSwapsMockStore = () => { customGas: { fallBackPrice: 5, }, + fromToken: 'ETH', }, metamask: { provider: { @@ -14,6 +15,15 @@ export const createSwapsMockStore = () => { cachedBalances: { [MAINNET_CHAIN_ID]: 5, }, + preferences: { + showFiatInTestnets: true, + }, + currentCurrency: 'ETH', + conversionRate: 1, + contractExchangeRates: { + '0xa0b86991c6218b36c1d19d4a2e9eb0ce3606eb48': 2, + '0x1111111111111111111111111111111111111111': 0.1, + }, accounts: { '0x0dcd5d886577d5081b0c52e242ef29e70be3e7bc': { address: '0x0dcd5d886577d5081b0c52e242ef29e70be3e7bc', @@ -26,6 +36,20 @@ export const createSwapsMockStore = () => { }, selectedAddress: '0x0dcd5d886577d5081b0c52e242ef29e70be3e7bc', frequentRpcListDetail: [], + tokens: [ + { + erc20: true, + symbol: 'BAT', + decimals: 18, + address: '0x0D8775F648430679A709E98d2b0Cb6250d2887EF', + }, + { + erc20: true, + symbol: 'USDT', + decimals: 6, + address: '0xdAC17F958D2ee523a2206206994597C13D831ec7', + }, + ], swapsState: { quotes: {}, fetchParams: { @@ -38,20 +62,6 @@ export const createSwapsMockStore = () => { }, }, }, - tokens: [ - { - erc20: true, - symbol: 'BAT', - decimals: 18, - address: '0x0D8775F648430679A709E98d2b0Cb6250d2887EF', - }, - { - erc20: true, - symbol: 'USDT', - decimals: 6, - address: '0xdAC17F958D2ee523a2206206994597C13D831ec7', - }, - ], tradeTxId: null, approveTxId: null, quotesLastFetched: null, diff --git a/test/jest/mocks.js b/test/jest/mocks.js new file mode 100644 index 000000000000..c57b2068c0d3 --- /dev/null +++ b/test/jest/mocks.js @@ -0,0 +1,61 @@ +export const TOP_ASSETS_GET_RESPONSE = [ + { + symbol: 'LINK', + address: '0x514910771af9ca656af840dff83e8264ecf986ca', + }, + { + symbol: 'UMA', + address: '0x04fa0d235c4abf4bcf4787af4cf447de572ef828', + }, + { + symbol: 'YFI', + address: '0x0bc529c00c6401aef6d220be8c6ea1667f6ad93e', + }, + { + symbol: 'LEND', + address: '0x80fb784b7ed66730e8b1dbd9820afd29931aab03', + }, + { + symbol: 'SNX', + address: '0xc011a73ee8576fb46f5e1c5751ca3b9fe0af2a6f', + }, +]; + +export const REFRESH_TIME_GET_RESPONSE = { + seconds: 3600, +}; + +export const AGGREGATOR_METADATA_GET_RESPONSE = {}; + +export const GAS_PRICES_GET_RESPONSE = { + SafeGasPrice: '10', + ProposeGasPrice: '20', + FastGasPrice: '30', +}; + +export const TOKENS_GET_RESPONSE = [ + { + erc20: true, + symbol: 'META', + decimals: 18, + address: '0x617b3f8050a0BD94b6b1da02B4384eE5B4DF13F4', + }, + { + erc20: true, + symbol: 'ZRX', + decimals: 18, + address: '0xE41d2489571d322189246DaFA5ebDe1F4699F498', + }, + { + erc20: true, + symbol: 'AST', + decimals: 4, + address: '0x27054b13b1B798B345b591a4d22e6562d47eA75a', + }, + { + erc20: true, + symbol: 'BAT', + decimals: 18, + address: '0x0D8775F648430679A709E98d2b0Cb6250d2887EF', + }, +]; diff --git a/ui/app/__mocks__/react-router-dom.js b/ui/app/__mocks__/react-router-dom.js index 981a488d797d..dd15434a12c1 100644 --- a/ui/app/__mocks__/react-router-dom.js +++ b/ui/app/__mocks__/react-router-dom.js @@ -3,4 +3,9 @@ const originalModule = jest.requireActual('react-router-dom'); module.exports = { ...originalModule, useHistory: jest.fn(), + useLocation: jest.fn(() => { + return { + pathname: '/swaps/build-quote', + }; + }), }; diff --git a/ui/app/pages/swaps/__snapshots__/index.test.js.snap b/ui/app/pages/swaps/__snapshots__/index.test.js.snap new file mode 100644 index 000000000000..e35876ecbbf3 --- /dev/null +++ b/ui/app/pages/swaps/__snapshots__/index.test.js.snap @@ -0,0 +1,31 @@ +// Jest Snapshot v1, https://goo.gl/fbAQLP + +exports[`Swap renders the component with initial props 1`] = ` +
+
+
+
+
+ Swap +
+
+ Cancel +
+
+
+
+
+
+`; diff --git a/ui/app/pages/swaps/awaiting-swap/__snapshots__/quotes-timeout-icon.test.js.snap b/ui/app/pages/swaps/awaiting-swap/__snapshots__/quotes-timeout-icon.test.js.snap new file mode 100644 index 000000000000..d117414fa8b6 --- /dev/null +++ b/ui/app/pages/swaps/awaiting-swap/__snapshots__/quotes-timeout-icon.test.js.snap @@ -0,0 +1,18 @@ +// Jest Snapshot v1, https://goo.gl/fbAQLP + +exports[`QuotesTimeoutIcon renders the component 1`] = ` +
+ + + +
+`; diff --git a/ui/app/pages/swaps/awaiting-swap/__snapshots__/swap-failure-icon.test.js.snap b/ui/app/pages/swaps/awaiting-swap/__snapshots__/swap-failure-icon.test.js.snap new file mode 100644 index 000000000000..3d195032b399 --- /dev/null +++ b/ui/app/pages/swaps/awaiting-swap/__snapshots__/swap-failure-icon.test.js.snap @@ -0,0 +1,18 @@ +// Jest Snapshot v1, https://goo.gl/fbAQLP + +exports[`SwapFailureIcon renders the component 1`] = ` +
+ + + +
+`; diff --git a/ui/app/pages/swaps/awaiting-swap/__snapshots__/swap-success-icon.test.js.snap b/ui/app/pages/swaps/awaiting-swap/__snapshots__/swap-success-icon.test.js.snap new file mode 100644 index 000000000000..f5c27628d420 --- /dev/null +++ b/ui/app/pages/swaps/awaiting-swap/__snapshots__/swap-success-icon.test.js.snap @@ -0,0 +1,18 @@ +// Jest Snapshot v1, https://goo.gl/fbAQLP + +exports[`SwapSuccessIcon renders the component 1`] = ` +
+ + + +
+`; diff --git a/ui/app/pages/swaps/awaiting-swap/quotes-timeout-icon.test.js b/ui/app/pages/swaps/awaiting-swap/quotes-timeout-icon.test.js new file mode 100644 index 000000000000..6afc922efdfb --- /dev/null +++ b/ui/app/pages/swaps/awaiting-swap/quotes-timeout-icon.test.js @@ -0,0 +1,11 @@ +import React from 'react'; + +import { renderWithProvider } from '../../../../../test/jest'; +import QuotesTimeoutIcon from './quotes-timeout-icon'; + +describe('QuotesTimeoutIcon', () => { + it('renders the component', () => { + const { container } = renderWithProvider(); + expect(container).toMatchSnapshot(); + }); +}); diff --git a/ui/app/pages/swaps/awaiting-swap/swap-failure-icon.test.js b/ui/app/pages/swaps/awaiting-swap/swap-failure-icon.test.js new file mode 100644 index 000000000000..be75020f8810 --- /dev/null +++ b/ui/app/pages/swaps/awaiting-swap/swap-failure-icon.test.js @@ -0,0 +1,11 @@ +import React from 'react'; + +import { renderWithProvider } from '../../../../../test/jest'; +import SwapFailureIcon from './swap-failure-icon'; + +describe('SwapFailureIcon', () => { + it('renders the component', () => { + const { container } = renderWithProvider(); + expect(container).toMatchSnapshot(); + }); +}); diff --git a/ui/app/pages/swaps/awaiting-swap/swap-success-icon.test.js b/ui/app/pages/swaps/awaiting-swap/swap-success-icon.test.js new file mode 100644 index 000000000000..39d9eed1258a --- /dev/null +++ b/ui/app/pages/swaps/awaiting-swap/swap-success-icon.test.js @@ -0,0 +1,11 @@ +import React from 'react'; + +import { renderWithProvider } from '../../../../../test/jest'; +import SwapSuccessIcon from './swap-success-icon'; + +describe('SwapSuccessIcon', () => { + it('renders the component', () => { + const { container } = renderWithProvider(); + expect(container).toMatchSnapshot(); + }); +}); diff --git a/ui/app/pages/swaps/awaiting-swap/view-on-ether-scan-link/__snapshots__/view-on-ether-scan-link.test.js.snap b/ui/app/pages/swaps/awaiting-swap/view-on-ether-scan-link/__snapshots__/view-on-ether-scan-link.test.js.snap new file mode 100644 index 000000000000..309f67cc434b --- /dev/null +++ b/ui/app/pages/swaps/awaiting-swap/view-on-ether-scan-link/__snapshots__/view-on-ether-scan-link.test.js.snap @@ -0,0 +1,21 @@ +// Jest Snapshot v1, https://goo.gl/fbAQLP + +exports[`ViewOnEtherScanLink renders the component with a custom block explorer link 1`] = ` +
+
+ View at custom-blockchain.explorer +
+
+`; + +exports[`ViewOnEtherScanLink renders the component with initial props 1`] = ` +
+
+ View on Etherscan +
+
+`; diff --git a/ui/app/pages/swaps/awaiting-swap/view-on-ether-scan-link/view-on-ether-scan-link.test.js b/ui/app/pages/swaps/awaiting-swap/view-on-ether-scan-link/view-on-ether-scan-link.test.js new file mode 100644 index 000000000000..0eb8a4dc7b64 --- /dev/null +++ b/ui/app/pages/swaps/awaiting-swap/view-on-ether-scan-link/view-on-ether-scan-link.test.js @@ -0,0 +1,37 @@ +import React from 'react'; + +import { renderWithProvider } from '../../../../../../test/jest'; +import ViewOnEtherScanLink from '.'; + +const createProps = (customProps = {}) => { + return { + txHash: + '0x58e5a0fc7fbc849eddc100d44e86276168a8c7baaa5604e44ba6f5eb8ba1b7eb', + blockExplorerUrl: 'https://block.explorer', + isCustomBlockExplorerUrl: false, + ...customProps, + }; +}; + +describe('ViewOnEtherScanLink', () => { + it('renders the component with initial props', () => { + const { container, getByText } = renderWithProvider( + , + ); + expect(getByText('View on Etherscan')).toBeInTheDocument(); + expect(container).toMatchSnapshot(); + }); + + it('renders the component with a custom block explorer link', () => { + const { container, getByText } = renderWithProvider( + , + ); + expect(getByText('View at custom-blockchain.explorer')).toBeInTheDocument(); + expect(container).toMatchSnapshot(); + }); +}); diff --git a/ui/app/pages/swaps/build-quote/__snapshots__/build-quote.test.js.snap b/ui/app/pages/swaps/build-quote/__snapshots__/build-quote.test.js.snap new file mode 100644 index 000000000000..c6f8bda5ea00 --- /dev/null +++ b/ui/app/pages/swaps/build-quote/__snapshots__/build-quote.test.js.snap @@ -0,0 +1,66 @@ +// Jest Snapshot v1, https://goo.gl/fbAQLP + +exports[`BuildQuote renders the component with initial props 1`] = ` +
+ + + +
+`; + +exports[`BuildQuote renders the component with initial props 2`] = ` + +`; diff --git a/ui/app/pages/swaps/build-quote/build-quote.test.js b/ui/app/pages/swaps/build-quote/build-quote.test.js new file mode 100644 index 000000000000..d27990687fe2 --- /dev/null +++ b/ui/app/pages/swaps/build-quote/build-quote.test.js @@ -0,0 +1,47 @@ +import React from 'react'; +import configureMockStore from 'redux-mock-store'; +import thunk from 'redux-thunk'; + +import { + renderWithProvider, + createSwapsMockStore, + setBackgroundConnection, +} from '../../../../../test/jest'; +import BuildQuote from '.'; + +const middleware = [thunk]; +const createProps = (customProps = {}) => { + return { + inputValue: '5', + onInputChange: jest.fn(), + ethBalance: '6 ETH', + setMaxSlippage: jest.fn(), + maxSlippage: 15, + selectedAccountAddress: 'selectedAccountAddress', + isFeatureFlagLoaded: false, + ...customProps, + }; +}; + +setBackgroundConnection({ + resetPostFetchState: jest.fn(), +}); + +describe('BuildQuote', () => { + it('renders the component with initial props', () => { + const store = configureMockStore(middleware)(createSwapsMockStore()); + const props = createProps(); + const { getByText } = renderWithProvider(, store); + expect(getByText('Swap from')).toBeInTheDocument(); + expect(getByText('Swap to')).toBeInTheDocument(); + expect(getByText('ETH')).toBeInTheDocument(); + expect(getByText('Slippage Tolerance')).toBeInTheDocument(); + expect(getByText('2%')).toBeInTheDocument(); + expect(getByText('3%')).toBeInTheDocument(); + expect(getByText('Review Swap')).toBeInTheDocument(); + expect( + document.querySelector('.slippage-buttons__button-group'), + ).toMatchSnapshot(); + expect(document.querySelector('.swaps-footer')).toMatchSnapshot(); + }); +}); diff --git a/ui/app/pages/swaps/fee-card/pig-icon.test.js b/ui/app/pages/swaps/fee-card/pig-icon.test.js new file mode 100644 index 000000000000..7764681b8d4a --- /dev/null +++ b/ui/app/pages/swaps/fee-card/pig-icon.test.js @@ -0,0 +1,11 @@ +import React from 'react'; + +import { renderWithProvider } from '../../../../../test/jest'; +import PigIcon from './pig-icon'; + +describe('PigIcon', () => { + it('renders the component', () => { + const { container } = renderWithProvider(); + expect(container.firstChild.nodeName).toBe('svg'); + }); +}); diff --git a/ui/app/pages/swaps/index.test.js b/ui/app/pages/swaps/index.test.js new file mode 100644 index 000000000000..fc47e01bf2a0 --- /dev/null +++ b/ui/app/pages/swaps/index.test.js @@ -0,0 +1,63 @@ +import React from 'react'; +import configureMockStore from 'redux-mock-store'; +import thunk from 'redux-thunk'; +import nock from 'nock'; +import { waitFor } from '@testing-library/react'; + +import { + renderWithProvider, + createSwapsMockStore, + setBackgroundConnection, + MOCKS, + CONSTANTS, +} from '../../../../test/jest'; +import Swap from '.'; + +const middleware = [thunk]; + +setBackgroundConnection({ + resetPostFetchState: jest.fn(), + resetSwapsState: jest.fn(), + setSwapsLiveness: jest.fn(() => true), + setSwapsTokens: jest.fn(), + setSwapsTxGasPrice: jest.fn(), +}); + +describe('Swap', () => { + let tokensNock; + + beforeEach(() => { + nock(CONSTANTS.METASWAP_BASE_URL) + .get('/topAssets') + .reply(200, MOCKS.TOP_ASSETS_GET_RESPONSE); + + nock(CONSTANTS.METASWAP_BASE_URL) + .get('/refreshTime') + .reply(200, MOCKS.REFRESH_TIME_GET_RESPONSE); + + nock(CONSTANTS.METASWAP_BASE_URL) + .get('/aggregatorMetadata') + .reply(200, MOCKS.AGGREGATOR_METADATA_GET_RESPONSE); + + nock(CONSTANTS.METASWAP_BASE_URL) + .get('/gasPrices') + .reply(200, MOCKS.GAS_PRICES_GET_RESPONSE); + + tokensNock = nock(CONSTANTS.METASWAP_BASE_URL) + .get('/tokens') + .reply(200, MOCKS.TOKENS_GET_RESPONSE); + }); + + afterAll(() => { + nock.cleanAll(); + }); + + it('renders the component with initial props', async () => { + const store = configureMockStore(middleware)(createSwapsMockStore()); + const { container, getByText } = renderWithProvider(, store); + await waitFor(() => expect(tokensNock.isDone()).toBe(true)); + expect(getByText('Swap')).toBeInTheDocument(); + expect(getByText('Cancel')).toBeInTheDocument(); + expect(container).toMatchSnapshot(); + }); +}); diff --git a/ui/app/pages/swaps/loading-swaps-quotes/__snapshots__/aggregator-logo.test.js.snap b/ui/app/pages/swaps/loading-swaps-quotes/__snapshots__/aggregator-logo.test.js.snap new file mode 100644 index 000000000000..f2063ca4d448 --- /dev/null +++ b/ui/app/pages/swaps/loading-swaps-quotes/__snapshots__/aggregator-logo.test.js.snap @@ -0,0 +1,18 @@ +// Jest Snapshot v1, https://goo.gl/fbAQLP + +exports[`AggregatorLogo renders the component with initial props 1`] = ` +
+ +
+`; diff --git a/ui/app/pages/swaps/loading-swaps-quotes/__snapshots__/loading-swaps-quotes-stories-metadata.test.js.snap b/ui/app/pages/swaps/loading-swaps-quotes/__snapshots__/loading-swaps-quotes-stories-metadata.test.js.snap new file mode 100644 index 000000000000..cbb28155e807 --- /dev/null +++ b/ui/app/pages/swaps/loading-swaps-quotes/__snapshots__/loading-swaps-quotes-stories-metadata.test.js.snap @@ -0,0 +1,30 @@ +// Jest Snapshot v1, https://goo.gl/fbAQLP + +exports[`storiesMetadata matches expected values for storiesMetadata 1`] = ` +Object { + "airswap": Object { + "color": "#2B71FF", + "icon": "", + }, + "dexag": Object { + "color": "#13171F", + "icon": "", + }, + "oneInch": Object { + "color": "#323232", + "icon": "", + }, + "paraswap": Object { + "color": "#0058D4", + "icon": "", + }, + "totle": Object { + "color": "#283B4C", + "icon": "", + }, + "zeroExV1": Object { + "color": "#000", + "icon": "", + }, +} +`; diff --git a/ui/app/pages/swaps/loading-swaps-quotes/aggregator-logo.test.js b/ui/app/pages/swaps/loading-swaps-quotes/aggregator-logo.test.js new file mode 100644 index 000000000000..fb81e33e63ce --- /dev/null +++ b/ui/app/pages/swaps/loading-swaps-quotes/aggregator-logo.test.js @@ -0,0 +1,22 @@ +import React from 'react'; + +import { renderWithProvider } from '../../../../../test/jest'; +import AggregatorLogo from './aggregator-logo'; + +const createProps = (customProps = {}) => { + return { + color: '#000', + icon: + '', + ...customProps, + }; +}; + +describe('AggregatorLogo', () => { + it('renders the component with initial props', () => { + const { container } = renderWithProvider( + , + ); + expect(container).toMatchSnapshot(); + }); +}); diff --git a/ui/app/pages/swaps/loading-swaps-quotes/background-animation.test.js b/ui/app/pages/swaps/loading-swaps-quotes/background-animation.test.js new file mode 100644 index 000000000000..64e31843ecc6 --- /dev/null +++ b/ui/app/pages/swaps/loading-swaps-quotes/background-animation.test.js @@ -0,0 +1,12 @@ +import React from 'react'; + +import { renderWithProvider } from '../../../../../test/jest'; +import BackgroundAnimation from './background-animation'; + +describe('BackgroundAnimation', () => { + it('renders the component', () => { + const { container } = renderWithProvider(); + expect(container.firstChild.nodeName).toBe('DIV'); + expect(container.firstChild.firstChild.nodeName).toBe('svg'); + }); +}); diff --git a/ui/app/pages/swaps/loading-swaps-quotes/loading-swaps-quotes-stories-metadata.test.js b/ui/app/pages/swaps/loading-swaps-quotes/loading-swaps-quotes-stories-metadata.test.js new file mode 100644 index 000000000000..8d119cc9a188 --- /dev/null +++ b/ui/app/pages/swaps/loading-swaps-quotes/loading-swaps-quotes-stories-metadata.test.js @@ -0,0 +1,7 @@ +import { storiesMetadata } from './loading-swaps-quotes-stories-metadata'; + +describe('storiesMetadata', () => { + it('matches expected values for storiesMetadata', () => { + expect(storiesMetadata).toMatchSnapshot(); + }); +}); diff --git a/ui/app/pages/swaps/main-quote-summary/__snapshots__/quote-backdrop.test.js.snap b/ui/app/pages/swaps/main-quote-summary/__snapshots__/quote-backdrop.test.js.snap new file mode 100644 index 000000000000..2a1fef0ff0ac --- /dev/null +++ b/ui/app/pages/swaps/main-quote-summary/__snapshots__/quote-backdrop.test.js.snap @@ -0,0 +1,74 @@ +// Jest Snapshot v1, https://goo.gl/fbAQLP + +exports[`QuotesBackdrop renders the component with initial props 1`] = ` + + + +`; + +exports[`QuotesBackdrop renders the component with initial props 2`] = ` + + + + + + + + + +`; + +exports[`QuotesBackdrop renders the component with initial props 3`] = ` + + + + +`; diff --git a/ui/app/pages/swaps/main-quote-summary/quote-backdrop.test.js b/ui/app/pages/swaps/main-quote-summary/quote-backdrop.test.js new file mode 100644 index 000000000000..caab811ca5a3 --- /dev/null +++ b/ui/app/pages/swaps/main-quote-summary/quote-backdrop.test.js @@ -0,0 +1,23 @@ +import React from 'react'; + +import { renderWithProvider } from '../../../../../test/jest'; +import QuotesBackdrop from './quote-backdrop'; + +const createProps = (customProps = {}) => { + return { + withTopTab: false, + ...customProps, + }; +}; + +describe('QuotesBackdrop', () => { + it('renders the component with initial props', () => { + const { container } = renderWithProvider( + , + ); + expect(container.firstChild.nodeName).toBe('svg'); + expect(document.querySelector('g')).toMatchSnapshot(); + expect(document.querySelector('filter')).toMatchSnapshot(); + expect(document.querySelector('linearGradient')).toMatchSnapshot(); + }); +}); diff --git a/ui/app/pages/swaps/select-quote-popover/mock-quote-data.test.js b/ui/app/pages/swaps/select-quote-popover/mock-quote-data.test.js new file mode 100644 index 000000000000..ebe761581ea2 --- /dev/null +++ b/ui/app/pages/swaps/select-quote-popover/mock-quote-data.test.js @@ -0,0 +1,18 @@ +import quoteDataRows from './mock-quote-data'; + +describe('quoteDataRows', () => { + it('matches expected values for quoteDataRows', () => { + expect(quoteDataRows[0].aggId).toBe('Agg1'); + expect(quoteDataRows[0].amountReceiving).toBe('100 DAI'); + expect(quoteDataRows[1].aggId).toBe('Agg2'); + expect(quoteDataRows[1].amountReceiving).toBe('101 DAI'); + expect(quoteDataRows[2].aggId).toBe('Agg3'); + expect(quoteDataRows[2].amountReceiving).toBe('102 DAI'); + expect(quoteDataRows[3].aggId).toBe('Agg4'); + expect(quoteDataRows[3].amountReceiving).toBe('150 DAI'); + expect(quoteDataRows[4].aggId).toBe('Agg5'); + expect(quoteDataRows[4].amountReceiving).toBe('104 DAI'); + expect(quoteDataRows[5].aggId).toBe('Agg6'); + expect(quoteDataRows[5].amountReceiving).toBe('105 DAI'); + }); +}); diff --git a/ui/app/pages/swaps/select-quote-popover/sort-list/__snapshots__/sort-list.test.js.snap b/ui/app/pages/swaps/select-quote-popover/sort-list/__snapshots__/sort-list.test.js.snap new file mode 100644 index 000000000000..a267c11f354b --- /dev/null +++ b/ui/app/pages/swaps/select-quote-popover/sort-list/__snapshots__/sort-list.test.js.snap @@ -0,0 +1,139 @@ +// Jest Snapshot v1, https://goo.gl/fbAQLP + +exports[`SortList renders the component with initial props 1`] = ` +
+ + WETH + +
+ + Receiving + +
+
+
+ +
+
+
+ + + +
+
+`; + +exports[`SortList renders the component with initial props 2`] = ` +
+ + Estimated network fees + +
+
+
+ +
+
+
+ + + +
+`; + +exports[`SortList renders the component with initial props 3`] = ` +
+
+
+
+ 101000000000000000000 +
+
+ + 0% Slippage + +
+
+ $14.26 +
+
+
+ RFQ +
+
+
+ +
+
+`; diff --git a/ui/app/pages/swaps/select-quote-popover/sort-list/sort-list.test.js b/ui/app/pages/swaps/select-quote-popover/sort-list/sort-list.test.js new file mode 100644 index 000000000000..57896b8e042a --- /dev/null +++ b/ui/app/pages/swaps/select-quote-popover/sort-list/sort-list.test.js @@ -0,0 +1,83 @@ +import React from 'react'; + +import { renderWithProvider } from '../../../../../../test/jest'; +import SortList from './sort-list'; + +const createProps = (customProps = {}) => { + return { + selectedAggId: 'Agg2', + onSelect: jest.fn(), + onCaretClick: jest.fn(), + swapToSymbol: 'WETH', + quoteDataRows: [ + { + aggId: 'Agg1', + amountReceiving: '100 DAI', + destinationTokenDecimals: 18, + destinationTokenSymbol: 'DAI', + destinationTokenValue: '100000000000000000000', + isBestQuote: false, + networkFees: '$15.25', + quoteSource: 'AGG', + rawNetworkFees: '10.25', + slippage: 3, + sourceTokenDecimals: 18, + sourceTokenSymbol: 'ETH', + sourceTokenValue: '250000000000000000', + }, + { + aggId: 'Agg2', + amountReceiving: '101 DAI', + destinationTokenDecimals: 18, + destinationTokenSymbol: 'DAI', + destinationTokenValue: '101000000000000000000', + isBestQuote: false, + networkFees: '$14.26', + quoteSource: 'RFQ', + rawNetworkFees: '10.26', + slippage: 3, + sourceTokenDecimals: 18, + sourceTokenSymbol: 'ETH', + sourceTokenValue: '250000000000000000', + }, + { + aggId: 'Agg3', + amountReceiving: '102 DAI', + destinationTokenDecimals: 18, + destinationTokenSymbol: 'DAI', + destinationTokenValue: '102000000000000000000', + isBestQuote: false, + networkFees: '$13.27', + quoteSource: 'DEX', + rawNetworkFees: '10.27', + slippage: 3, + sourceTokenDecimals: 18, + sourceTokenSymbol: 'ETH', + sourceTokenValue: '250000000000000000', + }, + ], + sortDirection: 1, + setSortDirection: jest.fn(), + sortColumn: 'slippage', + setSortColumn: jest.fn(), + ...customProps, + }; +}; + +describe('SortList', () => { + it('renders the component with initial props', () => { + const { getByText } = renderWithProvider(); + expect(getByText('$15.25')).toBeInTheDocument(); + expect(getByText('$14.26')).toBeInTheDocument(); + expect(getByText('$13.27')).toBeInTheDocument(); + expect( + document.querySelector('.select-quote-popover__receiving'), + ).toMatchSnapshot(); + expect( + document.querySelector('.select-quote-popover__network-fees-header'), + ).toMatchSnapshot(); + expect( + document.querySelector('.select-quote-popover__row--selected'), + ).toMatchSnapshot(); + }); +});