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();
});
});