import { render, screen, act } from '../../../tests/helpers/render'; import userEvent from '@testing-library/user-event'; import { ToastContainer } from './Toast'; describe('ToastContainer', () => { beforeEach(() => { vi.useFakeTimers(); }); afterEach(() => { vi.useRealTimers(); }); function addToast(message: string, type: 'success' | 'error' | 'warning' | 'info' = 'info', duration = 3000) { act(() => { window.__addToast!(message, type, duration); }); } it('FE-COMP-TOAST-001: renders empty container initially', () => { const { container } = render(); // No toast items — only the outer container div expect(container.querySelectorAll('.nomad-toast').length).toBe(0); }); it('FE-COMP-TOAST-002: success toast renders with message', () => { render(); addToast('File saved successfully', 'success'); expect(screen.getByText('File saved successfully')).toBeTruthy(); }); it('FE-COMP-TOAST-003: error toast renders with message', () => { render(); addToast('Something went wrong', 'error'); expect(screen.getByText('Something went wrong')).toBeTruthy(); }); it('FE-COMP-TOAST-004: warning toast renders with message', () => { render(); addToast('Low disk space', 'warning'); expect(screen.getByText('Low disk space')).toBeTruthy(); }); it('FE-COMP-TOAST-005: info toast renders with message', () => { render(); addToast('Update available', 'info'); expect(screen.getByText('Update available')).toBeTruthy(); }); it('FE-COMP-TOAST-006: toast auto-dismisses after duration', () => { render(); addToast('Temporary message', 'info', 2000); expect(screen.getByText('Temporary message')).toBeTruthy(); // After duration + 400ms animation delay, toast is removed act(() => { vi.advanceTimersByTime(2000 + 400 + 10); }); expect(screen.queryByText('Temporary message')).toBeNull(); }); it('FE-COMP-TOAST-007: clicking close button dismisses the toast', () => { const { container } = render(); act(() => { window.__addToast!('Close me', 'success', 0); // duration 0 = no auto-dismiss }); expect(screen.getByText('Close me')).toBeTruthy(); const closeBtn = container.querySelector('.nomad-toast button') as HTMLElement; act(() => { closeBtn.click(); }); // removeToast sets removing: true then schedules removal after 400ms act(() => { vi.advanceTimersByTime(401); }); expect(screen.queryByText('Close me')).toBeNull(); }); it('FE-COMP-TOAST-008: multiple toasts display simultaneously', () => { render(); addToast('First toast', 'success', 0); addToast('Second toast', 'error', 0); addToast('Third toast', 'info', 0); expect(screen.getByText('First toast')).toBeTruthy(); expect(screen.getByText('Second toast')).toBeTruthy(); expect(screen.getByText('Third toast')).toBeTruthy(); }); });