import { render } from '@testing-library/react';
import {
Skeleton,
SkeletonAvatar,
SkeletonText,
SkeletonCard,
SkeletonList,
SkeletonTable,
SkeletonForm,
} from '../Skeleton';
describe('Skeleton Component', () => {
it('renders basic skeleton', () => {
const { container } = render();
const skeleton = container.firstChild;
expect(skeleton).toHaveClass('animate-pulse', 'bg-slate-200');
});
it('renders with different variants', () => {
const { rerender, container } = render();
let skeleton = container.firstChild;
expect(skeleton).toHaveClass('rounded');
rerender();
skeleton = container.firstChild;
expect(skeleton).toHaveClass('rounded-full');
rerender();
skeleton = container.firstChild;
expect(skeleton).toHaveClass('h-4');
});
it('applies custom className', () => {
const { container } = render();
const skeleton = container.firstChild;
expect(skeleton).toHaveClass('w-full', 'h-20');
});
it('has aria-hidden attribute', () => {
const { container } = render();
const skeleton = container.firstChild;
expect(skeleton).toHaveAttribute('aria-hidden', 'true');
});
});
describe('SkeletonAvatar Component', () => {
it('renders circular skeleton', () => {
const { container } = render();
const avatar = container.firstChild;
expect(avatar).toHaveClass('rounded-full');
});
it('renders with different sizes', () => {
const { rerender, container } = render();
let avatar = container.firstChild;
expect(avatar).toHaveClass('h-8', 'w-8');
rerender();
avatar = container.firstChild;
expect(avatar).toHaveClass('h-12', 'w-12');
rerender();
avatar = container.firstChild;
expect(avatar).toHaveClass('h-16', 'w-16');
});
});
describe('SkeletonText Component', () => {
it('renders default number of lines', () => {
const { container } = render();
const lines = container.querySelectorAll('.h-4');
expect(lines).toHaveLength(3);
});
it('renders custom number of lines', () => {
const { container } = render();
const lines = container.querySelectorAll('.h-4');
expect(lines).toHaveLength(5);
});
it('makes last line shorter', () => {
const { container } = render();
const lines = container.querySelectorAll('.h-4');
expect(lines[1]).toHaveClass('w-3/4');
});
});
describe('SkeletonCard Component', () => {
it('renders card with avatar by default', () => {
const { container } = render();
const avatar = container.querySelector('.rounded-full');
expect(avatar).toBeInTheDocument();
});
it('renders without avatar when specified', () => {
const { container } = render();
const avatar = container.querySelector('.rounded-full');
expect(avatar).not.toBeInTheDocument();
});
it('renders custom number of text lines', () => {
const { container } = render();
const textContainer = container.querySelector('.space-y-2');
const lines = textContainer?.querySelectorAll('.h-4');
expect(lines).toHaveLength(5);
});
it('has card styling', () => {
const { container } = render();
const card = container.firstChild;
expect(card).toHaveClass('rounded-lg', 'border', 'bg-white', 'p-6');
});
});
describe('SkeletonList Component', () => {
it('renders default number of cards', () => {
const { container } = render();
const cards = container.querySelectorAll('.rounded-lg.border');
expect(cards).toHaveLength(3);
});
it('renders custom number of cards', () => {
const { container } = render();
const cards = container.querySelectorAll('.rounded-lg.border');
expect(cards).toHaveLength(5);
});
it('passes showAvatar prop to cards', () => {
const { container } = render();
const avatars = container.querySelectorAll('.rounded-full');
expect(avatars).toHaveLength(0);
});
});
describe('SkeletonTable Component', () => {
it('renders table with header by default', () => {
const { container } = render();
const header = container.querySelector('.bg-slate-50');
expect(header).toBeInTheDocument();
});
it('renders without header when specified', () => {
const { container } = render();
const header = container.querySelector('.bg-slate-50');
expect(header).not.toBeInTheDocument();
});
it('renders correct number of rows and columns', () => {
const { container } = render();
const rows = container.querySelectorAll('.divide-y > div');
expect(rows).toHaveLength(3);
const firstRowCells = rows[0].querySelectorAll('.h-4');
expect(firstRowCells).toHaveLength(4);
});
});
describe('SkeletonForm Component', () => {
it('renders default number of fields', () => {
const { container } = render();
const fields = container.querySelectorAll('.space-y-2');
expect(fields).toHaveLength(3);
});
it('renders custom number of fields', () => {
const { container } = render();
const fields = container.querySelectorAll('.space-y-2');
expect(fields).toHaveLength(5);
});
it('includes submit button skeleton', () => {
const { container } = render();
// Count all h-10 elements (fields + button)
const elements = container.querySelectorAll('.h-10');
// Should have fields + 1 submit button
expect(elements.length).toBeGreaterThan(3);
});
});