Commit 1cc1efd4 authored by Thomas Randolph's avatar Thomas Randolph

Test the UI updates when the name is already taken

parent f3ae8d53
...@@ -28,6 +28,15 @@ const TEST_FALLBACK_RULE = { ...@@ -28,6 +28,15 @@ const TEST_FALLBACK_RULE = {
isFallback: true, isFallback: true,
}; };
const TEST_LOCKED_RULE_NAME = 'LOCKED_RULE'; const TEST_LOCKED_RULE_NAME = 'LOCKED_RULE';
const nameTakenError = {
response: {
data: {
message: {
name: ['has already been taken'],
},
},
},
};
const localVue = createLocalVue(); const localVue = createLocalVue();
localVue.use(Vuex); localVue.use(Vuex);
...@@ -242,7 +251,7 @@ describe('EE Approvals RuleForm', () => { ...@@ -242,7 +251,7 @@ describe('EE Approvals RuleForm', () => {
.catch(done.fail); .catch(done.fail);
}); });
it('on submit with data, posts rule', () => { describe('with valid data', () => {
const users = [1, 2]; const users = [1, 2];
const groups = [2, 3]; const groups = [2, 3];
const userRecords = users.map(id => ({ id, type: TYPE_USER })); const userRecords = users.map(id => ({ id, type: TYPE_USER }));
...@@ -260,16 +269,37 @@ describe('EE Approvals RuleForm', () => { ...@@ -260,16 +269,37 @@ describe('EE Approvals RuleForm', () => {
protectedBranchIds: branches, protectedBranchIds: branches,
}; };
beforeEach(() => {
findNameInput().setValue(expected.name); findNameInput().setValue(expected.name);
findApprovalsRequiredInput().setValue(expected.approvalsRequired); findApprovalsRequiredInput().setValue(expected.approvalsRequired);
wrapper.vm.approvers = groupRecords.concat(userRecords); wrapper.vm.approvers = groupRecords.concat(userRecords);
wrapper.vm.branches = expected.protectedBranchIds; wrapper.vm.branches = expected.protectedBranchIds;
});
it('on submit, posts rule', () => {
wrapper.vm.submit(); wrapper.vm.submit();
expect(actions.postRule).toHaveBeenCalledWith(expect.anything(), expected, undefined); expect(actions.postRule).toHaveBeenCalledWith(expect.anything(), expected, undefined);
}); });
it('when submitted with a duplicate name, shows the "taken name" validation', async () => {
store.state.settings.prefix = 'project-settings';
jest.spyOn(wrapper.vm, 'postRule').mockRejectedValueOnce(nameTakenError);
wrapper.vm.submit();
await wrapper.vm.$nextTick();
// We have to wait for two ticks because the promise needs to resolve
// AND the result has to update into the UI
await wrapper.vm.$nextTick();
expect(findNameValidation()).toEqual({
isValid: false,
feedback: 'Rule name is already taken.',
});
});
});
it('adds selected approvers on selection', () => { it('adds selected approvers on selection', () => {
const orig = [{ id: 7, type: TYPE_GROUP }]; const orig = [{ id: 7, type: TYPE_GROUP }];
const selected = [{ id: 2, type: TYPE_USER }]; const selected = [{ id: 2, type: TYPE_USER }];
...@@ -302,7 +332,7 @@ describe('EE Approvals RuleForm', () => { ...@@ -302,7 +332,7 @@ describe('EE Approvals RuleForm', () => {
]); ]);
}); });
it('on submit, puts rule', () => { describe('with valid data', () => {
const userRecords = TEST_RULE.users.map(x => ({ ...x, type: TYPE_USER })); const userRecords = TEST_RULE.users.map(x => ({ ...x, type: TYPE_USER }));
const groupRecords = TEST_RULE.groups.map(x => ({ ...x, type: TYPE_GROUP })); const groupRecords = TEST_RULE.groups.map(x => ({ ...x, type: TYPE_GROUP }));
const users = userRecords.map(x => x.id); const users = userRecords.map(x => x.id);
...@@ -318,10 +348,36 @@ describe('EE Approvals RuleForm', () => { ...@@ -318,10 +348,36 @@ describe('EE Approvals RuleForm', () => {
protectedBranchIds: [], protectedBranchIds: [],
}; };
beforeEach(() => {
findNameInput().setValue(expected.name);
findApprovalsRequiredInput().setValue(expected.approvalsRequired);
wrapper.vm.approvers = groupRecords.concat(userRecords);
wrapper.vm.branches = expected.protectedBranchIds;
});
it('on submit, puts rule', () => {
wrapper.vm.submit(); wrapper.vm.submit();
expect(actions.putRule).toHaveBeenCalledWith(expect.anything(), expected, undefined); expect(actions.putRule).toHaveBeenCalledWith(expect.anything(), expected, undefined);
}); });
it('when submitted with a duplicate name, shows the "taken name" validation', async () => {
store.state.settings.prefix = 'project-settings';
jest.spyOn(wrapper.vm, 'putRule').mockRejectedValueOnce(nameTakenError);
wrapper.vm.submit();
await wrapper.vm.$nextTick();
// We have to wait for two ticks because the promise needs to resolve
// AND the result has to update into the UI
await wrapper.vm.$nextTick();
expect(findNameValidation()).toEqual({
isValid: false,
feedback: 'Rule name is already taken.',
});
});
});
}); });
describe('with init fallback rule', () => { describe('with init fallback rule', () => {
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment