import {mountWithTheme} from 'sentry-test/enzyme';
import {selectByValueAsync} from 'sentry-test/select-new';
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'}),
]);
});
afterEach(() => {
MemberListStore.teardown();
});
it('renders', function () {
const wrapper = mountWithTheme(
);
const submit = wrapper.find('SaveButton button');
expect(put).not.toHaveBeenCalled();
// if text is unchanged, submit button is disabled
submit.simulate('click');
expect(put).not.toHaveBeenCalled();
wrapper.find('StyledTextArea').simulate('change', {target: {value: 'new'}});
submit.simulate('click');
expect(put).toHaveBeenCalled();
expect(wrapper.find(OwnerInput)).toSnapshot();
});
it('updates on add preserving existing text', async function () {
const wrapper = mountWithTheme(
);
// Set a path, as path is selected bu default.
const pathInput = wrapper.find('RuleBuilder BuilderInput');
pathInput.simulate('change', {target: {value: 'file.js'}});
// Select the user.
await selectByValueAsync(wrapper, 'user:1', {control: true, name: 'owners'});
wrapper.update();
// Add the new rule.
const button = wrapper.find('RuleBuilder AddButton button');
button.simulate('click');
wrapper.update();
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',
},
})
);
});
});