import {render, screen, userEvent} from 'sentry-test/reactTestingLibrary';
import {Client} from 'sentry/api';
import OrganizationProjectsContainer from 'sentry/views/settings/organizationProjects';
describe('OrganizationProjects', function () {
let org;
let project;
let projectsGetMock;
let statsGetMock;
let projectsPutMock;
const routerContext = TestStubs.routerContext();
beforeEach(function () {
project = TestStubs.Project();
org = TestStubs.Organization();
projectsGetMock = Client.addMockResponse({
url: '/organizations/org-slug/projects/',
body: [project],
});
statsGetMock = Client.addMockResponse({
url: '/organizations/org-slug/stats/',
body: [[[], 1]],
});
projectsPutMock = Client.addMockResponse({
method: 'PUT',
url: '/projects/org-slug/project-slug/',
});
});
afterEach(function () {
Client.clearMockResponses();
});
it('should render the projects in the store', async function () {
const {container} = render();
expect(container).toSnapshot();
expect(screen.getByText('project-slug')).toBeInTheDocument();
expect(projectsGetMock).toHaveBeenCalledTimes(1);
expect(statsGetMock).toHaveBeenCalledTimes(1);
expect(projectsPutMock).toHaveBeenCalledTimes(0);
await userEvent.click(screen.getByRole('button', {name: 'Bookmark Project'}));
expect(
screen.getByRole('button', {name: 'Bookmark Project', pressed: true})
).toBeInTheDocument();
expect(projectsPutMock).toHaveBeenCalledTimes(1);
});
it('should search organization projects', async function () {
const searchMock = MockApiClient.addMockResponse({
url: `/organizations/${org.slug}/projects/`,
body: [],
});
render(, {
context: routerContext,
});
const searchBox = screen.getByRole('textbox');
await userEvent.type(searchBox, project.slug);
expect(searchMock).toHaveBeenLastCalledWith(
`/organizations/${org.slug}/projects/`,
expect.objectContaining({
method: 'GET',
query: {
query: project.slug,
},
})
);
await userEvent.type(searchBox, '{enter}');
expect(routerContext.context.router.push).toHaveBeenCalledTimes(1);
});
});