mirror of
https://github.com/kremalicious/metamask-extension.git
synced 2024-12-23 09:52:26 +01:00
167 lines
5.4 KiB
JavaScript
167 lines
5.4 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 PrivacySettings from './privacy-settings';
|
|
|
|
describe('Privacy Settings Onboarding View', () => {
|
|
const mockStore = {
|
|
metamask: {
|
|
networkConfigurations: {},
|
|
provider: {
|
|
type: 'test',
|
|
},
|
|
},
|
|
};
|
|
|
|
const store = configureMockStore([thunk])(mockStore);
|
|
const setFeatureFlagStub = jest.fn();
|
|
const setUsePhishDetectStub = 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();
|
|
|
|
setBackgroundConnection({
|
|
setFeatureFlag: setFeatureFlagStub,
|
|
setUsePhishDetect: setUsePhishDetectStub,
|
|
setUseTokenDetection: setUseTokenDetectionStub,
|
|
setUseCurrencyRateCheck: setUseCurrencyRateCheckStub,
|
|
setIpfsGateway: setIpfsGatewayStub,
|
|
completeOnboarding: completeOnboardingStub,
|
|
setUseMultiAccountBalanceChecker: setUseMultiAccountBalanceCheckerStub,
|
|
});
|
|
|
|
it('should update preferences', () => {
|
|
const { container, getByText } = renderWithProvider(
|
|
<PrivacySettings />,
|
|
store,
|
|
);
|
|
// All settings are initialized toggled to true
|
|
expect(setFeatureFlagStub).toHaveBeenCalledTimes(0);
|
|
expect(setUsePhishDetectStub).toHaveBeenCalledTimes(0);
|
|
expect(setUseTokenDetectionStub).toHaveBeenCalledTimes(0);
|
|
expect(setUseMultiAccountBalanceCheckerStub).toHaveBeenCalledTimes(0);
|
|
expect(setUseCurrencyRateCheckStub).toHaveBeenCalledTimes(0);
|
|
|
|
const toggles = container.querySelectorAll('input[type=checkbox]');
|
|
const submitButton = getByText('Done');
|
|
|
|
// toggle to false
|
|
fireEvent.click(toggles[0]);
|
|
fireEvent.click(toggles[1]);
|
|
fireEvent.click(toggles[2]);
|
|
fireEvent.click(toggles[3]);
|
|
fireEvent.click(toggles[4]);
|
|
fireEvent.click(submitButton);
|
|
|
|
expect(setFeatureFlagStub).toHaveBeenCalledTimes(1);
|
|
expect(setUsePhishDetectStub).toHaveBeenCalledTimes(1);
|
|
expect(setUseTokenDetectionStub).toHaveBeenCalledTimes(1);
|
|
expect(setUseMultiAccountBalanceCheckerStub).toHaveBeenCalledTimes(1);
|
|
expect(setUseCurrencyRateCheckStub).toHaveBeenCalledTimes(1);
|
|
|
|
expect(setFeatureFlagStub.mock.calls[0][1]).toStrictEqual(false);
|
|
expect(setUsePhishDetectStub.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);
|
|
|
|
// toggle back to true
|
|
fireEvent.click(toggles[0]);
|
|
fireEvent.click(toggles[1]);
|
|
fireEvent.click(toggles[2]);
|
|
fireEvent.click(toggles[3]);
|
|
fireEvent.click(toggles[4]);
|
|
fireEvent.click(submitButton);
|
|
expect(setFeatureFlagStub).toHaveBeenCalledTimes(2);
|
|
expect(setUsePhishDetectStub).toHaveBeenCalledTimes(2);
|
|
expect(setUseTokenDetectionStub).toHaveBeenCalledTimes(2);
|
|
expect(setUseMultiAccountBalanceCheckerStub).toHaveBeenCalledTimes(2);
|
|
expect(setUseCurrencyRateCheckStub).toHaveBeenCalledTimes(2);
|
|
|
|
expect(setFeatureFlagStub.mock.calls[1][1]).toStrictEqual(true);
|
|
expect(setUsePhishDetectStub.mock.calls[1][0]).toStrictEqual(true);
|
|
expect(setUseTokenDetectionStub.mock.calls[1][0]).toStrictEqual(true);
|
|
expect(setUseMultiAccountBalanceCheckerStub.mock.calls[1][0]).toStrictEqual(
|
|
true,
|
|
);
|
|
expect(setUseCurrencyRateCheckStub.mock.calls[1][0]).toStrictEqual(true);
|
|
});
|
|
|
|
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();
|
|
});
|
|
});
|
|
});
|