uniswap-interface-uncensored/src/setupTests.ts
Mike Grabowski c07c401189
feat: add animation to Settings menu (#6617)
* feat: add price impact back

* chore: update tes tname

* chore: update snapshot for price impact

* fix

* fix

* update snapshot after rebase

* update snapshot

* chore: finish

* chore: remove snapshot

* feat: add test matcher

* cleanup

* chore: add animation test

* add comment

* update comment
2023-05-24 22:02:59 +04:00

108 lines
3.5 KiB
TypeScript

import '@testing-library/jest-dom' // jest custom assertions
import 'polyfills'
import 'jest-styled-components' // adds style diffs to snapshot tests
import 'polyfills'
import type { createPopper } from '@popperjs/core'
import { useWeb3React } from '@web3-react/core'
import failOnConsole from 'jest-fail-on-console'
import { Readable } from 'stream'
import { toBeVisible } from 'test-utils/matchers'
import { mocked } from 'test-utils/mocked'
import { TextDecoder, TextEncoder } from 'util'
window.open = jest.fn()
window.getComputedStyle = jest.fn()
if (typeof global.TextEncoder === 'undefined') {
global.ReadableStream = Readable as unknown as typeof globalThis.ReadableStream
global.TextEncoder = TextEncoder
global.TextDecoder = TextDecoder as typeof global.TextDecoder
}
// Sets origin to the production origin, because some tests depend on this.
// This prevents each test file from needing to set this manually.
global.origin = 'https://app.uniswap.org'
global.matchMedia =
global.matchMedia ||
(() => {
return {
matches: false,
addEventListener: jest.fn(),
removeEventListener: jest.fn(),
}
})
jest.mock('@popperjs/core', () => {
const core = jest.requireActual('@popperjs/core')
return {
...core,
createPopper: (...args: Parameters<typeof createPopper>) => {
const [referenceElement, popperElement, options = {}] = args
// Prevent popper from making state updates asynchronously.
// This is necessary to avoid warnings during tests, as popper will asynchronously update state outside of test setup.
options?.modifiers?.push({
name: 'synchronousUpdate',
enabled: true,
phase: 'beforeMain',
effect: (state) => {
state.instance.update = () => {
state.instance.forceUpdate()
return Promise.resolve(state.instance.state)
}
},
})
return core.createPopper(referenceElement, popperElement, options)
},
}
})
jest.mock('@web3-react/core', () => {
const web3React = jest.requireActual('@web3-react/core')
const { Empty } = jest.requireActual('@web3-react/empty')
return {
...web3React,
initializeConnector: () =>
web3React.initializeConnector(
(actions: Parameters<typeof web3React.initializeConnector>[0]) => new Empty(actions)
),
useWeb3React: jest.fn(),
}
})
// Mocks are configured to reset between tests (by CRA), so they must be set in a beforeEach.
beforeEach(() => {
// Mock window.getComputedStyle, because it is otherwise too computationally expensive to unit test.
// Not mocking this results in multi-second tests when using popper.js.
mocked(window.getComputedStyle).mockImplementation(() => new CSSStyleDeclaration())
// Mock useWeb3React to return a chainId of 1 by default.
mocked(useWeb3React).mockReturnValue({ chainId: 1 } as ReturnType<typeof useWeb3React>)
})
/**
* Fail tests if anything is logged to the console. This keeps the console clean and ensures test output stays readable.
* If something should log to the console, it should be stubbed and asserted:
* @example
* beforeEach(() => jest.spyOn(console, 'error').mockReturnsValue())
* it('should log an error', () => {
* example()
* expect(console.error).toHaveBeenCalledWith(expect.any(Error))
* })
*/
failOnConsole({
shouldFailOnAssert: true,
shouldFailOnDebug: true,
shouldFailOnError: true,
shouldFailOnInfo: true,
shouldFailOnLog: true,
shouldFailOnWarn: true,
})
expect.extend({
toBeVisible,
})