2026-04-23 20:52:43 +03:00
|
|
|
import { render, screen } from '@testing-library/react';
|
|
|
|
|
import type { NavItem } from '../model/types';
|
2026-04-23 21:45:40 +03:00
|
|
|
import { SidebarNav } from './SidebarNav';
|
2026-04-19 08:40:08 +03:00
|
|
|
|
|
|
|
|
const ITEMS: NavItem[] = [
|
|
|
|
|
{ id: 'bio', label: 'Bio', number: '01' },
|
|
|
|
|
{ id: 'work', label: 'Work', number: '02' },
|
2026-04-23 20:52:43 +03:00
|
|
|
];
|
2026-04-19 08:40:08 +03:00
|
|
|
|
|
|
|
|
beforeEach(() => {
|
2026-04-23 21:45:40 +03:00
|
|
|
global.IntersectionObserver = class {
|
|
|
|
|
observe = vi.fn();
|
|
|
|
|
disconnect = vi.fn();
|
|
|
|
|
unobserve = vi.fn();
|
|
|
|
|
} as unknown as typeof IntersectionObserver;
|
2026-04-23 20:52:43 +03:00
|
|
|
});
|
2026-04-19 08:40:08 +03:00
|
|
|
|
|
|
|
|
describe('SidebarNav', () => {
|
|
|
|
|
describe('rendering', () => {
|
|
|
|
|
it('renders a nav element', () => {
|
2026-04-23 20:52:43 +03:00
|
|
|
render(<SidebarNav items={ITEMS} />);
|
|
|
|
|
expect(screen.getByRole('navigation')).toBeInTheDocument();
|
|
|
|
|
});
|
2026-04-19 08:40:08 +03:00
|
|
|
|
|
|
|
|
it('renders "Index" heading', () => {
|
2026-04-23 20:52:43 +03:00
|
|
|
render(<SidebarNav items={ITEMS} />);
|
|
|
|
|
expect(screen.getByText('Index')).toBeInTheDocument();
|
|
|
|
|
});
|
2026-04-19 08:40:08 +03:00
|
|
|
|
|
|
|
|
it('renders "Digital Monograph" subtitle', () => {
|
2026-04-23 20:52:43 +03:00
|
|
|
render(<SidebarNav items={ITEMS} />);
|
|
|
|
|
expect(screen.getByText('Digital Monograph')).toBeInTheDocument();
|
|
|
|
|
});
|
2026-04-19 08:40:08 +03:00
|
|
|
|
|
|
|
|
it('renders each item label and number', () => {
|
2026-04-23 20:52:43 +03:00
|
|
|
render(<SidebarNav items={ITEMS} />);
|
|
|
|
|
expect(screen.getByText('Bio')).toBeInTheDocument();
|
|
|
|
|
expect(screen.getByText('01')).toBeInTheDocument();
|
|
|
|
|
expect(screen.getByText('Work')).toBeInTheDocument();
|
|
|
|
|
expect(screen.getByText('02')).toBeInTheDocument();
|
|
|
|
|
});
|
2026-04-19 08:40:08 +03:00
|
|
|
|
|
|
|
|
it('renders "Quick Links" section', () => {
|
2026-04-23 20:52:43 +03:00
|
|
|
render(<SidebarNav items={ITEMS} />);
|
|
|
|
|
expect(screen.getByText('Quick Links')).toBeInTheDocument();
|
|
|
|
|
});
|
2026-04-19 08:40:08 +03:00
|
|
|
|
|
|
|
|
it('renders Email quick link', () => {
|
2026-04-23 20:52:43 +03:00
|
|
|
render(<SidebarNav items={ITEMS} />);
|
|
|
|
|
expect(screen.getByRole('link', { name: 'Email' })).toBeInTheDocument();
|
|
|
|
|
});
|
2026-04-19 08:40:08 +03:00
|
|
|
|
|
|
|
|
it('renders a button for each item', () => {
|
2026-04-23 20:52:43 +03:00
|
|
|
render(<SidebarNav items={ITEMS} />);
|
|
|
|
|
const buttons = screen.getAllByRole('button');
|
|
|
|
|
expect(buttons.length).toBeGreaterThanOrEqual(ITEMS.length);
|
|
|
|
|
});
|
|
|
|
|
});
|
|
|
|
|
});
|