/** * Tests for Admin Dashboard Page * Verifies rendering of admin dashboard with stats and quick actions */ import { render, screen } from '@testing-library/react'; import AdminPage from '@/app/[locale]/admin/page'; import { useAdminStats } from '@/lib/api/hooks/useAdmin'; // Mock the useAdminStats hook jest.mock('@/lib/api/hooks/useAdmin'); // Mock chart components jest.mock('@/components/charts', () => ({ UserGrowthChart: () =>
User Growth Chart
, OrganizationDistributionChart: () => (
Org Distribution Chart
), SessionActivityChart: () => (
Session Activity Chart
), UserStatusChart: () =>
User Status Chart
, })); const mockUseAdminStats = useAdminStats as jest.MockedFunction; // Helper function to render with default mocked stats function renderWithMockedStats() { mockUseAdminStats.mockReturnValue({ data: { totalUsers: 100, activeUsers: 80, totalOrganizations: 20, totalSessions: 30, }, isLoading: false, isError: false, error: null, } as any); return render(); } describe('AdminPage', () => { beforeEach(() => { jest.clearAllMocks(); }); it('renders admin dashboard title', () => { renderWithMockedStats(); expect(screen.getByText('Admin Dashboard')).toBeInTheDocument(); }); it('renders description text', () => { renderWithMockedStats(); expect( screen.getByText('Manage users, organizations, and system settings') ).toBeInTheDocument(); }); it('renders quick actions section', () => { renderWithMockedStats(); expect(screen.getByText('Quick Actions')).toBeInTheDocument(); }); it('renders user management card', () => { renderWithMockedStats(); expect(screen.getByText('User Management')).toBeInTheDocument(); expect(screen.getByText('View, create, and manage user accounts')).toBeInTheDocument(); }); it('renders organizations card', () => { renderWithMockedStats(); // Check for the quick actions card (not the stat card) expect(screen.getByText('Manage organizations and their members')).toBeInTheDocument(); }); it('renders system settings card', () => { renderWithMockedStats(); expect(screen.getByText('System Settings')).toBeInTheDocument(); expect(screen.getByText('Configure system-wide settings')).toBeInTheDocument(); }); it('renders quick actions in grid layout', () => { renderWithMockedStats(); // Check for Quick Actions heading which is above the grid expect(screen.getByText('Quick Actions')).toBeInTheDocument(); // Verify all three quick action cards are present expect(screen.getByText('User Management')).toBeInTheDocument(); expect(screen.getByText('System Settings')).toBeInTheDocument(); }); it('renders with proper container structure', () => { const { container } = renderWithMockedStats(); const containerDiv = container.querySelector('.container'); expect(containerDiv).toBeInTheDocument(); expect(containerDiv).toHaveClass('mx-auto', 'px-6', 'py-8'); }); it('renders analytics overview section', () => { renderWithMockedStats(); expect(screen.getByText('Analytics Overview')).toBeInTheDocument(); }); it('renders all chart components', () => { renderWithMockedStats(); expect(screen.getByTestId('user-growth-chart')).toBeInTheDocument(); expect(screen.getByTestId('org-distribution-chart')).toBeInTheDocument(); expect(screen.getByTestId('session-activity-chart')).toBeInTheDocument(); expect(screen.getByTestId('user-status-chart')).toBeInTheDocument(); }); });