import {initializeData as _initializeData} from 'sentry-test/performance/initializePerformanceData'; import {act, render, screen, waitFor} from 'sentry-test/reactTestingLibrary'; import ProjectsStore from 'sentry/stores/projectsStore'; import SpanMetricsTable from 'sentry/views/performance/transactionSummary/transactionSpans/spanMetricsTable'; const initializeData = () => { const data = _initializeData({ features: ['performance-view'], }); act(() => ProjectsStore.loadInitialData(data.organization.projects)); return data; }; describe('SuspectSpansTable', () => { it('should render the table and rows of data', async () => { const {organization, project} = initializeData(); const mockRequest = MockApiClient.addMockResponse({ url: `/organizations/${organization.slug}/events/`, method: 'GET', body: { data: [ { 'span.group': 'abc123', 'span.op': 'db', 'span.description': 'SELECT thing FROM my_cool_db', 'spm()': 4.448963396488444, 'sum(span.self_time)': 1236071121.5044901, 'avg(span.duration)': 30900.700924083318, }, ], }, }); render(); await waitFor(() => expect(screen.queryByTestId('loading-indicator')).not.toBeInTheDocument() ); expect(mockRequest).toHaveBeenCalled(); const { opHeader, descriptionHeader, throughputHeader, avgDurationHeader, timeSpentHeader, } = await findTableHeaders(); expect(opHeader).toHaveTextContent('Span Operation'); expect(descriptionHeader).toHaveTextContent('Span Description'); expect(throughputHeader).toHaveTextContent('Throughput'); expect(avgDurationHeader).toHaveTextContent('Avg Duration'); expect(timeSpentHeader).toHaveTextContent('Time Spent'); const {opCell, descriptionCell, throughputCell, avgDurationCell, timeSpentCell} = await findFirstRowCells(); expect(opCell).toHaveTextContent('db'); expect(descriptionCell).toHaveTextContent('SELECT thing FROM my_cool_db'); expect(throughputCell).toHaveTextContent('4.45/s'); expect(avgDurationCell).toHaveTextContent('30.90s'); expect(timeSpentCell).toHaveTextContent('2.04wk'); }); it('should handle the case when there is no span grouping', async () => { const {organization, project} = initializeData(); const mockRequest = MockApiClient.addMockResponse({ url: `/organizations/${organization.slug}/events/`, method: 'GET', body: { data: [ { 'span.op': 'db', 'spm()': 5000, 'sum(span.self_time)': 12346071121.5044901, 'avg(span.duration)': 30900.700924083318, }, ], }, }); render(); await waitFor(() => expect(screen.queryByTestId('loading-indicator')).not.toBeInTheDocument() ); expect(mockRequest).toHaveBeenCalled(); const {opCell, descriptionCell} = await findFirstRowCells(); expect(opCell).toHaveTextContent('db'); expect(descriptionCell).toHaveTextContent('\u2014'); }); }); async function findTableHeaders() { const tableHeaders = await screen.findAllByTestId('grid-head-cell'); const [ opHeader, descriptionHeader, throughputHeader, avgDurationHeader, timeSpentHeader, ] = tableHeaders; return { opHeader, descriptionHeader, throughputHeader, avgDurationHeader, timeSpentHeader, }; } async function findFirstRowCells() { const bodyCells = await screen.findAllByTestId('grid-body-cell'); const [opCell, descriptionCell, throughputCell, avgDurationCell, timeSpentCell] = bodyCells; return { opCell, descriptionCell, throughputCell, avgDurationCell, timeSpentCell, }; }