import { render, screen } from '@testing-library/react'; import { describe, it, expect, vi } from 'vitest'; import { Select, SelectTrigger, SelectValue, SelectContent, SelectItem } from './select'; import React from 'react'; // Mocking Portal vi.mock('@radix-ui/react-select', async () => { const actual = await vi.importActual('@radix-ui/react-select'); return { ...actual, Portal: ({ children }: { children: React.ReactNode }) => (
{children}
), }; }); describe('Select', () => { it('renders correctly', () => { render( ); expect(screen.getByText('Select fruit')).toBeInTheDocument(); }); it('shows content when open is true', () => { render( ); expect(screen.getByText('Apple')).toBeInTheDocument(); }); it('is disabled when disabled prop is true', () => { render( ); expect(screen.getByRole('combobox')).toBeDisabled(); }); it('renders SelectTrigger correctly with different sizes', () => { const { rerender } = render( ); expect(screen.getByRole('combobox')).toHaveClass('h-8'); rerender( ); expect(screen.getByRole('combobox')).toHaveClass('h-10'); rerender( ); expect(screen.getByRole('combobox')).toHaveClass('h-12'); }); it('has correct data-slot attributes', () => { const { container } = render( ); expect(container.querySelector('[data-slot="select-trigger"]')).toBeInTheDocument(); }); });