import { describe, it, expect } from 'vitest';
import { render, screen } from '@testing-library/react';
import { Modal } from '../modal';
describe('Modal', () => {
it('renders modal when open', () => {
render(
{}}>
Modal content
);
expect(screen.getByText('Modal content')).toBeInTheDocument();
});
it('does not render when closed', () => {
render(
{}}>
Hidden content
);
expect(screen.queryByText('Hidden content')).not.toBeInTheDocument();
});
it('renders with custom className', () => {
render(
{}}>
Content
);
expect(screen.getByText('Content')).toBeInTheDocument();
});
it('renders modal overlay', () => {
render(
{}}>
Content
);
expect(screen.getByTestId('content')).toBeInTheDocument();
});
it('renders close button by default', () => {
render(
{}}>
Content
);
expect(screen.getByLabelText('Close modal')).toBeInTheDocument();
});
it('hides close button when showClose is false', () => {
render(
{}} showClose={false}>
Content
);
expect(screen.queryByLabelText('Close modal')).not.toBeInTheDocument();
});
});