import {ProjectFixture} from 'sentry-fixture/project'; import {ProjectKeysFixture} from 'sentry-fixture/projectKeys'; import {initializeOrg} from 'sentry-test/initializeOrg'; import {render, screen} from 'sentry-test/reactTestingLibrary'; import ProjectsStore from 'sentry/stores/projectsStore'; import type {Project} from 'sentry/types'; import {ProjectInstallPlatform} from 'sentry/views/projectInstall/platform'; type ProjectWithBadPlatform = Omit & { platform: string; }; function mockProjectApiResponses(projects: Array) { MockApiClient.addMockResponse({ method: 'GET', url: '/organizations/org-slug/projects/', body: projects, }); MockApiClient.addMockResponse({ method: 'GET', url: '/projects/org-slug/project-slug/docs/other/', body: {}, }); MockApiClient.addMockResponse({ method: 'GET', url: '/projects/org-slug/project-slug/rules/', body: [], }); MockApiClient.addMockResponse({ method: 'GET', url: '/projects/org-slug/project-slug/', body: projects, }); MockApiClient.addMockResponse({ url: '/projects/org-slug/project-slug/keys/', method: 'GET', body: [ProjectKeysFixture()[0]], }); MockApiClient.addMockResponse({ url: `/projects/org-slug/project-slug/keys/${ProjectKeysFixture()[0].public}/`, method: 'PUT', body: {}, }); } describe('ProjectInstallPlatform', function () { beforeEach(function () { MockApiClient.clearMockResponses(); }); it('should render NotFound if no matching integration/platform', async function () { const routeParams = { projectId: ProjectFixture().slug, }; const {organization, routerProps, project, routerContext} = initializeOrg({ router: { location: { query: {}, }, params: routeParams, }, }); mockProjectApiResponses([{...project, platform: 'lua'}]); render(, { organization, context: routerContext, }); expect(await screen.findByText('Page Not Found')).toBeInTheDocument(); }); it('should display info for a non-supported platform', async function () { const routeParams = { projectId: ProjectFixture().slug, }; const {organization, routerProps, project} = initializeOrg({ router: { location: { query: {}, }, params: routeParams, }, }); // this is needed because we don't handle a loading state in the UI ProjectsStore.loadInitialData([{...project, platform: 'other'}]); mockProjectApiResponses([{...project, platform: 'other'}]); render(, { organization, }); expect( await screen.findByText(/We cannot provide instructions for 'Other' projects/) ).toBeInTheDocument(); }); it('should render getting started docs for correct platform', async function () { const project = ProjectFixture({platform: 'javascript'}); const routeParams = { projectId: project.slug, platform: 'python', }; const {routerProps, routerContext} = initializeOrg({ router: { location: { query: {}, }, params: routeParams, }, }); ProjectsStore.loadInitialData([project]); mockProjectApiResponses([project]); render(, { context: routerContext, }); expect( await screen.findByRole('heading', { name: 'Configure Browser JavaScript SDK', }) ).toBeInTheDocument(); }); });