waiter-floor-web/src/App.test.tsx
José René White Enciso 124e043a3b feat(waiter-web): add web baseline
Why: establish baseline web runtime scaffold before wave implementation.

What: add react app structure, docker runtime assets, docs runbooks, and ignore policy updates.

Rule: keep technical intent and repository workflow compliance.
2026-03-08 15:53:49 -06:00

32 lines
1020 B
TypeScript

import { fireEvent, render, screen, waitFor } from '@testing-library/react';
import { describe, expect, it, vi } from 'vitest';
vi.mock('./api/dashboardApi', () => ({
loadDashboard: vi.fn()
}));
import { loadDashboard } from './api/dashboardApi';
import App from './App';
describe('App', () => {
it('renders baseline page', () => {
render(<App />);
expect(screen.getByRole('heading', { name: 'Waiter Floor Web' })).toBeInTheDocument();
expect(screen.getByRole('button', { name: 'Load' })).toBeInTheDocument();
});
it('loads dashboard data when user clicks load', async () => {
vi.mocked(loadDashboard).mockResolvedValue({ summary: 'ok' });
render(<App />);
fireEvent.change(screen.getByRole('textbox'), { target: { value: 'ctx stage28' } });
fireEvent.click(screen.getByRole('button', { name: 'Load' }));
await waitFor(() => {
expect(loadDashboard).toHaveBeenCalledWith('ctx stage28');
expect(screen.getByText(/summary/)).toBeInTheDocument();
});
});
});