import selectEvent from 'react-select-event';
import {render, screen, userEvent} from 'sentry-test/reactTestingLibrary';
import MemberListStore from 'sentry/stores/memberListStore';
import OwnerInput from 'sentry/views/settings/project/projectOwnership/ownerInput';
describe('Project Ownership Input', function () {
let org;
let project;
let put;
beforeEach(function () {
org = TestStubs.Organization();
project = TestStubs.Project();
MockApiClient.addMockResponse({
url: '/organizations/org-slug/members/',
method: 'GET',
body: TestStubs.Members(),
});
put = MockApiClient.addMockResponse({
url: `/projects/${org.slug}/${project.slug}/ownership/`,
method: 'PUT',
body: {raw: 'url:src @dummy@example.com'},
});
MemberListStore.init();
MemberListStore.loadInitialData([
TestStubs.User({id: '1', email: 'bob@example.com'}),
]);
});
it('renders', async function () {
const {container} = render(
);
const submitButton = screen.getByRole('button', {name: 'Save'});
expect(put).not.toHaveBeenCalled();
// if text is unchanged, submit button is disabled
await userEvent.click(submitButton);
expect(put).not.toHaveBeenCalled();
const textarea = screen.getByRole('textbox', {name: 'Ownership Rules'});
await userEvent.clear(textarea);
await userEvent.type(textarea, 'new');
await userEvent.click(submitButton);
expect(put).toHaveBeenCalled();
expect(container).toSnapshot();
});
it('updates on add preserving existing text', async function () {
render(
);
// Set a path, as path is selected bu default.
await userEvent.type(screen.getByRole('textbox', {name: 'Rule pattern'}), 'file.js');
// Select the user.
await selectEvent.select(
screen.getByRole('textbox', {name: 'Rule owner'}),
'Foo Bar'
);
// Add the new rule.
await userEvent.click(screen.getByRole('button', {name: 'Add rule'}));
expect(put).toHaveBeenCalledWith(
'/projects/org-slug/project-slug/ownership/',
expect.objectContaining({
data: {
raw: 'url:src @dummy@example.com' + '\n' + 'path:file.js bob@example.com',
},
})
);
});
});