mirror of
https://github.com/kremalicious/metamask-extension.git
synced 2024-12-23 09:52:26 +01:00
b5ece42ca1
* Sending showCustodyConfirmLink as a prop and fixing other issues * Upgraded MMI extension monrepo and trying to fix the issue * prevents deeplink from closing * Fixed styles of Custody view and changed the place of it * Fixed CI issues * fixing eslint issues * Update LavaMoat policies * fixing tests * Fixed test * updated snapshots * reorder, otherwise it won't make sense * adds necessary methods * removes duplicated key value * updated snapshot --------- Co-authored-by: Antonio Regadas <antonio.regadas@consensys.net> Co-authored-by: MetaMask Bot <metamaskbot@users.noreply.github.com> Co-authored-by: António Regadas <apregadas@gmail.com>
137 lines
3.6 KiB
JavaScript
137 lines
3.6 KiB
JavaScript
import React from 'react';
|
|
import { screen, fireEvent } from '@testing-library/react';
|
|
import configureMockStore from 'redux-mock-store';
|
|
import { renderWithProvider } from '../../../../test/lib/render-helpers';
|
|
import ConfirmAddCustodianToken from './confirm-add-custodian-token';
|
|
|
|
const mockedRemoveAddTokenConnectRequest = jest
|
|
.fn()
|
|
.mockReturnValue({ type: 'TYPE' });
|
|
|
|
jest.mock('../../../store/institutional/institution-background', () => ({
|
|
mmiActionsFactory: () => ({
|
|
removeAddTokenConnectRequest: mockedRemoveAddTokenConnectRequest,
|
|
}),
|
|
}));
|
|
|
|
describe('Confirm Add Custodian Token', () => {
|
|
const mockStore = {
|
|
metamask: {
|
|
providerConfig: {
|
|
type: 'test',
|
|
},
|
|
preferences: {
|
|
useNativeCurrencyAsPrimaryCurrency: true,
|
|
},
|
|
institutionalFeatures: {
|
|
complianceProjectId: '',
|
|
connectRequests: [
|
|
{
|
|
labels: [
|
|
{
|
|
key: 'service',
|
|
value: 'test',
|
|
},
|
|
],
|
|
origin: 'origin',
|
|
token: 'testToken',
|
|
feature: 'custodian',
|
|
service: 'Jupiter',
|
|
apiUrl: 'https://',
|
|
chainId: 1,
|
|
},
|
|
],
|
|
},
|
|
},
|
|
history: {
|
|
push: '/',
|
|
mostRecentOverviewPage: '/',
|
|
},
|
|
};
|
|
|
|
const store = configureMockStore()(mockStore);
|
|
|
|
it('opens confirm add custodian token with correct token', () => {
|
|
renderWithProvider(<ConfirmAddCustodianToken />, store);
|
|
|
|
const tokenContainer = screen.getByText('...testToken');
|
|
expect(tokenContainer).toBeInTheDocument();
|
|
});
|
|
|
|
it('shows the custodian on cancel click', () => {
|
|
renderWithProvider(<ConfirmAddCustodianToken />, store);
|
|
|
|
const cancelButton = screen.getByTestId('cancel-btn');
|
|
|
|
fireEvent.click(cancelButton);
|
|
|
|
expect(screen.getByText('Custodian')).toBeInTheDocument();
|
|
});
|
|
|
|
it('tries to connect to custodian with empty token', async () => {
|
|
const customMockedStore = {
|
|
metamask: {
|
|
providerConfig: {
|
|
type: 'test',
|
|
},
|
|
preferences: {
|
|
useNativeCurrencyAsPrimaryCurrency: true,
|
|
},
|
|
institutionalFeatures: {
|
|
complianceProjectId: '',
|
|
connectRequests: [
|
|
{
|
|
labels: [
|
|
{
|
|
key: 'service',
|
|
value: 'test',
|
|
},
|
|
],
|
|
origin: 'origin',
|
|
token: '',
|
|
feature: 'custodian',
|
|
service: 'Jupiter',
|
|
apiUrl: 'https://',
|
|
chainId: 1,
|
|
},
|
|
],
|
|
},
|
|
},
|
|
history: {
|
|
push: '/',
|
|
mostRecentOverviewPage: '/',
|
|
},
|
|
};
|
|
|
|
const customStore = configureMockStore()(customMockedStore);
|
|
|
|
renderWithProvider(<ConfirmAddCustodianToken />, customStore);
|
|
|
|
const confirmButton = screen.getByTestId('confirm-btn');
|
|
fireEvent.click(confirmButton);
|
|
|
|
const errorMessage = screen.getByTestId('connect-custodian-token-error');
|
|
|
|
expect(errorMessage).toBeVisible();
|
|
});
|
|
|
|
it('clicks the confirm button and shows the test value', async () => {
|
|
renderWithProvider(<ConfirmAddCustodianToken />, store);
|
|
|
|
const confirmButton = screen.getByTestId('confirm-btn');
|
|
fireEvent.click(confirmButton);
|
|
|
|
expect(screen.getByText('test')).toBeInTheDocument();
|
|
});
|
|
|
|
it('shows the error area', () => {
|
|
renderWithProvider(<ConfirmAddCustodianToken />, store);
|
|
|
|
const confirmButton = screen.getByTestId('confirm-btn');
|
|
|
|
fireEvent.click(confirmButton);
|
|
|
|
expect(screen.getByTestId('error-message')).toBeVisible();
|
|
});
|
|
});
|