import {ProjectFixture} from 'sentry-fixture/project'; import {render, screen} from 'sentry-test/reactTestingLibrary'; import usePageFilters from 'sentry/utils/usePageFilters'; import useProjects from 'sentry/utils/useProjects'; import {useOnboardingProject} from 'sentry/views/insights/common/queries/useOnboardingProject'; import {ModuleName} from 'sentry/views/insights/types'; import {ModulesOnboarding} from './modulesOnboarding'; jest.mock('sentry/utils/useProjects'); jest.mock('sentry/utils/usePageFilters'); jest.mock('sentry/views/insights/common/queries/useOnboardingProject'); describe('ModulesOnboarding', () => { afterEach(() => { jest.resetAllMocks(); }); it('renders children correctly', async () => { const project = ProjectFixture({hasInsightsCaches: true}); project.firstTransactionEvent = true; project.hasInsightsCaches = true; jest.mocked(useProjects).mockReturnValue({ projects: [project], onSearch: jest.fn(), placeholders: [], fetching: false, hasMore: null, fetchError: null, initiallyLoaded: false, }); jest.mocked(useOnboardingProject).mockReturnValue(undefined); jest.mocked(usePageFilters).mockReturnValue({ isReady: true, desyncedFilters: new Set(), pinnedFilters: new Set(), shouldPersist: true, selection: { datetime: { period: '10d', start: null, end: null, utc: false, }, environments: [], projects: [2], }, }); render(
Module Content
); await screen.getByText('Module Content'); }); it('renders onboarding content correctly', async () => { const project = ProjectFixture(); jest.mocked(useProjects).mockReturnValue({ projects: [project], onSearch: jest.fn(), placeholders: [], fetching: false, hasMore: null, fetchError: null, initiallyLoaded: false, }); jest.mocked(usePageFilters).mockReturnValue({ isReady: true, desyncedFilters: new Set(), pinnedFilters: new Set(), shouldPersist: true, selection: { datetime: { period: '10d', start: null, end: null, utc: false, }, environments: [], projects: [2], }, }); render(
Module Content
); await screen.findByText('Bringing you one less hard problem in computer science'); }); it('renders performance onboarding if onboardingProject', async () => { const project = ProjectFixture(); jest.mocked(useOnboardingProject).mockReturnValue(project); jest.mocked(useProjects).mockReturnValue({ projects: [project], onSearch: jest.fn(), placeholders: [], fetching: false, hasMore: null, fetchError: null, initiallyLoaded: false, }); jest.mocked(usePageFilters).mockReturnValue({ isReady: true, desyncedFilters: new Set(), pinnedFilters: new Set(), shouldPersist: true, selection: { datetime: { period: '10d', start: null, end: null, utc: false, }, environments: [], projects: [2], }, }); render(
Module Content
); await screen.findByText('Pinpoint problems'); }); });