import { render, screen, fireEvent } from '@testing-library/react'; import { describe, it, expect, vi } from 'vitest'; import { ImageCropper } from './ImageCropper'; // Mock react-easy-crop vi.mock('react-easy-crop', () => ({ default: ({ image, onCropChange, onCropComplete }: any) => (
cropper
), })); describe('ImageCropper Component', () => { const mockOnCancel = vi.fn(); const mockOnCropComplete = vi.fn(); beforeEach(() => { vi.clearAllMocks(); }); it('renders cropper with image', () => { render( , ); expect(screen.getByTestId('cropper')).toBeInTheDocument(); expect(screen.getByText('Edit Image')).toBeInTheDocument(); }); it('calls onCancel when cancel button is clicked', () => { render( , ); const cancelButton = screen.getByText('Cancel'); fireEvent.click(cancelButton); expect(mockOnCancel).toHaveBeenCalled(); }); it('calls onCropComplete when save button is clicked', () => { render( , ); // First complete a crop const completeButton = screen.getByText('Complete Crop'); fireEvent.click(completeButton); // Then save const saveButton = screen.getByText('Apply Crop'); fireEvent.click(saveButton); expect(mockOnCropComplete).toHaveBeenCalled(); }); it('renders with circular crop when circularCrop is true', () => { render( , ); expect(screen.getByTestId('cropper')).toBeInTheDocument(); }); });