2023-11-16 10:16:16 +00:00
|
|
|
import { fireEvent, render } from '@testing-library/react'
|
2023-05-30 07:01:07 +00:00
|
|
|
import BigNumber from 'bignumber.js'
|
2023-05-31 08:34:26 +00:00
|
|
|
|
2023-05-30 07:01:07 +00:00
|
|
|
import TokenInput from 'components/TokenInput'
|
|
|
|
import { ASSETS } from 'constants/assets'
|
|
|
|
|
2023-06-05 06:47:42 +00:00
|
|
|
jest.mock('components/DisplayCurrency', () => {
|
|
|
|
return {
|
|
|
|
__esModule: true,
|
|
|
|
default: (props: any) =>
|
|
|
|
require('utils/testing').createMockComponent('mock-display-currency-component', props),
|
|
|
|
}
|
|
|
|
})
|
|
|
|
|
2023-05-30 07:01:07 +00:00
|
|
|
describe('<TokenInput />', () => {
|
|
|
|
const asset = ASSETS[0]
|
|
|
|
const defaultProps = {
|
|
|
|
amount: new BigNumber(1),
|
|
|
|
asset,
|
|
|
|
max: new BigNumber(100),
|
|
|
|
onChangeAsset: jest.fn(),
|
|
|
|
onChange: jest.fn(),
|
|
|
|
}
|
|
|
|
|
2023-06-05 06:47:42 +00:00
|
|
|
afterAll(() => {
|
|
|
|
jest.unmock('components/DisplayCurrency')
|
|
|
|
})
|
|
|
|
|
2023-05-30 07:01:07 +00:00
|
|
|
it('should render', () => {
|
2023-11-16 10:16:16 +00:00
|
|
|
const { container } = render(<TokenInput warningMessages={[]} {...defaultProps} />)
|
2023-05-30 07:01:07 +00:00
|
|
|
expect(container).toBeInTheDocument()
|
|
|
|
})
|
|
|
|
|
|
|
|
it('should handle `className` prop correctly', () => {
|
|
|
|
const testClass = 'test-class'
|
2023-11-16 10:16:16 +00:00
|
|
|
const { getByTestId } = render(
|
|
|
|
<TokenInput warningMessages={[]} {...defaultProps} className={testClass} />,
|
|
|
|
)
|
2023-05-30 07:01:07 +00:00
|
|
|
expect(getByTestId('token-input-component')).toHaveClass(testClass)
|
|
|
|
})
|
|
|
|
|
|
|
|
it('should handle `disabled` prop correctly', () => {
|
2023-11-16 10:16:16 +00:00
|
|
|
const { getByTestId } = render(
|
|
|
|
<TokenInput warningMessages={[]} {...defaultProps} disabled={true} />,
|
|
|
|
)
|
2023-06-05 06:47:42 +00:00
|
|
|
expect(getByTestId('token-input-component')).toHaveClass('pointer-events-none', 'opacity-50')
|
2023-05-30 07:01:07 +00:00
|
|
|
})
|
|
|
|
|
|
|
|
it('should handle `maxText` prop correctly', () => {
|
2023-11-16 10:16:16 +00:00
|
|
|
const { getByTestId } = render(
|
|
|
|
<TokenInput warningMessages={[]} {...defaultProps} maxText='Max' />,
|
|
|
|
)
|
2023-05-30 07:01:07 +00:00
|
|
|
expect(getByTestId('token-input-max-button')).toBeInTheDocument()
|
|
|
|
})
|
|
|
|
|
|
|
|
describe('should render the max button', () => {
|
|
|
|
it('when `maxText` prop is defined', () => {
|
2023-11-16 10:16:16 +00:00
|
|
|
const { getByTestId } = render(
|
|
|
|
<TokenInput warningMessages={[]} {...defaultProps} maxText='Max' />,
|
|
|
|
)
|
2023-05-30 07:01:07 +00:00
|
|
|
expect(getByTestId('token-input-max-button')).toBeInTheDocument()
|
|
|
|
})
|
|
|
|
it('not when `maxText` prop is undefined', () => {
|
2023-11-16 10:16:16 +00:00
|
|
|
const { queryByTestId } = render(<TokenInput warningMessages={[]} {...defaultProps} />)
|
2023-05-30 07:01:07 +00:00
|
|
|
expect(queryByTestId('token-input-max-button')).not.toBeInTheDocument()
|
|
|
|
})
|
|
|
|
})
|
|
|
|
|
|
|
|
describe('should render <Select />', () => {
|
|
|
|
it('when `hasSelect` prop is true and balances is defined', () => {
|
2023-11-16 10:16:16 +00:00
|
|
|
const { getByTestId } = render(
|
|
|
|
<TokenInput warningMessages={[]} {...defaultProps} balances={[]} hasSelect />,
|
|
|
|
)
|
2023-05-30 07:01:07 +00:00
|
|
|
expect(getByTestId('select-component')).toBeInTheDocument()
|
|
|
|
})
|
|
|
|
it('not when `hasSelect` prop is true and balances is not defined', () => {
|
2023-11-16 10:16:16 +00:00
|
|
|
const { queryByTestId } = render(
|
|
|
|
<TokenInput warningMessages={[]} {...defaultProps} hasSelect />,
|
|
|
|
)
|
2023-05-30 07:01:07 +00:00
|
|
|
expect(queryByTestId('select-component')).not.toBeInTheDocument()
|
|
|
|
})
|
|
|
|
it('not when `hasSelect` prop is false and balances is defined', () => {
|
2023-11-16 10:16:16 +00:00
|
|
|
const { queryByTestId } = render(
|
|
|
|
<TokenInput warningMessages={[]} {...defaultProps} balances={[]} />,
|
|
|
|
)
|
2023-05-30 07:01:07 +00:00
|
|
|
expect(queryByTestId('select-component')).not.toBeInTheDocument()
|
|
|
|
})
|
|
|
|
})
|
|
|
|
|
|
|
|
it('should call onMaxBtnClick when the user clicks on max button', () => {
|
2023-11-16 10:16:16 +00:00
|
|
|
const { getByTestId } = render(
|
|
|
|
<TokenInput warningMessages={[]} {...defaultProps} maxText='max' />,
|
|
|
|
)
|
2023-05-30 07:01:07 +00:00
|
|
|
const maxBtn = getByTestId('token-input-max-button')
|
|
|
|
fireEvent.click(maxBtn)
|
|
|
|
expect(defaultProps.onChange).toBeCalledWith(defaultProps.max)
|
|
|
|
})
|
|
|
|
})
|