123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130 |
- import {ProjectFixture} from 'sentry-fixture/project';
- import {UserFixture} from 'sentry-fixture/user';
- import {initializeOrg} from 'sentry-test/initializeOrg';
- import {render, screen, userEvent} from 'sentry-test/reactTestingLibrary';
- import type {EventViewOptions} from 'sentry/utils/discover/eventView';
- import EventView from 'sentry/utils/discover/eventView';
- import {getCustomEventsFieldRenderer} from 'sentry/views/dashboards/datasetConfig/errorsAndTransactions';
- describe('getCustomFieldRenderer', function () {
- const {organization, router, routerContext} = initializeOrg();
- const baseEventViewOptions: EventViewOptions = {
- start: undefined,
- end: undefined,
- createdBy: UserFixture(),
- display: undefined,
- fields: [],
- sorts: [],
- query: '',
- project: [],
- environment: [],
- yAxis: 'count()',
- id: undefined,
- name: undefined,
- statsPeriod: '14d',
- team: [],
- topEvents: undefined,
- };
- it('links trace ids to performance', async function () {
- const customFieldRenderer = getCustomEventsFieldRenderer('trace', {});
- render(
- customFieldRenderer(
- {trace: 'abcd'},
- {
- organization,
- location: router.location,
- eventView: new EventView({
- ...baseEventViewOptions,
- fields: [{field: 'trace'}],
- }),
- }
- ) as React.ReactElement<any, any>,
- {context: routerContext}
- );
- await userEvent.click(await screen.findByText('abcd'));
- expect(router.push).toHaveBeenCalledWith({
- pathname: '/organizations/org-slug/performance/trace/abcd/',
- query: {
- pageEnd: undefined,
- pageStart: undefined,
- statsPeriod: '14d',
- },
- });
- });
- it('links event ids to event details', async function () {
- const project = ProjectFixture();
- const customFieldRenderer = getCustomEventsFieldRenderer('id', {});
- render(
- customFieldRenderer(
- {id: 'defg', 'project.name': project.slug},
- {
- organization,
- location: router.location,
- eventView: new EventView({
- ...baseEventViewOptions,
- fields: [{field: 'id'}],
- project: [parseInt(project.id, 10)],
- }),
- }
- ) as React.ReactElement<any, any>,
- {context: routerContext}
- );
- await userEvent.click(await screen.findByText('defg'));
- expect(router.push).toHaveBeenCalledWith({
- pathname: `/organizations/org-slug/discover/${project.slug}:defg/`,
- query: {
- display: undefined,
- environment: [],
- field: ['id'],
- id: undefined,
- interval: undefined,
- name: undefined,
- project: [parseInt(project.id, 10)],
- query: '',
- sort: [],
- topEvents: undefined,
- widths: [],
- yAxis: 'count()',
- pageEnd: undefined,
- pageStart: undefined,
- statsPeriod: '14d',
- },
- });
- });
- it('links << unparameterized >> title/transaction columns to event details', async function () {
- const project = ProjectFixture();
- const customFieldRenderer = getCustomEventsFieldRenderer('title', {});
- render(
- customFieldRenderer(
- {title: '<< unparameterized >>'},
- {
- organization,
- location: router.location,
- eventView: new EventView({
- ...baseEventViewOptions,
- fields: [{field: 'id'}],
- project: [parseInt(project.id, 10)],
- }),
- }
- ) as React.ReactElement<any, any>,
- {context: routerContext}
- );
- await userEvent.click(await screen.findByText('<< unparameterized >>'));
- expect(router.push).toHaveBeenCalledWith(
- expect.objectContaining({
- pathname: `/organizations/org-slug/discover/results/`,
- query: expect.objectContaining({
- query: 'event.type:transaction transaction.source:"url"',
- }),
- })
- );
- });
- });
|