import {QueryClientProvider} from '@tanstack/react-query'; import {OrganizationFixture} from 'sentry-fixture/organization'; import {makeTestQueryClient} from 'sentry-test/queryClient'; import {renderHook, waitFor} from 'sentry-test/reactTestingLibrary'; import * as useOrganization from 'sentry/utils/useOrganization'; import {useTraceMeta} from './useTraceMeta'; const organization = OrganizationFixture(); const queryClient = makeTestQueryClient(); describe('useTraceMeta', () => { beforeEach(function () { queryClient.clear(); jest.clearAllMocks(); jest.spyOn(useOrganization, 'default').mockReturnValue(organization); }); it('Returns merged metaResults', async () => { const traceSlugs = ['slug1', 'slug2', 'slug3']; // Mock the API calls MockApiClient.addMockResponse({ method: 'GET', url: '/organizations/org-slug/events-trace-meta/slug1/', body: { errors: 1, performance_issues: 1, projects: 1, transactions: 1, }, }); MockApiClient.addMockResponse({ method: 'GET', url: '/organizations/org-slug/events-trace-meta/slug2/', body: { errors: 1, performance_issues: 1, projects: 1, transactions: 1, }, }); MockApiClient.addMockResponse({ method: 'GET', url: '/organizations/org-slug/events-trace-meta/slug3/', body: { errors: 1, performance_issues: 1, projects: 1, transactions: 1, }, }); const wrapper = ({children}: {children: React.ReactNode}) => ( {children} ); const {result} = renderHook(() => useTraceMeta(traceSlugs), {wrapper}); expect(result.current).toEqual({ data: undefined, errors: [], isLoading: true, }); await waitFor(() => expect(result.current.isLoading).toBe(false)); expect(result.current).toEqual({ data: { errors: 3, performance_issues: 3, projects: 1, transactions: 3, }, errors: [], isLoading: false, }); }); it('Collects errors from rejected api calls', async () => { const traceSlugs = ['slug1', 'slug2', 'slug3']; // Mock the API calls const mockRequest1 = MockApiClient.addMockResponse({ method: 'GET', url: '/organizations/org-slug/events-trace-meta/slug1/', statusCode: 400, }); const mockRequest2 = MockApiClient.addMockResponse({ method: 'GET', url: '/organizations/org-slug/events-trace-meta/slug2/', statusCode: 400, }); const mockRequest3 = MockApiClient.addMockResponse({ method: 'GET', url: '/organizations/org-slug/events-trace-meta/slug3/', statusCode: 400, }); const wrapper = ({children}: {children: React.ReactNode}) => ( {children} ); const {result} = renderHook(() => useTraceMeta(traceSlugs), {wrapper}); expect(result.current).toEqual({ data: undefined, errors: [], isLoading: true, }); await waitFor(() => expect(result.current.isLoading).toBe(false)); expect(result.current).toEqual({ data: { errors: 0, performance_issues: 0, projects: 0, transactions: 0, }, errors: [expect.any(Error), expect.any(Error), expect.any(Error)], isLoading: false, }); expect(mockRequest1).toHaveBeenCalledTimes(1); expect(mockRequest2).toHaveBeenCalledTimes(1); expect(mockRequest3).toHaveBeenCalledTimes(1); }); it('Accumulates metaResults and collects errors from rejected api calls', async () => { const traceSlugs = ['slug1', 'slug2', 'slug3']; // Mock the API calls const mockRequest1 = MockApiClient.addMockResponse({ method: 'GET', url: '/organizations/org-slug/events-trace-meta/slug1/', statusCode: 400, }); const mockRequest2 = MockApiClient.addMockResponse({ method: 'GET', url: '/organizations/org-slug/events-trace-meta/slug2/', body: { errors: 1, performance_issues: 1, projects: 1, transactions: 1, }, }); const mockRequest3 = MockApiClient.addMockResponse({ method: 'GET', url: '/organizations/org-slug/events-trace-meta/slug3/', body: { errors: 1, performance_issues: 1, projects: 1, transactions: 1, }, }); const wrapper = ({children}: {children: React.ReactNode}) => ( {children} ); const {result} = renderHook(() => useTraceMeta(traceSlugs), {wrapper}); expect(result.current).toEqual({ data: undefined, errors: [], isLoading: true, }); await waitFor(() => expect(result.current.isLoading).toBe(false)); expect(result.current).toEqual({ data: { errors: 2, performance_issues: 2, projects: 1, transactions: 2, }, errors: [expect.any(Error)], isLoading: false, }); expect(mockRequest1).toHaveBeenCalledTimes(1); expect(mockRequest2).toHaveBeenCalledTimes(1); expect(mockRequest3).toHaveBeenCalledTimes(1); }); });