import { describe, it, expect, vi } from 'vitest';
import { render, screen, fireEvent } from '@testing-library/react';
import ConfirmationModal from '../ConfirmationModal';
// Mock react-i18next
vi.mock('react-i18next', () => ({
useTranslation: () => ({
t: (key: string) => key,
}),
}));
describe('ConfirmationModal', () => {
const defaultProps = {
isOpen: true,
onClose: vi.fn(),
onConfirm: vi.fn(),
title: 'Test Title',
message: 'Test message',
};
beforeEach(() => {
vi.clearAllMocks();
});
it('returns null when not open', () => {
const { container } = render(
);
expect(container.firstChild).toBeNull();
});
it('renders title when open', () => {
render();
expect(screen.getByText('Test Title')).toBeInTheDocument();
});
it('renders message when open', () => {
render();
expect(screen.getByText('Test message')).toBeInTheDocument();
});
it('renders message as ReactNode', () => {
render(
Custom content}
/>
);
expect(screen.getByTestId('custom-message')).toBeInTheDocument();
});
it('calls onClose when close button is clicked', () => {
render();
const buttons = screen.getAllByRole('button');
fireEvent.click(buttons[0]);
expect(defaultProps.onClose).toHaveBeenCalled();
});
it('calls onClose when cancel button is clicked', () => {
render();
fireEvent.click(screen.getByText('common.cancel'));
expect(defaultProps.onClose).toHaveBeenCalled();
});
it('calls onConfirm when confirm button is clicked', () => {
render();
fireEvent.click(screen.getByText('common.confirm'));
expect(defaultProps.onConfirm).toHaveBeenCalled();
});
it('uses custom confirm text', () => {
render();
expect(screen.getByText('Yes, delete')).toBeInTheDocument();
});
it('uses custom cancel text', () => {
render();
expect(screen.getByText('No, keep')).toBeInTheDocument();
});
it('renders info variant', () => {
render();
expect(screen.getByText('Test Title')).toBeInTheDocument();
});
it('renders warning variant', () => {
render();
expect(screen.getByText('Test Title')).toBeInTheDocument();
});
it('renders danger variant', () => {
render();
expect(screen.getByText('Test Title')).toBeInTheDocument();
});
it('renders success variant', () => {
render();
expect(screen.getByText('Test Title')).toBeInTheDocument();
});
it('disables buttons when loading', () => {
render();
const buttons = screen.getAllByRole('button');
buttons.forEach((button) => {
expect(button).toBeDisabled();
});
});
it('shows spinner when loading', () => {
render();
const spinner = document.querySelector('.animate-spin');
expect(spinner).toBeInTheDocument();
});
});