import React from 'react'; import sinon from 'sinon'; import configureMockStore from 'redux-mock-store'; import { fireEvent, screen } from '@testing-library/react'; import { renderWithProvider } from '../../../../test/lib/render-helpers'; import { HardwareKeyringTypes } from '../../../../shared/constants/hardware-wallets'; import AccountMenu from '.'; describe('Account Menu', () => { const mockStore = { metamask: { provider: { type: 'test', }, preferences: { useNativeCurrencyAsPrimaryCurrency: true, }, }, }; const store = configureMockStore()(mockStore); const props = { isAccountMenuOpen: true, addressConnectedSubjectMap: {}, accounts: [ { address: '0x00', name: 'Account 1', balance: '0x0', }, { address: '0x1', name: 'Imported Account 1', balance: '0x0', }, ], keyrings: [ { type: HardwareKeyringTypes.hdKeyTree, accounts: ['0xAdress'], }, { type: HardwareKeyringTypes.imported, accounts: ['0x1'], }, ], prevIsAccountMenuOpen: false, lockMetamask: sinon.spy(), showAccountDetail: sinon.spy(), showRemoveAccountConfirmationModal: sinon.spy(), toggleAccountMenu: sinon.spy(), history: { push: sinon.spy(), }, }; beforeEach(() => { renderWithProvider(, store); }); afterEach(() => { props.toggleAccountMenu.resetHistory(); props.history.push.resetHistory(); }); describe('Render Content', () => { it('returns account name from identities', () => { const accountName = screen.queryAllByTestId('account-menu__account'); expect(accountName).toHaveLength(2); }); it('renders user preference currency display balance from account balance', () => { const accountBalance = screen.queryAllByTestId('account-menu__balance'); expect(accountBalance).toHaveLength(2); }); it('simulate click', () => { const click = screen.getAllByTestId('account-menu__account'); fireEvent.click(click[0]); expect(props.showAccountDetail.calledOnce).toStrictEqual(true); expect(props.showAccountDetail.getCall(0).args[0]).toStrictEqual('0x00'); }); it('render imported account label', () => { const importedAccount = screen.getByText('Imported'); expect(importedAccount).toBeInTheDocument(); }); }); describe('Log Out', () => { it('logout', () => { const logout = screen.getByText('Lock'); expect(logout).toBeInTheDocument(); }); it('simulate click', () => { const logout = screen.getByText('Lock'); fireEvent.click(logout); expect(props.lockMetamask.calledOnce).toStrictEqual(true); expect(props.history.push.getCall(0).args[0]).toStrictEqual('/'); }); }); describe('Create Account', () => { it('renders create account item', () => { const createAccount = screen.getByText('Create account'); expect(createAccount).toBeInTheDocument(); }); it('calls toggle menu and push new-account route to history', () => { const createAccount = screen.getByText('Create account'); fireEvent.click(createAccount); expect(props.toggleAccountMenu.calledOnce).toStrictEqual(true); expect(props.history.push.getCall(0).args[0]).toStrictEqual( '/new-account', ); }); }); describe('Import Account', () => { it('renders import account item', () => { const importAccount = screen.getByText('Import account'); expect(importAccount).toBeInTheDocument(); }); it('calls toggle menu and push /new-account/import route to history', () => { const importAccount = screen.getByText('Import account'); fireEvent.click(importAccount); expect(props.toggleAccountMenu.calledOnce).toStrictEqual(true); expect(props.history.push.getCall(0).args[0]).toStrictEqual( '/new-account/import', ); }); }); describe('Connect hardware wallet', () => { it('renders import account item', () => { const connectHardwareWallet = screen.getByText('Connect hardware wallet'); expect(connectHardwareWallet).toBeInTheDocument(); }); it('calls toggle menu and push /new-account/connect route to history', () => { const connectHardwareWallet = screen.getByText('Connect hardware wallet'); fireEvent.click(connectHardwareWallet); expect(props.toggleAccountMenu.calledOnce).toStrictEqual(true); expect(props.history.push.getCall(0).args[0]).toStrictEqual( '/new-account/connect', ); }); }); describe('Support', () => { global.platform = { openTab: sinon.spy() }; it('renders import account item', () => { const support = screen.getByText('Submit a ticket'); expect(support).toBeInTheDocument(); }); it('opens support link when clicked', () => { const support = screen.getByText('Submit a ticket'); fireEvent.click(support); expect(global.platform.openTab.calledOnce).toStrictEqual(true); }); }); describe('Settings', () => { it('renders import account item', () => { const settings = screen.getByText('Settings'); expect(settings).toBeInTheDocument(); }); it('calls toggle menu and push /new-account/connect route to history', () => { const settings = screen.getByText('Settings'); fireEvent.click(settings); expect(props.toggleAccountMenu.calledOnce).toStrictEqual(true); expect(props.history.push.getCall(0).args[0]).toStrictEqual('/settings'); }); }); });