Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Added vitest for VolunteerContainer #2693

Original file line number Diff line number Diff line change
Expand Up @@ -12,13 +12,34 @@ import userEvent from '@testing-library/user-event';
import { MOCKS } from './Volunteers/Volunteers.mocks';
import { StaticMockLink } from 'utils/StaticMockLink';
import { LocalizationProvider } from '@mui/x-date-pickers';
import { describe, it, beforeEach, expect, vi } from 'vitest';

/**
* Unit tests for the `VolunteerContainer` component.
*
* The tests ensure the `VolunteerContainer` component renders correctly with various routes and URL parameters.
* Mocked dependencies are used to isolate the component and verify its behavior.
* all tests are covered
*/
NishantSinghhhhh marked this conversation as resolved.
Show resolved Hide resolved

const link1 = new StaticMockLink(MOCKS);

const renderVolunteerContainer = (): RenderResult => {
const mockedUseParams = vi.fn();

vi.mock('react-router-dom', async () => {
const actual = await vi.importActual('react-router-dom');
return {
...actual,
useParams: () => mockedUseParams(),
};
});

const renderVolunteerContainer = (
initialPath = '/event/orgId/eventId',
): RenderResult => {
return render(
<MockedProvider addTypename={false} link={link1}>
<MemoryRouter initialEntries={['/event/orgId/eventId']}>
<MemoryRouter initialEntries={[initialPath]}>
NishantSinghhhhh marked this conversation as resolved.
Show resolved Hide resolved
NishantSinghhhhh marked this conversation as resolved.
Show resolved Hide resolved
<Provider store={store}>
<LocalizationProvider>
<I18nextProvider i18n={i18n}>
Expand All @@ -41,54 +62,37 @@ const renderVolunteerContainer = (): RenderResult => {
};

describe('Testing Volunteer Container', () => {
beforeAll(() => {
jest.mock('react-router-dom', () => ({
...jest.requireActual('react-router-dom'),
useParams: () => ({ orgId: 'orgId', eventId: 'eventId' }),
}));
});

afterAll(() => {
jest.clearAllMocks();
beforeEach(() => {
vi.clearAllMocks();
});

it('should redirect to fallback URL if URL params are undefined', async () => {
render(
<MockedProvider addTypename={false} link={link1}>
<MemoryRouter initialEntries={['/event/']}>
<Provider store={store}>
<I18nextProvider i18n={i18n}>
<Routes>
<Route path="/event/" element={<VolunteerContainer />} />
NishantSinghhhhh marked this conversation as resolved.
Show resolved Hide resolved
<Route
path="/"
element={<div data-testid="paramsError"></div>}
/>
</Routes>
</I18nextProvider>
</Provider>
</MemoryRouter>
</MockedProvider>,
);
mockedUseParams.mockReturnValue({});

renderVolunteerContainer('/');

await waitFor(() => {
expect(screen.getByTestId('paramsError')).toBeInTheDocument();
});
});

test('Testing Volunteer Container Screen -> Toggle screens', async () => {
it('Testing Volunteer Container Screen -> Toggle screens', async () => {
mockedUseParams.mockReturnValue({ orgId: 'orgId', eventId: 'eventId' });

renderVolunteerContainer();

const groupRadio = await screen.findByTestId('groupsRadio');
expect(groupRadio).toBeInTheDocument();
userEvent.click(groupRadio);

const requestsRadio = await screen.findByTestId('requestsRadio');
expect(requestsRadio).toBeInTheDocument();
userEvent.click(requestsRadio);

const individualRadio = await screen.findByTestId('individualRadio');

expect(groupRadio).toBeInTheDocument();
expect(requestsRadio).toBeInTheDocument();
expect(individualRadio).toBeInTheDocument();
userEvent.click(individualRadio);

await waitFor(async () => {
await userEvent.click(groupRadio);
await userEvent.click(requestsRadio);
await userEvent.click(individualRadio);
});
});
});
2 changes: 1 addition & 1 deletion src/screens/EventVolunteers/VolunteerContainer.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -34,7 +34,7 @@ function volunteerContainer(): JSX.Element {
return (
<div>
<div className="mt-2 mb-4 d-flex justify-content-between">
<span className={styles.titlemodal}>
<span className={styles.titlemodal} data-testid="dataTypeTitle">
{t(
`${dataType === 'group' ? 'volunteerGroups' : dataType === 'individual' ? 'volunteers' : 'requests'}`,
)}
Expand Down
Loading