import React from 'react'; import { describe, expect, it, vi } from 'vitest'; import { render, screen } from '@testing-library/react'; import { EventDataProvider } from '../context/EventDataContext'; vi.mock('@tamagui/stacks', () => ({ YStack: ({ children }: { children: React.ReactNode }) =>
{children}
, XStack: ({ children }: { children: React.ReactNode }) =>
{children}
, })); vi.mock('@tamagui/text', () => ({ SizableText: ({ children }: { children: React.ReactNode }) => {children}, })); vi.mock('@tamagui/button', () => ({ Button: ({ children, ...rest }: { children: React.ReactNode }) => ( ), })); vi.mock('@tamagui/sheet', () => { const Sheet = ({ children }: { children: React.ReactNode }) =>
{children}
; Sheet.Overlay = ({ children }: { children?: React.ReactNode }) =>
{children}
; Sheet.Frame = ({ children }: { children?: React.ReactNode }) =>
{children}
; Sheet.Handle = ({ children }: { children?: React.ReactNode }) =>
{children}
; return { Sheet }; }); vi.mock('react-router-dom', () => ({ useNavigate: () => vi.fn(), useSearchParams: () => [new URLSearchParams(), vi.fn()], })); vi.mock('lucide-react', () => ({ Image: () => image, Filter: () => filter, Camera: () => camera, Grid2x2: () => grid, Zap: () => zap, UploadCloud: () => upload, ListVideo: () => list, RefreshCcw: () => refresh, FlipHorizontal: () => flip, X: () => close, Sparkles: () => sparkles, Trophy: () => trophy, Play: () => play, Share2: () => share, MessageSquare: () => message, Copy: () => copy, ChevronLeft: () => chevron-left, ChevronRight: () => chevron-right, QrCode: () => qr, Link: () => link, Users: () => users, Heart: () => heart, })); vi.mock('../components/AppShell', () => ({ default: ({ children }: { children: React.ReactNode }) =>
{children}
, })); vi.mock('../context/EventDataContext', () => ({ EventDataProvider: ({ children }: { children: React.ReactNode }) => <>{children}, useEventData: () => ({ token: 'demo', tasksEnabled: true, event: null }), })); vi.mock('../services/uploadApi', () => ({ useUploadQueue: () => ({ items: [], loading: false, add: vi.fn() }), uploadPhoto: vi.fn(), })); vi.mock('@/guest/services/pendingUploadsApi', () => ({ fetchPendingUploadsSummary: vi.fn().mockResolvedValue({ items: [], totalCount: 0 }), })); vi.mock('../services/photosApi', () => ({ fetchGallery: vi.fn().mockResolvedValue({ data: [], next_cursor: null, latest_photo_at: null, notModified: false }), fetchPhoto: vi.fn().mockResolvedValue(null), likePhoto: vi.fn().mockResolvedValue(0), unlikePhoto: vi.fn().mockResolvedValue(0), createPhotoShareLink: vi.fn().mockResolvedValue({ url: null }), })); vi.mock('../hooks/usePollGalleryDelta', () => ({ usePollGalleryDelta: () => ({ data: { photos: [], latestPhotoAt: null, nextCursor: null }, loading: false, error: null }), })); vi.mock('@/guest/i18n/useTranslation', () => ({ useTranslation: () => ({ t: (key: string, arg2?: Record | string, arg3?: string) => typeof arg2 === 'string' || arg2 === undefined ? (arg2 ?? arg3 ?? key) : (arg3 ?? key), locale: 'de', }), })); vi.mock('@/guest/i18n/LocaleContext', () => ({ useLocale: () => ({ locale: 'de', availableLocales: [], setLocale: vi.fn() }), })); vi.mock('@/hooks/use-appearance', () => ({ useAppearance: () => ({ resolved: 'light' }), })); vi.mock('../services/tasksApi', () => ({ fetchTasks: vi.fn().mockResolvedValue([]), })); vi.mock('../services/emotionsApi', () => ({ fetchEmotions: vi.fn().mockResolvedValue([]), })); vi.mock('../hooks/usePollStats', () => ({ usePollStats: () => ({ stats: { onlineGuests: 0, tasksSolved: 0, guestCount: 0, likesCount: 0, latestPhotoAt: null, }, }), })); vi.mock('../services/qrApi', () => ({ fetchEventQrCode: () => Promise.resolve({ qr_code_data_url: null }), })); vi.mock('@/guest/hooks/useGuestTaskProgress', () => ({ useGuestTaskProgress: () => ({ completedCount: 0 }), })); import GalleryScreen from '../screens/GalleryScreen'; import UploadScreen from '../screens/UploadScreen'; import TasksScreen from '../screens/TasksScreen'; import ShareScreen from '../screens/ShareScreen'; describe('Guest v2 screens copy', () => { it('renders gallery header', () => { render( ); expect(screen.getByText('Neues Foto hochladen')).toBeInTheDocument(); }); it('renders upload preview prompt', () => { render( ); expect(screen.getByText('Camera')).toBeInTheDocument(); }); it('renders tasks quest when enabled', () => { render( ); expect(screen.getByText('Mission hub')).toBeInTheDocument(); }); it('renders share hub header', () => { render( ); expect(screen.getByText('Invite guests')).toBeInTheDocument(); }); });