1
0
mirror of https://github.com/kremalicious/metamask-extension.git synced 2024-11-28 23:06:37 +01:00
metamask-extension/ui/components/app/custom-nonce/custom-nonce.test.js

66 lines
2.0 KiB
JavaScript

import React from 'react';
import configureMockStore from 'redux-mock-store';
import { fireEvent } from '@testing-library/react';
import { renderWithProvider } from '../../../../test/lib/render-helpers';
import CustomNonce from './custom-nonce';
describe('CustomNonce', () => {
const store = configureMockStore()({});
let props = {};
beforeEach(() => {
props = {
nextNonce: 1,
customNonceValue: '',
showCustomizeNonceModal: jest.fn(),
};
});
it('should render CustomNonce component header', () => {
const { queryByText } = renderWithProvider(
<CustomNonce {...props} />,
store,
);
expect(queryByText('Nonce')).toBeInTheDocument();
expect(queryByText('Edit')).toBeInTheDocument();
});
it('should render CustomNonce component value when custom nonce value is a empty string', () => {
const { queryByText } = renderWithProvider(
<CustomNonce {...props} />,
store,
);
expect(queryByText('Nonce')).toBeInTheDocument();
expect(queryByText('Edit')).toBeInTheDocument();
expect(queryByText('1')).toBeInTheDocument();
});
it('should render CustomNonce component value when custom nonce value is edited', () => {
props.customNonceValue = '3';
const { queryByText } = renderWithProvider(
<CustomNonce {...props} />,
store,
);
expect(queryByText('Nonce')).toBeInTheDocument();
expect(queryByText('Edit')).toBeInTheDocument();
expect(queryByText('3')).toBeInTheDocument();
});
it('should render CustomNonce component to show customize nonce modal', () => {
const { queryByText, getByText } = renderWithProvider(
<CustomNonce {...props} />,
store,
);
const editButton = getByText('Edit');
expect(queryByText('Nonce')).toBeInTheDocument();
expect(editButton).toBeInTheDocument();
expect(queryByText('1')).toBeInTheDocument();
fireEvent.click(editButton);
expect(props.showCustomizeNonceModal).toHaveBeenCalledTimes(1);
});
});