/*
* Copyright OpenSearch Contributors
* SPDX-License-Identifier: Apache-2.0
*/
import { fireEvent, render, waitFor } from '@testing-library/react';
import React from 'react';
import {
coreServicesMock,
notificationServiceMock,
} from '../../../../test/mocks/serviceMock';
import { CoreServicesContext } from '../../../components/coreServices';
import { CreateSenderModal } from '../components/modals/CreateSenderModal';
describe(' spec', () => {
it('renders the component', () => {
const utils = render(
{}}
onClose={() => {}}
services={notificationServiceMock}
/>
);
expect(utils.container.firstChild).toMatchSnapshot();
});
it('validates input', async () => {
const utils = render(
{}}
onClose={() => {}}
services={notificationServiceMock}
/>
);
utils.getByText('Create').click();
expect(utils.container.firstChild).toMatchSnapshot();
});
// TODO: Skipping test due to timeout
it.skip('creates senders', async () => {
const notificationServiceMock = jest.fn() as any;
const createConfig = jest.fn(async () => Promise.resolve());
notificationServiceMock.notificationService = {
createConfig,
};
const utils = render(
{}}
onClose={() => {}}
services={notificationServiceMock}
/>
);
const nameInput = utils.getByTestId('create-sender-form-name-input');
fireEvent.change(nameInput, { target: { value: 'test-name' } });
const emailInput = utils.getByTestId('create-sender-form-email-input');
fireEvent.change(emailInput, { target: { value: 'test@email.com' } });
const hostInput = utils.getByTestId('create-sender-form-host-input');
fireEvent.change(hostInput, { target: { value: 'host.com' } });
const portInput = utils.getByTestId('create-sender-form-port-input');
fireEvent.change(portInput, { target: { value: '23' } });
utils.getByText('Create').click();
await waitFor(() => {
expect(createConfig).toBeCalled();
});
});
// TODO: Skipping test due to timeout
it.skip('handles failures', async () => {
const notificationServiceMock = jest.fn() as any;
const createConfig = jest.fn(async () => Promise.reject());
notificationServiceMock.notificationService = {
createConfig,
};
const utils = render(
{}}
onClose={() => {}}
services={notificationServiceMock}
/>
);
const nameInput = utils.getByTestId('create-sender-form-name-input');
fireEvent.change(nameInput, { target: { value: 'test-name' } });
const emailInput = utils.getByTestId('create-sender-form-email-input');
fireEvent.change(emailInput, { target: { value: 'test@email.com' } });
const hostInput = utils.getByTestId('create-sender-form-host-input');
fireEvent.change(hostInput, { target: { value: 'host.com' } });
const portInput = utils.getByTestId('create-sender-form-port-input');
fireEvent.change(portInput, { target: { value: '23' } });
utils.getByText('Create').click();
await waitFor(() => {
expect(createConfig).toBeCalled();
});
});
});