import {OrganizationFixture} from 'sentry-fixture/organization'; import {ProjectFixture} from 'sentry-fixture/project'; import {initializeOrg} from 'sentry-test/initializeOrg'; import {render, screen} from 'sentry-test/reactTestingLibrary'; import type {InjectedRouter} from 'sentry/types/legacyReactRouter'; import EventView from 'sentry/utils/discover/eventView'; import {MEPSettingProvider} from 'sentry/utils/performance/contexts/metricsEnhancedSetting'; import {useLocation} from 'sentry/utils/useLocation'; import {SpanOperationBreakdownFilter} from 'sentry/views/performance/transactionSummary/filter'; import SummaryContent from 'sentry/views/performance/transactionSummary/transactionOverview/content'; jest.mock('sentry/utils/useLocation'); jest.mocked(useLocation).mockReturnValue({ action: 'POP', hash: '', key: 'abc123', pathname: '/organizations/org-slug/performance/', query: {}, search: '', state: undefined, }); function initialize(query, additionalFeatures: string[] = []) { const features = ['transaction-event', 'performance-view', ...additionalFeatures]; const organization = OrganizationFixture({ features, }); const initialData = initializeOrg({ organization, router: { location: { query: {...query}, }, }, projects: [], }); const eventView = EventView.fromNewQueryWithLocation( { id: undefined, version: 2, name: 'test-transaction', fields: ['id', 'user.display', 'transaction.duration', 'trace', 'timestamp'], projects: [], }, initialData.router.location ); const spanOperationBreakdownFilter = SpanOperationBreakdownFilter.NONE; const transactionName = 'example-transaction'; return { ...initialData, spanOperationBreakdownFilter, transactionName, location: initialData.router.location, eventView, }; } function WrappedComponent({ organization, ...props }: React.ComponentProps & { router: InjectedRouter, any>; }) { return ( ); } describe('Transaction Summary Content', function () { beforeEach(function () { MockApiClient.addMockResponse({ method: 'GET', url: '/organizations/org-slug/prompts-activity/', body: {}, }); MockApiClient.addMockResponse({ url: '/organizations/org-slug/sdk-updates/', body: [], }); MockApiClient.addMockResponse({ url: '/organizations/org-slug/events/', body: {data: [{'event.type': 'error'}], meta: {fields: {'event.type': 'string'}}}, }); MockApiClient.addMockResponse({ url: '/organizations/org-slug/users/', body: [], }); MockApiClient.addMockResponse({ url: '/organizations/org-slug/issues/?limit=5&query=is%3Aunresolved%20transaction%3Aexample-transaction&sort=trends&statsPeriod=14d', body: [], }); MockApiClient.addMockResponse({ url: '/organizations/org-slug/events-facets/', body: [], }); MockApiClient.addMockResponse({ url: '/organizations/org-slug/releases/stats/', body: [], }); MockApiClient.addMockResponse({ url: '/organizations/org-slug/events-stats/', body: [], }); MockApiClient.addMockResponse({ url: '/organizations/org-slug/events-facets-performance/', body: {}, }); MockApiClient.addMockResponse({ url: '/organizations/org-slug/events-has-measurements/', body: {measurements: false}, }); MockApiClient.addMockResponse({ url: '/organizations/org-slug/events-spans-performance/', body: [ { op: 'ui.long-task', group: 'c777169faad84eb4', description: 'Main UI thread blocked', frequency: 713, count: 9040, avgOccurrences: null, sumExclusiveTime: 1743893.9822921753, p50ExclusiveTime: null, p75ExclusiveTime: 244.9998779296875, p95ExclusiveTime: null, p99ExclusiveTime: null, }, ], }); MockApiClient.addMockResponse({ url: `/projects/org-slug/project-slug/profiling/functions/`, body: {functions: []}, }); MockApiClient.addMockResponse({ url: '/organizations/org-slug/dynamic-sampling/custom-rules/', body: '', }); MockApiClient.addMockResponse({ url: '/organizations/org-slug/profiling/flamegraph/', body: { activeProfileIndex: 0, metadata: { deviceClassification: '', deviceLocale: '', deviceManufacturer: '', deviceModel: '', deviceOSName: '', deviceOSVersion: '', durationNS: 0, organizationID: 0, platform: '', profileID: '', projectID: 0, received: '0001-01-01T00:00:00Z', sampled: false, timestamp: '0001-01-01T00:00:00Z', traceID: '', transactionID: '', transactionName: '', version: '', }, platform: '', profiles: [ { endValue: 0, isMainThread: true, name: '', samples: [], startValue: 0, threadID: 0, type: 'sampled', unit: 'count', weights: [], sample_durations_ns: null, }, ], projectID: 0, shared: { frames: [], }, transactionName: '', metrics: [], }, }); }); afterEach(function () { MockApiClient.clearMockResponses(); }); it('performs basic rendering', async function () { const project = ProjectFixture(); const { organization, location, eventView, spanOperationBreakdownFilter, transactionName, router, } = initialize({}); render( {}} router={router} />, {router, organization} ); expect( await screen.findByTestId('page-filter-environment-selector') ).toBeInTheDocument(); expect(screen.getByTestId('page-filter-timerange-selector')).toBeInTheDocument(); expect(screen.getByTestId('smart-search-bar')).toBeInTheDocument(); expect(screen.getByTestId('transaction-summary-charts')).toBeInTheDocument(); expect(screen.getByRole('heading', {name: /user misery/i})).toBeInTheDocument(); expect(screen.getByRole('heading', {name: /status breakdown/i})).toBeInTheDocument(); expect(screen.getByRole('heading', {name: /apdex/i})).toBeInTheDocument(); expect(screen.getByTestId('apdex-summary-value')).toBeInTheDocument(); expect(screen.getByRole('heading', {name: /failure rate/i})).toBeInTheDocument(); expect(screen.getByTestId('failure-rate-summary-value')).toBeInTheDocument(); }); });