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