import {initializeOrg} from 'sentry-test/initializeOrg';
import {render, screen, waitFor} from 'sentry-test/reactTestingLibrary';
import ProjectsStore from 'sentry/stores/projectsStore';
import {Project} from 'sentry/types';
import {ProjectInstallPlatform} from 'sentry/views/projectInstall/platform';
function mockProjectApiResponses(projects: Project[]) {
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: [TestStubs.ProjectKeys()[0]],
});
MockApiClient.addMockResponse({
url: `/projects/org-slug/project-slug/keys/${TestStubs.ProjectKeys()[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: TestStubs.Project().slug,
};
const {organization, router, route, 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 redirect to neutral docs if no matching platform', async function () {
const routeParams = {
projectId: TestStubs.Project().slug,
};
const {organization, router, route, project, routerContext} = 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,
context: routerContext,
}
);
await waitFor(() => {
expect(router.push).toHaveBeenCalledTimes(1);
});
});
it('should render getting started docs for correct platform', async function () {
const project = TestStubs.Project({platform: 'javascript'});
const routeParams = {
projectId: project.slug,
platform: 'python',
};
const {router, route, routerContext} = initializeOrg({
router: {
location: {
query: {},
},
params: routeParams,
},
});
ProjectsStore.loadInitialData([project]);
mockProjectApiResponses([project]);
render(
,
{
context: routerContext,
}
);
expect(
await screen.findByRole('heading', {
name: 'Configure JavaScript SDK',
})
).toBeInTheDocument();
});
});