import {initializeData} from 'sentry-test/performance/initializePerformanceData'; import {act, render, screen} from 'sentry-test/reactTestingLibrary'; import TeamStore from 'sentry/stores/teamStore'; import {OrganizationContext} from 'sentry/views/organizationContext'; import {generatePerformanceEventView} from 'sentry/views/performance/data'; import {PerformanceLanding} from 'sentry/views/performance/landing'; export function addMetricsDataMock(settings?: { metricsCount: number; nullCount: number; unparamCount: number; dynamicSampledProjects?: number[]; }) { const metricsCount = settings?.metricsCount ?? 10; const unparamCount = settings?.unparamCount ?? 0; const nullCount = settings?.nullCount ?? 0; const dynamic_sampling_projects = settings?.dynamicSampledProjects ?? [1]; MockApiClient.addMockResponse({ method: 'GET', url: `/organizations/org-slug/events-metrics-compatibility/`, body: { compatible_projects: [], dynamic_sampling_projects, sum: { metrics: metricsCount, metrics_unparam: unparamCount, metrics_null: nullCount, }, }, }); MockApiClient.addMockResponse({ method: 'GET', url: `/organizations/org-slug/events/`, body: { data: [{}], meta: {}, }, }); } const WrappedComponent = ({data, withStaticFilters = true}) => { const eventView = generatePerformanceEventView(data.router.location, data.projects, { withStaticFilters, }); return ( {}} handleTrendsClick={() => {}} setError={() => {}} withStaticFilters={withStaticFilters} /> ); }; const features = [ 'performance-transaction-name-only-search', 'organizations:performance-transaction-name-only-search', ]; describe('Performance > Landing > MetricsDataSwitcher', function () { let wrapper: any; act(() => void TeamStore.loadInitialData([], false, null)); beforeEach(function () { // @ts-ignore no-console // eslint-disable-next-line no-console jest.spyOn(console, 'error').mockImplementation(jest.fn()); MockApiClient.addMockResponse({ url: '/organizations/org-slug/sdk-updates/', body: [], }); MockApiClient.addMockResponse({ url: '/prompts-activity/', body: {}, }); MockApiClient.addMockResponse({ url: '/organizations/org-slug/projects/', body: [], }); MockApiClient.addMockResponse({ method: 'GET', url: `/organizations/org-slug/key-transactions-list/`, body: [], }); MockApiClient.addMockResponse({ method: 'GET', url: `/organizations/org-slug/legacy-key-transactions-count/`, body: [], }); MockApiClient.addMockResponse({ method: 'GET', url: `/organizations/org-slug/events-stats/`, body: [], }); MockApiClient.addMockResponse({ method: 'GET', url: `/organizations/org-slug/events-trends-stats/`, body: [], }); MockApiClient.addMockResponse({ method: 'GET', url: `/organizations/org-slug/events-histogram/`, body: [], }); MockApiClient.addMockResponse({ method: 'GET', url: `/organizations/org-slug/eventsv2/`, body: { meta: { id: 'string', }, data: [ { id: '1234', }, ], }, }); }); afterEach(function () { MockApiClient.clearMockResponses(); // @ts-ignore no-console // eslint-disable-next-line no-console console.error.mockRestore(); if (wrapper) { wrapper.unmount(); wrapper = undefined; } }); it('renders basic UI elements', function () { addMetricsDataMock(); const project = TestStubs.Project(); const data = initializeData({ project: project.id, projects: [project], features, }); wrapper = render(, data.routerContext); expect(screen.getByTestId('performance-landing-v3')).toBeInTheDocument(); }); it('renders with feature flag and all metric data', async function () { addMetricsDataMock(); const project = TestStubs.Project(); const data = initializeData({ project: project.id, projects: [project], features, }); wrapper = render(, data.routerContext); expect(await screen.findByTestId('transaction-search-bar')).toBeInTheDocument(); }); it('renders with feature flag and no metrics data', async function () { addMetricsDataMock({ metricsCount: 0, nullCount: 0, unparamCount: 0, }); const project = TestStubs.Project(); const data = initializeData({ project: project.id, projects: [project], features, }); wrapper = render(, data.routerContext); expect(await screen.findByTestId('smart-search-bar')).toBeInTheDocument(); }); it('renders with feature flag and checking dynamic sampled projects exist', async function () { addMetricsDataMock({ metricsCount: 100, nullCount: 0, unparamCount: 0, }); const project = TestStubs.Project(); const data = initializeData({ project: project.id, projects: [project], features, }); wrapper = render(, data.routerContext); expect(await screen.findByTestId('transaction-search-bar')).toBeInTheDocument(); }); it('renders with feature flag and any incompatible data', async function () { addMetricsDataMock({ metricsCount: 100, nullCount: 1, unparamCount: 0, }); const project = TestStubs.Project(); const data = initializeData({ project: project.id, projects: [project], features, }); wrapper = render(, data.routerContext); expect(await screen.findByTestId('smart-search-bar')).toBeInTheDocument(); expect( await screen.findByTestId('landing-mep-alert-single-project-incompatible') ).toBeInTheDocument(); }); it('renders with feature flag and any incompatible transactions on multiple projects', async function () { addMetricsDataMock({ metricsCount: 100, nullCount: 1, unparamCount: 0, }); const project = TestStubs.Project({id: 1}); const project2 = TestStubs.Project({id: 2}); const data = initializeData({ project: '-1', projects: [project, project2], features, }); wrapper = render(, data.routerContext); expect(await screen.findByTestId('smart-search-bar')).toBeInTheDocument(); expect( await screen.findByTestId('landing-mep-alert-multi-project-incompatible') ).toBeInTheDocument(); }); it('renders with feature flag and all other(unparam) transactions', async function () { addMetricsDataMock({ metricsCount: 100, nullCount: 0, unparamCount: 100, }); const project = TestStubs.Project(); const data = initializeData({ project: project.id, projects: [project], features, }); wrapper = render(, data.routerContext); expect(await screen.findByTestId('smart-search-bar')).toBeInTheDocument(); expect( await screen.findByTestId('landing-mep-alert-unnamed-discover') ).toBeInTheDocument(); }); it('renders with feature flag and partial other(unparam) transactions and platform with docs', async function () { addMetricsDataMock({ metricsCount: 100, nullCount: 0, unparamCount: 1, }); const platformWithDocs = 'javascript.react'; const project = TestStubs.Project({platform: platformWithDocs}); const data = initializeData({ project: project.id, projects: [project], features, }); wrapper = render(, data.routerContext); expect(await screen.findByTestId('transaction-search-bar')).toBeInTheDocument(); expect( await screen.findByTestId('landing-mep-alert-unnamed-discover-or-set') ).toBeInTheDocument(); }); it('renders with feature flag and partial other(unparam) transactions', async function () { addMetricsDataMock({ metricsCount: 100, nullCount: 0, unparamCount: 1, }); const project = TestStubs.Project(); const data = initializeData({ project: project.id, projects: [project], features, }); wrapper = render(, data.routerContext); expect(await screen.findByTestId('transaction-search-bar')).toBeInTheDocument(); expect( await screen.findByTestId('landing-mep-alert-unnamed-discover') ).toBeInTheDocument(); }); });