Commit 1ee67e28 authored by Florie Guibert's avatar Florie Guibert

Delete description diff in notes

- Frontend tests in ee/spec
- Fix linting error
parent c84238ff
...@@ -509,7 +509,6 @@ export const fetchDescriptionVersion = (_, { endpoint, startingVersion }) => { ...@@ -509,7 +509,6 @@ export const fetchDescriptionVersion = (_, { endpoint, startingVersion }) => {
export const setCurrentDiscussionId = ({ commit }, discussionId) => export const setCurrentDiscussionId = ({ commit }, discussionId) =>
commit(types.SET_CURRENT_DISCUSSION_ID, discussionId); commit(types.SET_CURRENT_DISCUSSION_ID, discussionId);
export const softDeleteDescriptionVersion = (_, { endpoint, startingVersion }) => { export const softDeleteDescriptionVersion = (_, { endpoint, startingVersion }) => {
let requestUrl = endpoint; let requestUrl = endpoint;
...@@ -520,8 +519,9 @@ export const softDeleteDescriptionVersion = (_, { endpoint, startingVersion }) = ...@@ -520,8 +519,9 @@ export const softDeleteDescriptionVersion = (_, { endpoint, startingVersion }) =
return axios return axios
.delete(requestUrl) .delete(requestUrl)
.then(res => res.data) .then(res => res.data)
.catch(() => { .catch(e => {
Flash(__('Something went wrong while deleting description changes. Please try again.')); Flash(__('Something went wrong while deleting description changes. Please try again.'));
return Promise.reject(e);
}); });
}; };
......
...@@ -318,7 +318,7 @@ $note-form-margin-left: 72px; ...@@ -318,7 +318,7 @@ $note-form-margin-left: 72px;
top: 18px; top: 18px;
right: 0; right: 0;
} }
pre { pre {
max-height: $dropdown-max-height-lg; max-height: $dropdown-max-height-lg;
white-space: pre-wrap; white-space: pre-wrap;
......
import { mount } from '@vue/test-utils';
import axios from '~/lib/utils/axios_utils';
import MockAdapter from 'axios-mock-adapter';
import IssueSystemNote from '~/vue_shared/components/notes/system_note.vue';
import createStore from '~/notes/stores';
import waitForPromises from 'helpers/wait_for_promises';
describe('system note component', () => {
let wrapper;
let props;
let mock;
const diffData = '<span class="idiff">Description</span><span class="idiff addition">Diff</span>';
function mockFetchDiff() {
mock.onGet('/path/to/diff').replyOnce(200, diffData);
}
function mockDeleteDiff() {
mock.onDelete('/path/to/diff/1').replyOnce(200);
}
beforeEach(() => {
props = {
note: {
id: '1424',
author: {
id: 1,
name: 'Root',
username: 'root',
state: 'active',
avatar_url: 'path',
path: '/root',
},
note_html: '<p dir="auto">closed</p>',
system_note_icon_name: 'status_closed',
created_at: '2017-08-02T10:51:58.559Z',
description_version_id: 1,
description_diff_path: 'path/to/diff',
delete_description_version_path: 'path/to/diff/1',
can_delete_description_version: true,
description_version_deleted: false,
},
};
const store = createStore();
store.dispatch('setTargetNoteHash', `note_${props.note.id}`);
mock = new MockAdapter(axios);
wrapper = mount(IssueSystemNote, {
store,
propsData: props,
provide: {
glFeatures: { saveDescriptionVersions: true, descriptionDiffs: true },
},
});
});
afterEach(() => {
mock.restore();
wrapper.destroy();
});
it('should display button to toggle description diff, description version does not display', () => {
const button = wrapper.find('.note-headline-light .btn-blank');
expect(button.exists()).toBe(true);
expect(button.text()).toContain('Compare with previous version');
expect(wrapper.find('.description-version').exists()).toBe(false);
});
it('click on button to toggle description diff displays description diff with delete icon button', done => {
mockFetchDiff();
expect(wrapper.find('.description-version').exists()).toBe(false);
const button = wrapper.find('.note-headline-light .btn-blank');
button.trigger('click');
return wrapper.vm
.$nextTick()
.then(() => waitForPromises())
.then(() => {
expect(wrapper.find('.description-version').exists()).toBe(true);
expect(wrapper.find('.description-version').html()).toContain(diffData);
expect(
wrapper
.find('.description-version button.delete-description-history svg.ic-remove')
.exists(),
).toBe(true);
done();
});
});
it('click on delete icon button deletes description diff', done => {
mockFetchDiff();
mockDeleteDiff();
wrapper.find('.note-headline-light .btn-blank').trigger('click');
return wrapper.vm
.$nextTick()
.then(() => waitForPromises())
.then(() => {
const button = wrapper.find('.description-version button.delete-description-history');
button.trigger('click');
})
.then(() => waitForPromises())
.then(() => {
expect(wrapper.find('.description-version').text()).toContain('Deleted');
done();
});
});
});
import Vue from 'vue';
import { mount } from '@vue/test-utils'; import { mount } from '@vue/test-utils';
import axios from '~/lib/utils/axios_utils';
import MockAdapter from 'axios-mock-adapter';
import IssueSystemNote from '~/vue_shared/components/notes/system_note.vue'; import IssueSystemNote from '~/vue_shared/components/notes/system_note.vue';
import createStore from '~/notes/stores'; import createStore from '~/notes/stores';
import initMRPopovers from '~/mr_popover/index'; import initMRPopovers from '~/mr_popover/index';
...@@ -11,7 +8,6 @@ jest.mock('~/mr_popover/index', () => jest.fn()); ...@@ -11,7 +8,6 @@ jest.mock('~/mr_popover/index', () => jest.fn());
describe('system note component', () => { describe('system note component', () => {
let vm; let vm;
let props; let props;
let mock;
beforeEach(() => { beforeEach(() => {
props = { props = {
...@@ -28,30 +24,19 @@ describe('system note component', () => { ...@@ -28,30 +24,19 @@ describe('system note component', () => {
note_html: '<p dir="auto">closed</p>', note_html: '<p dir="auto">closed</p>',
system_note_icon_name: 'status_closed', system_note_icon_name: 'status_closed',
created_at: '2017-08-02T10:51:58.559Z', created_at: '2017-08-02T10:51:58.559Z',
description_version_id: 1,
description_diff_path: 'path/to/diff',
delete_description_version_path: 'path/to/diff/1',
can_delete_description_version: true,
description_version_deleted: false,
}, },
}; };
const store = createStore(); const store = createStore();
store.dispatch('setTargetNoteHash', `note_${props.note.id}`); store.dispatch('setTargetNoteHash', `note_${props.note.id}`);
mock = new MockAdapter(axios);
vm = mount(IssueSystemNote, { vm = mount(IssueSystemNote, {
store, store,
propsData: props, propsData: props,
provide: {
glFeatures: { saveDescriptionVersions: true, descriptionDiffs: true },
},
}); });
}); });
afterEach(() => { afterEach(() => {
mock.restore();
vm.destroy(); vm.destroy();
}); });
...@@ -77,42 +62,4 @@ describe('system note component', () => { ...@@ -77,42 +62,4 @@ describe('system note component', () => {
it('should initMRPopovers onMount', () => { it('should initMRPopovers onMount', () => {
expect(initMRPopovers).toHaveBeenCalled(); expect(initMRPopovers).toHaveBeenCalled();
}); });
it('should display button to toggle description diff, description version does not display', () => {
const button = vm.find('.note-headline-light .btn-blank');
expect(button).toExist();
expect(button.text()).toContain('Compare with previous version');
expect(vm.find('.description-version').exists()).toBe(false);
});
it('click on button to toggle description diff displays description diff with delete icon button', done => {
const diffData =
'<span class="idiff">Description</span><span class="idiff addition">Diff</span>';
mock.onGet(`/path/to/diff/1`).replyOnce(200, {
data: diffData,
});
const button = vm.find('.note-headline-light .btn-blank');
button.trigger('click');
Vue.nextTick(() => {
expect(vm.find('.description-version').exists()).toBe(true);
expect(vm.find('.description-version').html()).toContain(diffData);
expect(
vm.find('.description-version button.delete-description-history svg.s16').exists(),
).toBe(true);
done();
});
});
it('click on delete icon button deletes description diff', done => {
vm.find('.note-headline-light .btn-blank').trigger('click');
Vue.nextTick(() => {
const button = vm.find('.description-version button.delete-description-history');
button.trigger('click');
expect(vm.find('.description-version').text()).toContain('Deleted');
done();
});
});
}); });
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