import { render, screen } from '@testing-library/react';
import { describe, it, expect } from 'vitest';
import { Textarea } from './textarea';
describe('Textarea Component', () => {
it('renders textarea', () => {
render();
const textarea = screen.getByPlaceholderText('Enter text');
expect(textarea).toBeInTheDocument();
expect(textarea).toHaveClass('bg-kodo-graphite');
});
it('renders with label', () => {
render();
const label = screen.getByText('Description');
expect(label).toBeInTheDocument();
const textarea = screen.getByLabelText('Description');
expect(textarea).toBeInTheDocument();
});
it('displays error message', () => {
render();
const error = screen.getByText('This field is required');
expect(error).toBeInTheDocument();
expect(error).toHaveClass('text-kodo-red');
const textarea = screen.getByRole('textbox');
expect(textarea).toHaveClass('border-kodo-red');
});
it('applies custom className', () => {
render();
const textarea = screen.getByRole('textbox');
expect(textarea).toHaveClass('custom-textarea');
});
it('handles disabled state', () => {
render();
const textarea = screen.getByRole('textbox');
expect(textarea).toBeDisabled();
});
it('handles value prop', () => {
render();
const textarea = screen.getByRole('textbox');
expect(textarea).toHaveValue('Test value');
});
});