import { render, screen, fireEvent } from '@testing-library/react'; import { describe, it, expect, vi } from 'vitest'; import { Input } from './input'; import React from 'react'; describe('Input', () => { it('renders correctly with default props', () => { render(); const input = screen.getByPlaceholderText('Enter text'); expect(input).toBeInTheDocument(); expect(input).toHaveClass('h-10'); // md size }); it('renders correctly with different sizes', () => { const { rerender } = render(); expect(screen.getByPlaceholderText('Small')).toHaveClass('h-8'); rerender(); expect(screen.getByPlaceholderText('Large')).toHaveClass('h-12'); }); it('handles value changes', () => { const handleChange = vi.fn(); render(); const input = screen.getByPlaceholderText('Type here'); fireEvent.change(input, { target: { value: 'Hello' } }); expect(handleChange).toHaveBeenCalledTimes(1); expect((input as HTMLInputElement).value).toBe('Hello'); }); it('is disabled when disabled prop is true', () => { render(); const input = screen.getByPlaceholderText('Disabled'); expect(input).toBeDisabled(); expect(input).toHaveClass('disabled:opacity-50'); }); it('renders with custom className', () => { render(); expect(screen.getByPlaceholderText('Custom')).toHaveClass('custom-class'); }); it('renders with correct type', () => { render(); expect(screen.getByPlaceholderText('Password')).toHaveAttribute('type', 'password'); }); });