import { describe, it, expect, beforeEach, vi } from 'vitest'; import { renderHook, waitFor } from '@testing-library/react'; import { QueryClient, QueryClientProvider } from '@tanstack/react-query'; import type { ReactNode } from 'react'; import { useEnvironmentStore } from '../environment-store'; vi.mock('../client', () => ({ api: { GET: vi.fn(), POST: vi.fn() }, })); import { api as apiClient } from '../client'; import { useAlerts, useUnreadCount } from './alerts'; function wrapper({ children }: { children: ReactNode }) { const qc = new QueryClient({ defaultOptions: { queries: { retry: false } } }); return {children}; } describe('useAlerts', () => { beforeEach(() => { vi.clearAllMocks(); useEnvironmentStore.setState({ environment: 'dev' }); }); it('fetches up to 200 alerts for selected env (no server-side filter params)', async () => { // Backend AlertController.list accepts only `limit`; state/severity are // dropped server-side. We therefore fetch once per env and filter // client-side via react-query `select`. (apiClient.GET as any).mockResolvedValue({ data: [], error: null }); const { result } = renderHook( () => useAlerts({ state: 'FIRING', severity: ['CRITICAL', 'WARNING'] }), { wrapper }, ); await waitFor(() => expect(result.current.isSuccess).toBe(true)); expect(apiClient.GET).toHaveBeenCalledWith( '/environments/{envSlug}/alerts', expect.objectContaining({ params: expect.objectContaining({ path: { envSlug: 'dev' }, query: { limit: 200 }, }), }), ); }); it('applies state + severity filters client-side via select', async () => { const dataset = [ { id: '1', state: 'FIRING', severity: 'CRITICAL', title: 'a' }, { id: '2', state: 'FIRING', severity: 'WARNING', title: 'b' }, { id: '3', state: 'ACKNOWLEDGED', severity: 'CRITICAL', title: 'c' }, { id: '4', state: 'RESOLVED', severity: 'INFO', title: 'd' }, ]; (apiClient.GET as any).mockResolvedValue({ data: dataset, error: null }); const { result } = renderHook( () => useAlerts({ state: ['FIRING'], severity: ['CRITICAL', 'WARNING'] }), { wrapper }, ); await waitFor(() => expect(result.current.isSuccess).toBe(true)); const ids = (result.current.data ?? []).map((a: any) => a.id); expect(ids).toEqual(['1', '2']); }); it('does not fetch when no env is selected', () => { useEnvironmentStore.setState({ environment: undefined }); const { result } = renderHook(() => useAlerts(), { wrapper }); expect(result.current.fetchStatus).toBe('idle'); expect(apiClient.GET).not.toHaveBeenCalled(); }); }); describe('useUnreadCount', () => { beforeEach(() => { vi.clearAllMocks(); useEnvironmentStore.setState({ environment: 'dev' }); }); it('returns the server payload unmodified', async () => { (apiClient.GET as any).mockResolvedValue({ data: { count: 3 }, error: null, }); const { result } = renderHook(() => useUnreadCount(), { wrapper }); await waitFor(() => expect(result.current.isSuccess).toBe(true)); expect(result.current.data).toEqual({ count: 3 }); }); });