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/global-menu/global-menu.test.js
David Walsh cd68bf9d09
UX: Remove portfolio from global menu (#20221)
* UX: Remove portfolio from global menu

* Remove unused locale string

* Code-fence the metaMetricsId
2023-07-27 09:35:27 -07:00

86 lines
2.7 KiB
JavaScript

import React from 'react';
import { renderWithProvider, fireEvent, waitFor } from '../../../../test/jest';
import configureStore from '../../../store/store';
import mockState from '../../../../test/data/mock-state.json';
import { GlobalMenu } from '.';
const render = (metamaskStateChanges = {}) => {
const store = configureStore({
metamask: {
...mockState.metamask,
...metamaskStateChanges,
},
});
return renderWithProvider(
<GlobalMenu anchorElement={document.body} closeMenu={() => undefined} />,
store,
);
};
const mockLockMetaMask = jest.fn();
const mockSetAccountDetailsAddress = jest.fn();
jest.mock('../../../store/actions', () => ({
lockMetamask: () => mockLockMetaMask,
setAccountDetailsAddress: () => mockSetAccountDetailsAddress,
}));
describe('AccountListItem', () => {
it('locks MetaMask when item is clicked', async () => {
render();
fireEvent.click(document.querySelector('[data-testid="global-menu-lock"]'));
await waitFor(() => {
expect(mockLockMetaMask).toHaveBeenCalled();
});
});
it('opens the support site when item is clicked', async () => {
global.platform = { openTab: jest.fn() };
const { getByTestId } = render();
fireEvent.click(getByTestId('global-menu-support'));
await waitFor(() => {
expect(global.platform.openTab).toHaveBeenCalled();
});
});
it('disables the settings item when there is an active transaction', async () => {
const { getByTestId } = render();
await waitFor(() => {
expect(getByTestId('global-menu-settings')).toBeDisabled();
});
});
it('enables the settings item when there is no active transaction', async () => {
const { getByTestId } = render({ unapprovedTxs: {} });
await waitFor(() => {
expect(getByTestId('global-menu-settings')).toBeEnabled();
});
});
it('disables the connected sites item when there is an active transaction', async () => {
const { getByTestId } = render();
await waitFor(() => {
expect(getByTestId('global-menu-connected-sites')).toBeDisabled();
});
});
it('enables the connected sites item when there is no active transaction', async () => {
const { getByTestId } = render({ unapprovedTxs: {} });
await waitFor(() => {
expect(getByTestId('global-menu-connected-sites')).toBeEnabled();
});
});
it('expands metamask to tab when item is clicked', async () => {
global.platform = { openExtensionInBrowser: jest.fn() };
render();
fireEvent.click(
document.querySelector('[data-testid="global-menu-expand"]'),
);
await waitFor(() => {
expect(global.platform.openExtensionInBrowser).toHaveBeenCalled();
});
});
});