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-menu/network-list-menu.test.js

134 lines
4.3 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, renderWithProvider } from '../../../../test/jest';
import configureStore from '../../../store/store';
import mockState from '../../../../test/data/mock-state.json';
import {
CHAIN_IDS,
2023-03-31 19:58:25 +02:00
MAINNET_DISPLAY_NAME,
SEPOLIA_DISPLAY_NAME,
} from '../../../../shared/constants/network';
import { NetworkListMenu } from '.';
const mockSetShowTestNetworks = jest.fn();
const mockSetProviderType = jest.fn();
const mockToggleNetworkMenu = jest.fn();
2023-03-31 19:58:25 +02:00
jest.mock('../../../store/actions.ts', () => ({
setShowTestNetworks: () => mockSetShowTestNetworks,
setProviderType: () => mockSetProviderType,
toggleNetworkMenu: () => mockToggleNetworkMenu,
2023-03-31 19:58:25 +02:00
}));
const render = (
showTestNetworks = false,
currentChainId = '0x5',
providerConfigId = 'chain5',
isUnlocked = true,
) => {
const state = {
2023-03-31 19:58:25 +02:00
metamask: {
...mockState.metamask,
isUnlocked,
providerConfig: {
...mockState.metamask.providerConfig,
chainId: currentChainId,
id: providerConfigId,
},
2023-03-31 19:58:25 +02:00
preferences: {
showTestNetworks,
},
},
};
const store = configureStore(state);
return renderWithProvider(<NetworkListMenu onClose={jest.fn()} />, store);
2023-03-31 19:58:25 +02:00
};
describe('NetworkListMenu', () => {
it('displays important controls', () => {
const { getByText, getByPlaceholderText } = render();
2023-03-31 19:58:25 +02:00
expect(getByText('Add network')).toBeInTheDocument();
expect(getByText('Show test networks')).toBeInTheDocument();
expect(getByPlaceholderText('Search')).toBeInTheDocument();
2023-03-31 19:58:25 +02:00
});
it('renders mainnet item', () => {
const { getByText } = render();
expect(getByText(MAINNET_DISPLAY_NAME)).toBeInTheDocument();
});
it('renders test networks when it should', () => {
const { getByText } = render(true);
expect(getByText(SEPOLIA_DISPLAY_NAME)).toBeInTheDocument();
});
it('toggles showTestNetworks when toggle is clicked', () => {
const { queryAllByRole } = render();
const [testNetworkToggle] = queryAllByRole('checkbox');
fireEvent.click(testNetworkToggle);
expect(mockSetShowTestNetworks).toHaveBeenCalled();
});
it('disables toggle when on test network', () => {
render(false, CHAIN_IDS.GOERLI);
expect(document.querySelector('.toggle-button--disabled')).toBeDefined();
});
2023-03-31 19:58:25 +02:00
it('switches networks when an item is clicked', () => {
const { getByText } = render();
fireEvent.click(getByText(MAINNET_DISPLAY_NAME));
expect(mockToggleNetworkMenu).toHaveBeenCalled();
2023-03-31 19:58:25 +02:00
expect(mockSetProviderType).toHaveBeenCalled();
});
it('shows the correct selected network when networks share the same chain ID', () => {
// Mainnet and Custom Mainnet RPC both use chain ID 0x1
render(false, '0x1', 'testNetworkConfigurationId');
// Contains Mainnet and the two custom networks
const networkItems = document.querySelectorAll(
'.multichain-network-list-item',
);
expect(networkItems).toHaveLength(3);
const selectedNodes = document.querySelectorAll(
'.multichain-network-list-item--selected',
);
expect(selectedNodes).toHaveLength(1);
const selectedNodeText = selectedNodes[0].querySelector(
'.multichain-network-list-item__network-name',
).textContent;
expect(selectedNodeText).toStrictEqual('Custom Mainnet RPC');
});
it('narrows down search results', () => {
const { queryByText, getByPlaceholderText } = render();
expect(queryByText('Chain 5')).toBeInTheDocument();
const searchBox = getByPlaceholderText('Search');
fireEvent.change(searchBox, { target: { value: 'Main' } });
expect(queryByText('Chain 5')).not.toBeInTheDocument();
});
it('disables the "Add Network" button when MetaMask is locked', () => {
const { queryByText } = render(false, '0x5', 'chain5', false);
expect(queryByText('Add network')).toBeDisabled();
});
it('enables the "Add Network" button when MetaMask is true', () => {
const { queryByText } = render(false, '0x5', 'chain5', true);
expect(queryByText('Add network')).toBeEnabled();
});
it('does not allow deleting networks when locked', () => {
render(false, '0x5', 'chain5', false);
expect(
document.querySelectorAll('multichain-network-list-item__delete'),
).toHaveLength(0);
});
2023-03-31 19:58:25 +02:00
});