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/recovery-phrase/review-recovery-phrase.test.js
Thomas Huang b91043cf72
Review Recovery Phrase onboarding unit test (#18301)
* Review Recovery Phrase onboarding unit test

* Add test for isFromReminderParam url navigation

* Lint
2023-04-20 13:33:25 -05:00

129 lines
3.6 KiB
JavaScript

import { fireEvent } from '@testing-library/react';
import React from 'react';
import configureMockStore from 'redux-mock-store';
import { renderWithProvider } from '../../../../test/lib/render-helpers';
import { ONBOARDING_CONFIRM_SRP_ROUTE } from '../../../helpers/constants/routes';
import RecoveryPhrase from './review-recovery-phrase';
const mockHistoryPush = jest.fn();
const mockHistoryReplace = jest.fn();
jest.mock('react-router-dom', () => ({
...jest.requireActual('react-router-dom'),
useHistory: () => ({
push: mockHistoryPush,
replace: mockHistoryReplace,
}),
}));
const mockStore = configureMockStore()();
describe('Review Recovery Phrase Component', () => {
const TEST_SEED =
'debris dizzy just program just float decrease vacant alarm reduce speak stadium';
const props = {
secretRecoveryPhrase: TEST_SEED,
};
it('should match snapshot', () => {
const { container } = renderWithProvider(
<RecoveryPhrase {...props} />,
mockStore,
);
expect(container).toMatchSnapshot();
});
it('should match snapshot after reveal recovery button is clicked', () => {
const { container, queryByTestId } = renderWithProvider(
<RecoveryPhrase {...props} />,
mockStore,
);
const revealRecoveryPhraseButton = queryByTestId('recovery-phrase-reveal');
fireEvent.click(revealRecoveryPhraseButton);
expect(container).toMatchSnapshot();
});
it('should click copy to cliboard', () => {
const { queryByText, queryByTestId } = renderWithProvider(
<RecoveryPhrase {...props} />,
mockStore,
);
jest.spyOn(window, 'prompt').mockImplementation();
// eslint-disable-next-line jest/prefer-spy-on
document.execCommand = jest.fn();
const revealRecoveryPhraseButton = queryByTestId('recovery-phrase-reveal');
fireEvent.click(revealRecoveryPhraseButton);
const copyToClipboard = queryByText('Copy to clipboard');
fireEvent.click(copyToClipboard);
expect(document.execCommand).toHaveBeenCalledWith('copy');
});
it('should hide seed after revealing', () => {
const { queryByText, queryByTestId } = renderWithProvider(
<RecoveryPhrase {...props} />,
mockStore,
);
const revealRecoveryPhraseButton = queryByTestId('recovery-phrase-reveal');
fireEvent.click(revealRecoveryPhraseButton);
const hideSeedPhrase = queryByText('Hide seed phrase');
fireEvent.click(hideSeedPhrase);
const revealSeedPhrase = queryByText('Reveal seed phrase');
expect(revealSeedPhrase).toBeInTheDocument();
});
it('should click next after revealing seed phrase', () => {
const { queryByTestId } = renderWithProvider(
<RecoveryPhrase {...props} />,
mockStore,
);
const revealRecoveryPhraseButton = queryByTestId('recovery-phrase-reveal');
fireEvent.click(revealRecoveryPhraseButton);
const nextButton = queryByTestId('recovery-phrase-next');
fireEvent.click(nextButton);
expect(mockHistoryPush).toHaveBeenCalledWith(ONBOARDING_CONFIRM_SRP_ROUTE);
});
it('should route to url with reminder parameter', () => {
const isReminderParam = '/?isFromReminder=true';
const { queryByTestId } = renderWithProvider(
<RecoveryPhrase {...props} />,
mockStore,
isReminderParam,
);
const revealRecoveryPhraseButton = queryByTestId('recovery-phrase-reveal');
fireEvent.click(revealRecoveryPhraseButton);
const nextButton = queryByTestId('recovery-phrase-next');
fireEvent.click(nextButton);
expect(mockHistoryPush).toHaveBeenCalledWith(
`${ONBOARDING_CONFIRM_SRP_ROUTE}${isReminderParam}`,
);
});
});