import {render, screen, userEvent, within} from 'sentry-test/reactTestingLibrary'; import QuickTraceMeta from 'sentry/views/performance/transactionDetails/quickTraceMeta'; describe('QuickTraceMeta', function () { const routerContext = TestStubs.routerContext(); const location = routerContext.context.location; const organization = TestStubs.Organization({features: ['performance-view']}); const project = TestStubs.Project({platform: 'javascript'}); const event = TestStubs.Event({contexts: {trace: {trace_id: 'a'.repeat(32)}}}); const emptyQuickTrace = { isLoading: false, error: null, trace: [], type: 'empty', currentEvent: null, }; const emptyTraceMeta = { projects: 0, transactions: 0, errors: 0, }; it('renders basic UI', function () { render( ); expect(screen.getByRole('heading', {name: 'Trace Navigator'})).toBeInTheDocument(); expect(screen.getByTestId('quick-trace-body')).toBeInTheDocument(); expect(screen.getByTestId('quick-trace-footer')).toHaveTextContent( `View Full Trace: ${'a'.repeat(8)} (0 events)` ); }); it('renders placeholder while loading', function () { render( ); expect(screen.getByRole('heading', {name: 'Trace Navigator'})).toBeInTheDocument(); const qtBody = screen.getByTestId('quick-trace-body'); expect(within(qtBody).getByTestId('loading-placeholder')).toBeInTheDocument(); expect(screen.getByTestId('quick-trace-footer')).toHaveTextContent( `View Full Trace: ${'a'.repeat(8)} (0 events)` ); }); it('renders errors', function () { render( ); expect(screen.getByRole('heading', {name: 'Trace Navigator'})).toBeInTheDocument(); expect(screen.getByTestId('quick-trace-body')).toHaveTextContent('\u2014'); expect(screen.getByTestId('quick-trace-footer')).toHaveTextContent( `View Full Trace: ${'a'.repeat(8)} (0 events)` ); }); it('renders missing trace when trace id is not present', function () { const newEvent = TestStubs.Event(); render( ); expect(screen.getByRole('heading', {name: 'Trace Navigator'})).toBeInTheDocument(); expect(screen.getByTestId('quick-trace-body')).toHaveTextContent('Missing Trace'); expect(screen.getByTestId('quick-trace-footer')).toHaveTextContent('Read the docs'); }); it('renders missing trace with hover card when feature disabled', async function () { const newEvent = TestStubs.Event(); const newOrg = TestStubs.Organization(); render( , {context: routerContext} ); expect(screen.getByRole('heading', {name: 'Trace Navigator'})).toBeInTheDocument(); expect(screen.getByTestId('quick-trace-body')).toHaveTextContent('Missing Trace'); const qtFooter = screen.getByTestId('quick-trace-footer'); expect(qtFooter).toHaveTextContent('Read the docs'); await userEvent.hover(qtFooter.firstChild); expect( await screen.findByText('Requires performance monitoring.') ).toBeInTheDocument(); }); it('does not render when platform does not support tracing', function () { const newProject = TestStubs.Project(); const newEvent = TestStubs.Event(); const result = render( ); expect(result.container).toBeEmptyDOMElement(); }); });