1
0
mirror of https://github.com/kremalicious/metamask-extension.git synced 2024-12-23 09:52:26 +01:00
metamask-extension/ui/components/multichain/network-list-item/network-list-item.test.js

82 lines
2.4 KiB
JavaScript
Raw Normal View History

2023-03-31 19:58:25 +02:00
/* eslint-disable jest/require-top-level-describe */
import React from 'react';
import { fireEvent, render } from '@testing-library/react';
import {
MATIC_TOKEN_IMAGE_URL,
POLYGON_DISPLAY_NAME,
} from '../../../../shared/constants/network';
import { NetworkListItem } from '.';
const DEFAULT_PROPS = {
name: POLYGON_DISPLAY_NAME,
iconSrc: MATIC_TOKEN_IMAGE_URL,
selected: false,
onClick: () => undefined,
onDeleteClick: () => undefined,
};
describe('NetworkListItem', () => {
it('renders properly', () => {
const { container } = render(<NetworkListItem {...DEFAULT_PROPS} />);
expect(container).toMatchSnapshot();
});
it('does not render the delete icon when no onDeleteClick is clicked', () => {
const { container } = render(
<NetworkListItem {...DEFAULT_PROPS} onDeleteClick={null} />,
);
expect(
container.querySelector('.multichain-network-list-item__delete'),
).toBeNull();
});
it('shows as selected when selected', () => {
const { container } = render(
<NetworkListItem {...DEFAULT_PROPS} selected />,
);
expect(
container.querySelector(
'.multichain-network-list-item__selected-indicator',
),
).toBeInTheDocument();
});
it('renders a tooltip when the network name is very long', () => {
const { container } = render(
<NetworkListItem
{...DEFAULT_PROPS}
name="This is a very long network name that will be truncated"
/>,
);
expect(
container.querySelector('.multichain-network-list-item__tooltip'),
).toBeInTheDocument();
});
it('executes onClick when the item is clicked', () => {
const onClick = jest.fn();
const { container } = render(
<NetworkListItem {...DEFAULT_PROPS} onClick={onClick} />,
);
fireEvent.click(container.querySelector('.multichain-network-list-item'));
expect(onClick).toHaveBeenCalled();
});
it('executes onDeleteClick when the delete button is clicked', () => {
const onDeleteClick = jest.fn();
const onClick = jest.fn();
const { container } = render(
<NetworkListItem
{...DEFAULT_PROPS}
onDeleteClick={onDeleteClick}
onClick={onClick}
/>,
);
fireEvent.click(
container.querySelector('.multichain-network-list-item__delete'),
);
expect(onDeleteClick).toHaveBeenCalledTimes(1);
expect(onClick).toHaveBeenCalledTimes(0);
});
});