import React from 'react'; import { describe, expect, it, vi } from 'vitest'; import { render, screen } from '@testing-library/react'; import { LocaleProvider } from '@/guest/i18n/LocaleContext'; vi.mock('react-router-dom', () => ({ useNavigate: () => vi.fn(), })); 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/input', () => ({ Input: ({ ...rest }: { [key: string]: unknown }) => , })); vi.mock('@tamagui/card', () => ({ Card: ({ children }: { children: React.ReactNode }) =>
{children}
, })); vi.mock('html5-qrcode', () => ({ Html5Qrcode: vi.fn().mockImplementation(() => ({ start: vi.fn(), stop: vi.fn(), })), })); vi.mock('lucide-react', () => ({ QrCode: () => qr, ArrowRight: () => arrow, })); import LandingScreen from '../screens/LandingScreen'; describe('LandingScreen', () => { it('renders join panel copy', () => { render( ); expect(screen.getByRole('button', { name: 'Event beitreten' })).toBeInTheDocument(); expect(screen.getAllByText('Event beitreten').length).toBeGreaterThan(1); expect(screen.getByPlaceholderText('Event-Code eingeben')).toBeInTheDocument(); }); });