import {LocationFixture} from 'sentry-fixture/locationFixture'; import {render, screen, userEvent} from 'sentry-test/reactTestingLibrary'; import type {NewQuery} from 'sentry/types/organization'; import {browserHistory} from 'sentry/utils/browserHistory'; import EventView from 'sentry/utils/discover/eventView'; import {EventSamplesTable} from 'sentry/views/performance/mobile/screenload/screenLoadSpans/eventSamplesTable'; describe('EventSamplesTable', function () { let mockLocation, mockQuery: NewQuery, mockEventView; beforeEach(function () { mockLocation = LocationFixture({ query: { statsPeriod: '99d', }, }); mockQuery = { name: '', fields: ['transaction.id'], query: '', version: 2, }; mockEventView = EventView.fromNewQueryWithLocation(mockQuery, mockLocation); }); it('uses a column name map to render column names', function () { mockQuery = { name: '', fields: ['rawField'], query: '', version: 2, }; mockEventView = EventView.fromNewQueryWithLocation(mockQuery, mockLocation); render( ); expect(screen.getByText('Readable Column Name')).toBeInTheDocument(); expect(screen.queryByText('rawField')).not.toBeInTheDocument(); }); it('uses the event ID key to get the event ID from the data payload', function () { mockQuery = { name: '', fields: ['transaction.id'], query: '', version: 2, }; mockEventView = EventView.fromNewQueryWithLocation(mockQuery, mockLocation); render( ); // Test only one column to isolate event ID expect(screen.getAllByRole('columnheader')).toHaveLength(1); expect(screen.getByRole('columnheader', {name: 'Event ID'})).toBeInTheDocument(); expect(screen.getByText('abc')).toBeInTheDocument(); expect(screen.queryByText('1')).not.toBeInTheDocument(); }); it('uses the profile ID key to get the profile ID from the data payload and display an icon button', async function () { mockQuery = { name: '', fields: ['profile.id', 'project.name'], // Project name is required to form the profile target query: '', version: 2, }; mockEventView = EventView.fromNewQueryWithLocation(mockQuery, mockLocation); render( ); // Test only one column to isolate profile column expect(screen.getAllByRole('columnheader')).toHaveLength(1); expect(screen.getByRole('columnheader', {name: 'Profile'})).toBeInTheDocument(); expect(await screen.findByRole('button', {name: 'View Profile'})).toBeInTheDocument(); }); it('updates URL params when device class selector is changed', async function () { mockQuery = { name: '', fields: ['transaction.id'], query: '', version: 2, }; mockEventView = EventView.fromNewQueryWithLocation(mockQuery, mockLocation); render( ); expect(screen.getByRole('button', {name: /device class all/i})).toBeInTheDocument(); await userEvent.click(screen.getByRole('button', {name: /device class all/i})); await userEvent.click(screen.getByText('Medium')); expect(browserHistory.push).toHaveBeenCalledWith( expect.objectContaining({ pathname: '/mock-pathname/', query: expect.objectContaining({ 'device.class': 'medium', }), }) ); }); it('updates URL params when the table is paginated', async function () { const pageLinks = '; rel="previous"; results="false"; cursor="0:0:1", ' + '; rel="next"; results="true"; cursor="0:20:0"'; render( ); expect(screen.getByRole('button', {name: 'Next'})).toBeInTheDocument(); await userEvent.click(screen.getByRole('button', {name: 'Next'})); expect(browserHistory.push).toHaveBeenCalledWith( expect.objectContaining({ pathname: '/mock-pathname/', query: expect.objectContaining({ customCursorName: '0:20:0', }), }) ); }); it('uses a custom sort key for sortable headers', async function () { mockQuery = { name: '', fields: ['transaction.id', 'duration'], query: '', version: 2, }; mockEventView = EventView.fromNewQueryWithLocation(mockQuery, mockLocation); render( ); // Ascending sort in transaction ID because the default is descending expect(await screen.findByRole('link', {name: 'Event ID'})).toHaveAttribute( 'href', '/mock-pathname/?customSortKey=transaction.id' ); expect(screen.getByRole('link', {name: 'Duration'})).toHaveAttribute( 'href', '/mock-pathname/?customSortKey=-duration' ); }); it('only displays data for the columns defined in the name map', async function () { mockQuery = { name: '', fields: ['transaction.id', 'duration'], query: '', version: 2, }; mockEventView = EventView.fromNewQueryWithLocation(mockQuery, mockLocation); render( ); // Although ID is queried for, because it's not defined in the map // it isn't rendered expect( await screen.findByRole('columnheader', {name: 'Duration'}) ).toBeInTheDocument(); expect(screen.getAllByRole('columnheader')).toHaveLength(1); }); });