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

refactor:vitest to EventVolunteers/Volunteers #2695

Merged
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Original file line number Diff line number Diff line change
Expand Up @@ -22,11 +22,18 @@ import { toast } from 'react-toastify';
import type { InterfaceVolunteerCreateModal } from './VolunteerCreateModal';
import VolunteerCreateModal from './VolunteerCreateModal';
import userEvent from '@testing-library/user-event';
import { vi } from 'vitest';

jest.mock('react-toastify', () => ({
/**
* Mock implementation of the `react-toastify` module.
* Mocks the `toast` object with `success` and `error` methods to allow testing
* without triggering actual toast notifications.
*/

vi.mock('react-toastify', () => ({
toast: {
success: jest.fn(),
error: jest.fn(),
success: vi.fn(),
error: vi.fn(),
},
}));

Expand All @@ -45,10 +52,10 @@ const t = {
const itemProps: InterfaceVolunteerCreateModal[] = [
{
isOpen: true,
hide: jest.fn(),
hide: vi.fn(),
eventId: 'eventId',
orgId: 'orgId',
refetchVolunteers: jest.fn(),
refetchVolunteers: vi.fn(),
},
];

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -15,11 +15,18 @@ import { toast } from 'react-toastify';
import type { InterfaceDeleteVolunteerModal } from './VolunteerDeleteModal';
import VolunteerDeleteModal from './VolunteerDeleteModal';
import userEvent from '@testing-library/user-event';
import { vi } from 'vitest';

jest.mock('react-toastify', () => ({
/**
* Mock implementation of the `react-toastify` module.
* Mocks the `toast` object with `success` and `error` methods to allow testing
* without triggering actual toast notifications.
*/

vi.mock('react-toastify', () => ({
toast: {
success: jest.fn(),
error: jest.fn(),
success: vi.fn(),
error: vi.fn(),
},
}));

Expand All @@ -38,8 +45,8 @@ const t = {
const itemProps: InterfaceDeleteVolunteerModal[] = [
{
isOpen: true,
hide: jest.fn(),
refetchVolunteers: jest.fn(),
hide: vi.fn(),
refetchVolunteers: vi.fn(),
volunteer: {
_id: 'volunteerId1',
hasAccepted: true,
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -10,6 +10,7 @@ import { store } from 'state/store';
import i18n from 'utils/i18nForTest';
import type { InterfaceVolunteerViewModal } from './VolunteerViewModal';
import VolunteerViewModal from './VolunteerViewModal';
import { vi } from 'vitest';

const t = {
...JSON.parse(
Expand All @@ -24,7 +25,7 @@ const t = {
const itemProps: InterfaceVolunteerViewModal[] = [
{
isOpen: true,
hide: jest.fn(),
hide: vi.fn(),
volunteer: {
_id: 'volunteerId1',
hasAccepted: true,
Expand All @@ -51,7 +52,7 @@ const itemProps: InterfaceVolunteerViewModal[] = [
},
{
isOpen: true,
hide: jest.fn(),
hide: vi.fn(),
volunteer: {
_id: 'volunteerId2',
hasAccepted: false,
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -7,13 +7,14 @@ import { fireEvent, render, screen, waitFor } from '@testing-library/react';
import userEvent from '@testing-library/user-event';
import { I18nextProvider } from 'react-i18next';
import { Provider } from 'react-redux';
import { MemoryRouter, Route, Routes } from 'react-router-dom';
import { MemoryRouter, Route, Routes, useParams } from 'react-router-dom';
import { store } from 'state/store';
import { StaticMockLink } from 'utils/StaticMockLink';
import i18n from 'utils/i18nForTest';
import Volunteers from './Volunteers';
import type { ApolloLink } from '@apollo/client';
import { MOCKS, MOCKS_EMPTY, MOCKS_ERROR } from './Volunteers.mocks';
import { vi } from 'vitest';

const link1 = new StaticMockLink(MOCKS);
const link2 = new StaticMockLink(MOCKS_ERROR);
Expand Down Expand Up @@ -58,19 +59,25 @@ const renderVolunteers = (link: ApolloLink): RenderResult => {
);
};

/** Mock useParams to provide consistent test data */

describe('Testing Volunteers Screen', () => {
beforeAll(() => {
jest.mock('react-router-dom', () => ({
...jest.requireActual('react-router-dom'),
useParams: () => ({ orgId: 'orgId', eventId: 'eventId' }),
}));
vi.mock('react-router-dom', async () => {
const actualDom = await vi.importActual('react-router-dom');
return {
...actualDom,
useParams: vi.fn(),
};
});
});

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

it('should redirect to fallback URL if URL params are undefined', async () => {
vi.mocked(useParams).mockReturnValue({ orgId: '', eventId: '' });
render(
<MockedProvider addTypename={false} link={link1}>
<MemoryRouter initialEntries={['/event/']}>
Expand All @@ -95,12 +102,21 @@ describe('Testing Volunteers Screen', () => {
});

it('should render Volunteers screen', async () => {
vi.mocked(useParams).mockReturnValue({
orgId: 'orgId',
eventId: 'eventId',
});

renderVolunteers(link1);
const searchInput = await screen.findByTestId('searchBy');
expect(searchInput).toBeInTheDocument();
});

it('Check Sorting Functionality', async () => {
vi.mocked(useParams).mockReturnValue({
orgId: 'orgId',
eventId: 'eventId',
});
renderVolunteers(link1);
const searchInput = await screen.findByTestId('searchBy');
expect(searchInput).toBeInTheDocument();
Expand Down Expand Up @@ -134,6 +150,10 @@ describe('Testing Volunteers Screen', () => {
});

it('Filter Volunteers by status (All)', async () => {
vi.mocked(useParams).mockReturnValue({
orgId: 'orgId',
eventId: 'eventId',
});
renderVolunteers(link1);

const filterBtn = await screen.findByTestId('filter');
Expand All @@ -151,6 +171,10 @@ describe('Testing Volunteers Screen', () => {
});

it('Filter Volunteers by status (Pending)', async () => {
vi.mocked(useParams).mockReturnValue({
orgId: 'orgId',
eventId: 'eventId',
});
renderVolunteers(link1);

const filterBtn = await screen.findByTestId('filter');
Expand All @@ -168,6 +192,10 @@ describe('Testing Volunteers Screen', () => {
});

it('Filter Volunteers by status (Accepted)', async () => {
vi.mocked(useParams).mockReturnValue({
orgId: 'orgId',
eventId: 'eventId',
});
renderVolunteers(link1);

const filterBtn = await screen.findByTestId('filter');
Expand All @@ -185,6 +213,10 @@ describe('Testing Volunteers Screen', () => {
});

it('Search', async () => {
vi.mocked(useParams).mockReturnValue({
orgId: 'orgId',
eventId: 'eventId',
});
renderVolunteers(link1);
const searchInput = await screen.findByTestId('searchBy');
expect(searchInput).toBeInTheDocument();
Expand All @@ -197,6 +229,10 @@ describe('Testing Volunteers Screen', () => {
});

it('should render screen with No Volunteers', async () => {
vi.mocked(useParams).mockReturnValue({
orgId: 'orgId',
eventId: 'eventId',
});
renderVolunteers(link3);

await waitFor(() => {
Expand All @@ -206,6 +242,10 @@ describe('Testing Volunteers Screen', () => {
});

it('Error while fetching volunteers data', async () => {
vi.mocked(useParams).mockReturnValue({
orgId: 'orgId',
eventId: 'eventId',
});
renderVolunteers(link2);

await waitFor(() => {
Expand All @@ -214,6 +254,10 @@ describe('Testing Volunteers Screen', () => {
});

it('Open and close Volunteer Modal (View)', async () => {
vi.mocked(useParams).mockReturnValue({
orgId: 'orgId',
eventId: 'eventId',
});
renderVolunteers(link1);

const viewItemBtn = await screen.findAllByTestId('viewItemBtn');
Expand All @@ -224,6 +268,10 @@ describe('Testing Volunteers Screen', () => {
});

it('Open and Close Volunteer Modal (Delete)', async () => {
vi.mocked(useParams).mockReturnValue({
orgId: 'orgId',
eventId: 'eventId',
});
renderVolunteers(link1);

const deleteItemBtn = await screen.findAllByTestId('deleteItemBtn');
Expand All @@ -234,6 +282,10 @@ describe('Testing Volunteers Screen', () => {
});

it('Open and close Volunteer Modal (Create)', async () => {
vi.mocked(useParams).mockReturnValue({
orgId: 'orgId',
eventId: 'eventId',
});
renderVolunteers(link1);

const addVolunteerBtn = await screen.findByTestId('addVolunteerBtn');
Expand Down
Loading