mirror of
https://github.com/mauriceboe/TREK.git
synced 2026-06-19 21:31:46 +00:00
de157cb87b
Server (172 tests): - journeyService unit tests (87 tests): CRUD, access control, sync, photos, contributors - journeyShareService unit tests (20 tests): share links, token validation, public access - journey integration tests (45 tests): all API routes, auth, permissions, edge cases - Test helpers: journey factories, RESET_TABLES updated Client (340+ tests): - journeyStore tests (15 tests): all store actions and state management - JourneyPage tests (20 tests): frontpage, create flow, suggestions, navigation - JourneyDetailPage tests (94 tests): all sub-components, entry editor, settings, share links, contributors, gallery, map, trip linking - JourneyPublicPage tests (18 tests): public view, tabs, restricted access - JourneyBookPDF tests (6 tests): PDF generation - BottomNav tests (9 tests): profile sheet, navigation - PhotoLightbox tests (8 tests): keyboard nav, counter - JourneyMap tests (12 tests): markers, polylines, zoom - Component tests: moodConfig, stripMarkdown, MarkdownToolbar, JournalBody, MobileTopHeader - DashboardPage tests (32 tests): spotlight card, quick actions, widget settings SonarQube: exclude unused MemoriesPanel from coverage (dead code, moved to Journey)
33 lines
1.3 KiB
TypeScript
33 lines
1.3 KiB
TypeScript
// FE-COMP-MOBILETOPHEADER-001 to FE-COMP-MOBILETOPHEADER-004
|
|
|
|
import { describe, it, expect } from 'vitest';
|
|
import { render, screen } from '../../../tests/helpers/render';
|
|
import MobileTopHeader from './MobileTopHeader';
|
|
|
|
describe('MobileTopHeader', () => {
|
|
it('FE-COMP-MOBILETOPHEADER-001: renders title as h1', () => {
|
|
render(<MobileTopHeader title="Journeys" />);
|
|
const heading = screen.getByRole('heading', { level: 1 });
|
|
expect(heading).toBeInTheDocument();
|
|
expect(heading.textContent).toBe('Journeys');
|
|
});
|
|
|
|
it('FE-COMP-MOBILETOPHEADER-002: renders subtitle when provided', () => {
|
|
render(<MobileTopHeader title="Journeys" subtitle="3 trips" />);
|
|
expect(screen.getByText('3 trips')).toBeInTheDocument();
|
|
});
|
|
|
|
it('FE-COMP-MOBILETOPHEADER-003: does not render subtitle when omitted', () => {
|
|
const { container } = render(<MobileTopHeader title="Journeys" />);
|
|
const subtitleEl = container.querySelector('.text-xs.text-zinc-500');
|
|
expect(subtitleEl).not.toBeInTheDocument();
|
|
});
|
|
|
|
it('FE-COMP-MOBILETOPHEADER-004: renders action children when provided', () => {
|
|
render(
|
|
<MobileTopHeader title="Trips" actions={<button>Add</button>} />,
|
|
);
|
|
expect(screen.getByRole('button', { name: 'Add' })).toBeInTheDocument();
|
|
});
|
|
});
|