mirror of
https://github.com/kremalicious/metamask-extension.git
synced 2024-12-23 09:52:26 +01:00
b91043cf72
* Review Recovery Phrase onboarding unit test * Add test for isFromReminderParam url navigation * Lint
129 lines
3.6 KiB
JavaScript
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}`,
|
|
);
|
|
});
|
|
});
|