import { render, screen, fireEvent } from '@testing-library/react'; import { describe, it, expect, vi } from 'vitest'; import { Dialog, DialogTrigger, DialogContent, DialogHeader, DialogTitle, DialogDescription, DialogFooter, } from './dialog'; import React from 'react'; // Mocking Portal vi.mock('@radix-ui/react-dialog', async () => { const actual = await vi.importActual('@radix-ui/react-dialog'); return { ...actual, Portal: ({ children }: { children: React.ReactNode }) => (
{children}
), }; }); describe('Dialog', () => { it('renders correctly', () => { render( Open Dialog Dialog Title Dialog Description ); expect(screen.getByText('Open Dialog')).toBeInTheDocument(); }); it('shows content when open is true', () => { render( Open Title ); expect(screen.getByText('Title')).toBeInTheDocument(); }); it('has correct data-slot attributes', () => { const { container } = render( Open ); expect(container.querySelector('[data-slot="dialog-trigger"]')).toBeInTheDocument(); }); it('renders with different sizes', () => { render( Small ); const content = screen.getByText('Small').closest('[data-slot="dialog-content"]'); expect(content).toHaveClass('max-w-sm'); }); });