You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
182 lines
5.4 KiB
182 lines
5.4 KiB
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 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: 'HD Key Tree',
|
|
accounts: ['0xAdress'],
|
|
},
|
|
{
|
|
type: 'Simple Key Pair',
|
|
accounts: ['0x1'],
|
|
},
|
|
],
|
|
prevIsAccountMenuOpen: false,
|
|
lockMetamask: sinon.spy(),
|
|
showAccountDetail: sinon.spy(),
|
|
showRemoveAccountConfirmationModal: sinon.spy(),
|
|
toggleAccountMenu: sinon.spy(),
|
|
history: {
|
|
push: sinon.spy(),
|
|
},
|
|
};
|
|
|
|
beforeEach(() => {
|
|
renderWithProvider(<AccountMenu.WrappedComponent {...props} />, 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');
|
|
});
|
|
});
|
|
});
|
|
|