1
0
mirror of https://github.com/kremalicious/metamask-extension.git synced 2024-12-23 09:52:26 +01:00
metamask-extension/ui/pages/onboarding-flow/privacy-settings/privacy-settings.test.js
Danica Shen 00d155ce2f
feat(878): implement network txn toggle and new style (#20363)
* 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>
2023-08-24 11:27:42 +01:00

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();
});
});
});