2019-09-27 12:06:07 +00:00
|
|
|
import { shallowMount } from '@vue/test-utils';
|
|
|
|
import ConfidentialIssueSidebar from '~/sidebar/components/confidential/confidential_issue_sidebar.vue';
|
2019-09-26 06:06:27 +00:00
|
|
|
import { mockTracking, triggerEvent } from 'helpers/tracking_helper';
|
2019-09-27 12:06:07 +00:00
|
|
|
import EditForm from '~/sidebar/components/confidential/edit_form.vue';
|
2017-08-07 23:56:16 +00:00
|
|
|
|
|
|
|
describe('Confidential Issue Sidebar Block', () => {
|
2019-09-27 12:06:07 +00:00
|
|
|
let wrapper;
|
2017-08-07 23:56:16 +00:00
|
|
|
|
2019-09-27 12:06:07 +00:00
|
|
|
const createComponent = propsData => {
|
2017-08-07 23:56:16 +00:00
|
|
|
const service = {
|
2018-05-28 11:41:30 +00:00
|
|
|
update: () => Promise.resolve(true),
|
2017-08-07 23:56:16 +00:00
|
|
|
};
|
|
|
|
|
2019-09-27 12:06:07 +00:00
|
|
|
wrapper = shallowMount(ConfidentialIssueSidebar, {
|
2017-08-07 23:56:16 +00:00
|
|
|
propsData: {
|
|
|
|
service,
|
2019-09-27 12:06:07 +00:00
|
|
|
...propsData,
|
2017-08-07 23:56:16 +00:00
|
|
|
},
|
2019-09-27 12:06:07 +00:00
|
|
|
sync: false,
|
|
|
|
});
|
|
|
|
};
|
|
|
|
|
|
|
|
it.each`
|
|
|
|
isConfidential | isEditable
|
|
|
|
${false} | ${false}
|
|
|
|
${false} | ${true}
|
|
|
|
${true} | ${false}
|
|
|
|
${true} | ${true}
|
|
|
|
`(
|
|
|
|
'renders for isConfidential = $isConfidential and isEditable = $isEditable',
|
|
|
|
({ isConfidential, isEditable }) => {
|
|
|
|
createComponent({
|
|
|
|
isConfidential,
|
|
|
|
isEditable,
|
|
|
|
});
|
|
|
|
|
|
|
|
expect(wrapper.element).toMatchSnapshot();
|
|
|
|
},
|
|
|
|
);
|
|
|
|
|
|
|
|
afterEach(() => {
|
|
|
|
wrapper.destroy();
|
2017-08-07 23:56:16 +00:00
|
|
|
});
|
|
|
|
|
2019-09-27 12:06:07 +00:00
|
|
|
describe('if editable', () => {
|
|
|
|
beforeEach(() => {
|
|
|
|
createComponent({
|
|
|
|
isConfidential: true,
|
|
|
|
isEditable: true,
|
|
|
|
});
|
|
|
|
});
|
2017-08-07 23:56:16 +00:00
|
|
|
|
2019-09-27 12:06:07 +00:00
|
|
|
it('displays the edit form when editable', () => {
|
|
|
|
wrapper.setData({ edit: false });
|
2017-08-07 23:56:16 +00:00
|
|
|
|
2019-09-27 12:06:07 +00:00
|
|
|
wrapper.find({ ref: 'editLink' }).trigger('click');
|
2017-08-07 23:56:16 +00:00
|
|
|
|
2019-09-27 12:06:07 +00:00
|
|
|
return wrapper.vm.$nextTick().then(() => {
|
|
|
|
expect(wrapper.find(EditForm).exists()).toBe(true);
|
|
|
|
});
|
2017-08-07 23:56:16 +00:00
|
|
|
});
|
2018-04-02 18:46:50 +00:00
|
|
|
|
2019-09-27 12:06:07 +00:00
|
|
|
it('displays the edit form when opened from collapsed state', () => {
|
|
|
|
wrapper.setData({ edit: false });
|
2018-04-02 18:46:50 +00:00
|
|
|
|
2019-09-27 12:06:07 +00:00
|
|
|
wrapper.find({ ref: 'collapseIcon' }).trigger('click');
|
2018-04-02 18:46:50 +00:00
|
|
|
|
2019-09-27 12:06:07 +00:00
|
|
|
return wrapper.vm.$nextTick().then(() => {
|
|
|
|
expect(wrapper.find(EditForm).exists()).toBe(true);
|
|
|
|
});
|
2018-04-02 18:46:50 +00:00
|
|
|
});
|
2019-08-21 19:12:11 +00:00
|
|
|
|
2019-09-27 12:06:07 +00:00
|
|
|
it('tracks the event when "Edit" is clicked', () => {
|
|
|
|
const spy = mockTracking('_category_', wrapper.element, jest.spyOn);
|
|
|
|
|
|
|
|
const editLink = wrapper.find({ ref: 'editLink' });
|
|
|
|
triggerEvent(editLink.element);
|
2019-08-21 19:12:11 +00:00
|
|
|
|
2019-09-27 12:06:07 +00:00
|
|
|
expect(spy).toHaveBeenCalledWith('_category_', 'click_edit_button', {
|
|
|
|
label: 'right_sidebar',
|
|
|
|
property: 'confidentiality',
|
|
|
|
});
|
2019-09-19 21:06:29 +00:00
|
|
|
});
|
2019-08-21 19:12:11 +00:00
|
|
|
});
|
2017-08-07 23:56:16 +00:00
|
|
|
});
|