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);
});
});