123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132 |
- 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(<SpanMetricsTable transactionName="Test Transaction" project={project} />);
- 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(<SpanMetricsTable transactionName="Test Transaction" project={project} />);
- 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,
- };
- }
|