mirror of
https://github.com/kremalicious/metamask-extension.git
synced 2024-12-23 09:52:26 +01:00
00d155ce2f
* feat(878): implement new incoming transaction toggle networks for setting and onboarding * Update state snapshots * feat(878): change gaps, migration types based on comment --------- Co-authored-by: Mark Stacey <markjstacey@gmail.com>
175 lines
5.7 KiB
JavaScript
175 lines
5.7 KiB
JavaScript
import React from 'react';
|
|
import { fireEvent } from '@testing-library/react';
|
|
import configureMockStore from 'redux-mock-store';
|
|
import thunk from 'redux-thunk';
|
|
import {
|
|
renderWithProvider,
|
|
setBackgroundConnection,
|
|
} from '../../../../test/jest';
|
|
import { CHAIN_IDS } from '../../../../shared/constants/network';
|
|
import PrivacySettings from './privacy-settings';
|
|
|
|
describe('Privacy Settings Onboarding View', () => {
|
|
const mockStore = {
|
|
metamask: {
|
|
networkConfigurations: {},
|
|
providerConfig: {
|
|
type: 'test',
|
|
},
|
|
incomingTransactionsPreferences: {
|
|
[CHAIN_IDS.MAINNET]: true,
|
|
[CHAIN_IDS.LINEA_MAINNET]: false,
|
|
[CHAIN_IDS.GOERLI]: false,
|
|
[CHAIN_IDS.SEPOLIA]: false,
|
|
[CHAIN_IDS.LINEA_GOERLI]: true,
|
|
},
|
|
},
|
|
};
|
|
|
|
const store = configureMockStore([thunk])(mockStore);
|
|
const setFeatureFlagStub = jest.fn();
|
|
const setUsePhishDetectStub = jest.fn();
|
|
const setUse4ByteResolutionStub = jest.fn();
|
|
const setUseTokenDetectionStub = jest.fn();
|
|
const setUseCurrencyRateCheckStub = jest.fn();
|
|
const setIpfsGatewayStub = jest.fn();
|
|
const completeOnboardingStub = jest
|
|
.fn()
|
|
.mockImplementation(() => Promise.resolve());
|
|
const setUseMultiAccountBalanceCheckerStub = jest.fn();
|
|
const setUseAddressBarEnsResolutionStub = jest.fn();
|
|
const setIncomingTransactionsPreferencesStub = jest.fn();
|
|
|
|
setBackgroundConnection({
|
|
setFeatureFlag: setFeatureFlagStub,
|
|
setUsePhishDetect: setUsePhishDetectStub,
|
|
setUse4ByteResolution: setUse4ByteResolutionStub,
|
|
setUseTokenDetection: setUseTokenDetectionStub,
|
|
setUseCurrencyRateCheck: setUseCurrencyRateCheckStub,
|
|
setIpfsGateway: setIpfsGatewayStub,
|
|
completeOnboarding: completeOnboardingStub,
|
|
setUseMultiAccountBalanceChecker: setUseMultiAccountBalanceCheckerStub,
|
|
setUseAddressBarEnsResolution: setUseAddressBarEnsResolutionStub,
|
|
setIncomingTransactionsPreferences: setIncomingTransactionsPreferencesStub,
|
|
});
|
|
|
|
it('should update preferences', () => {
|
|
const { container, getByText } = renderWithProvider(
|
|
<PrivacySettings />,
|
|
store,
|
|
);
|
|
// All settings are initialized toggled to true
|
|
expect(setUsePhishDetectStub).toHaveBeenCalledTimes(0);
|
|
expect(setUse4ByteResolutionStub).toHaveBeenCalledTimes(0);
|
|
expect(setUseTokenDetectionStub).toHaveBeenCalledTimes(0);
|
|
expect(setUseMultiAccountBalanceCheckerStub).toHaveBeenCalledTimes(0);
|
|
expect(setUseCurrencyRateCheckStub).toHaveBeenCalledTimes(0);
|
|
expect(setUseAddressBarEnsResolutionStub).toHaveBeenCalledTimes(0);
|
|
expect(setIncomingTransactionsPreferencesStub).toHaveBeenCalledTimes(0);
|
|
|
|
const toggles = container.querySelectorAll('input[type=checkbox]');
|
|
const submitButton = getByText('Done');
|
|
// toggle to false
|
|
fireEvent.click(toggles[1]);
|
|
fireEvent.click(toggles[6]);
|
|
fireEvent.click(toggles[7]);
|
|
fireEvent.click(toggles[8]);
|
|
fireEvent.click(toggles[9]);
|
|
fireEvent.click(toggles[10]);
|
|
fireEvent.click(toggles[11]);
|
|
|
|
fireEvent.click(submitButton);
|
|
|
|
expect(setIncomingTransactionsPreferencesStub).toHaveBeenCalledTimes(1);
|
|
expect(setUsePhishDetectStub).toHaveBeenCalledTimes(1);
|
|
expect(setUse4ByteResolutionStub).toHaveBeenCalledTimes(1);
|
|
expect(setUseTokenDetectionStub).toHaveBeenCalledTimes(1);
|
|
expect(setUseMultiAccountBalanceCheckerStub).toHaveBeenCalledTimes(1);
|
|
expect(setUseCurrencyRateCheckStub).toHaveBeenCalledTimes(1);
|
|
expect(setUseAddressBarEnsResolutionStub).toHaveBeenCalledTimes(1);
|
|
|
|
expect(setIncomingTransactionsPreferencesStub).toHaveBeenCalledWith(
|
|
CHAIN_IDS.MAINNET,
|
|
false,
|
|
expect.anything(),
|
|
);
|
|
|
|
expect(setUsePhishDetectStub.mock.calls[0][0]).toStrictEqual(false);
|
|
expect(setUse4ByteResolutionStub.mock.calls[0][0]).toStrictEqual(false);
|
|
expect(setUseTokenDetectionStub.mock.calls[0][0]).toStrictEqual(false);
|
|
expect(setUseMultiAccountBalanceCheckerStub.mock.calls[0][0]).toStrictEqual(
|
|
false,
|
|
);
|
|
expect(setUseCurrencyRateCheckStub.mock.calls[0][0]).toStrictEqual(false);
|
|
expect(setUseAddressBarEnsResolutionStub.mock.calls[0][0]).toStrictEqual(
|
|
false,
|
|
);
|
|
});
|
|
|
|
describe('IPFS', () => {
|
|
it('should handle proper IPFS input', () => {
|
|
const { queryByTestId, queryByText } = renderWithProvider(
|
|
<PrivacySettings />,
|
|
store,
|
|
);
|
|
|
|
const ipfsInput = queryByTestId('ipfs-input');
|
|
const ipfsEvent = {
|
|
target: {
|
|
value: 'ipfs.io',
|
|
},
|
|
};
|
|
|
|
fireEvent.change(ipfsInput, ipfsEvent);
|
|
|
|
const validIpfsUrl = queryByText('IPFS gateway URL is valid');
|
|
expect(validIpfsUrl).toBeInTheDocument();
|
|
|
|
const submitButton = queryByText('Done');
|
|
fireEvent.click(submitButton);
|
|
|
|
expect(setIpfsGatewayStub).toHaveBeenCalled();
|
|
});
|
|
|
|
it('should error with gateway.ipfs.io IPFS input', () => {
|
|
const { queryByTestId, queryByText } = renderWithProvider(
|
|
<PrivacySettings />,
|
|
store,
|
|
);
|
|
|
|
const ipfsInput = queryByTestId('ipfs-input');
|
|
const ipfsEvent = {
|
|
target: {
|
|
value: 'gateway.ipfs.io',
|
|
},
|
|
};
|
|
|
|
fireEvent.change(ipfsInput, ipfsEvent);
|
|
|
|
const invalidErrorMsg = queryByText('Please enter a valid URL');
|
|
|
|
expect(invalidErrorMsg).toBeInTheDocument();
|
|
});
|
|
|
|
it('should error with improper IPFS input', () => {
|
|
const { queryByTestId, queryByText } = renderWithProvider(
|
|
<PrivacySettings />,
|
|
store,
|
|
);
|
|
|
|
const ipfsInput = queryByTestId('ipfs-input');
|
|
const ipfsEvent = {
|
|
target: {
|
|
value: ' ',
|
|
},
|
|
};
|
|
|
|
fireEvent.change(ipfsInput, ipfsEvent);
|
|
|
|
const invalidErrorMsg = queryByText('Please enter a valid URL');
|
|
|
|
expect(invalidErrorMsg).toBeInTheDocument();
|
|
});
|
|
});
|
|
});
|