2019-09-30 21:07:59 +05:30
|
|
|
import { GlLoadingIcon } from '@gitlab/ui';
|
2021-03-11 19:13:27 +05:30
|
|
|
import { shallowMount } from '@vue/test-utils';
|
2022-04-04 11:22:00 +05:30
|
|
|
import { nextTick } from 'vue';
|
2019-09-30 21:07:59 +05:30
|
|
|
import LastCommit from '~/repository/components/last_commit.vue';
|
|
|
|
import UserAvatarLink from '~/vue_shared/components/user_avatar/user_avatar_link.vue';
|
|
|
|
|
|
|
|
let vm;
|
|
|
|
|
|
|
|
function createCommitData(data = {}) {
|
2020-03-13 15:44:24 +05:30
|
|
|
const defaultData = {
|
2019-09-30 21:07:59 +05:30
|
|
|
sha: '123456789',
|
|
|
|
title: 'Commit title',
|
2020-05-24 23:13:21 +05:30
|
|
|
titleHtml: 'Commit title',
|
2019-09-30 21:07:59 +05:30
|
|
|
message: 'Commit message',
|
2020-10-24 23:57:45 +05:30
|
|
|
webPath: '/commit/123',
|
2019-09-30 21:07:59 +05:30
|
|
|
authoredDate: '2019-01-01',
|
|
|
|
author: {
|
|
|
|
name: 'Test',
|
|
|
|
avatarUrl: 'https://test.com',
|
2020-10-24 23:57:45 +05:30
|
|
|
webPath: '/test',
|
2019-09-30 21:07:59 +05:30
|
|
|
},
|
2019-12-26 22:10:19 +05:30
|
|
|
pipeline: {
|
2019-09-30 21:07:59 +05:30
|
|
|
detailedStatus: {
|
|
|
|
detailsPath: 'https://test.com/pipeline',
|
|
|
|
icon: 'failed',
|
|
|
|
tooltip: 'failed',
|
|
|
|
text: 'failed',
|
|
|
|
group: {},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
};
|
2020-03-13 15:44:24 +05:30
|
|
|
return Object.assign(defaultData, data);
|
2019-09-30 21:07:59 +05:30
|
|
|
}
|
|
|
|
|
|
|
|
function factory(commit = createCommitData(), loading = false) {
|
|
|
|
vm = shallowMount(LastCommit, {
|
|
|
|
mocks: {
|
|
|
|
$apollo: {
|
|
|
|
queries: {
|
|
|
|
commit: {
|
|
|
|
loading: true,
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
});
|
2022-03-02 08:16:31 +05:30
|
|
|
// setData usage is discouraged. See https://gitlab.com/groups/gitlab-org/-/epics/7330 for details
|
|
|
|
// eslint-disable-next-line no-restricted-syntax
|
2019-09-30 21:07:59 +05:30
|
|
|
vm.setData({ commit });
|
|
|
|
vm.vm.$apollo.queries.commit.loading = loading;
|
|
|
|
}
|
|
|
|
|
2020-03-13 15:44:24 +05:30
|
|
|
const emptyMessageClass = 'font-italic';
|
|
|
|
|
2019-09-30 21:07:59 +05:30
|
|
|
describe('Repository last commit component', () => {
|
|
|
|
afterEach(() => {
|
|
|
|
vm.destroy();
|
|
|
|
});
|
|
|
|
|
|
|
|
it.each`
|
|
|
|
loading | label
|
|
|
|
${true} | ${'shows'}
|
|
|
|
${false} | ${'hides'}
|
2021-03-11 19:13:27 +05:30
|
|
|
`('$label when loading icon $loading is true', async ({ loading }) => {
|
2019-09-30 21:07:59 +05:30
|
|
|
factory(createCommitData(), loading);
|
|
|
|
|
2022-04-04 11:22:00 +05:30
|
|
|
await nextTick();
|
2021-03-11 19:13:27 +05:30
|
|
|
|
|
|
|
expect(vm.find(GlLoadingIcon).exists()).toBe(loading);
|
2019-09-30 21:07:59 +05:30
|
|
|
});
|
|
|
|
|
2021-03-11 19:13:27 +05:30
|
|
|
it('renders commit widget', async () => {
|
2019-09-30 21:07:59 +05:30
|
|
|
factory();
|
|
|
|
|
2022-04-04 11:22:00 +05:30
|
|
|
await nextTick();
|
2021-03-11 19:13:27 +05:30
|
|
|
|
|
|
|
expect(vm.element).toMatchSnapshot();
|
2019-09-30 21:07:59 +05:30
|
|
|
});
|
|
|
|
|
2021-03-11 19:13:27 +05:30
|
|
|
it('renders short commit ID', async () => {
|
2019-09-30 21:07:59 +05:30
|
|
|
factory();
|
|
|
|
|
2022-04-04 11:22:00 +05:30
|
|
|
await nextTick();
|
2021-03-11 19:13:27 +05:30
|
|
|
|
|
|
|
expect(vm.find('[data-testid="last-commit-id-label"]').text()).toEqual('12345678');
|
2019-09-30 21:07:59 +05:30
|
|
|
});
|
|
|
|
|
2021-03-11 19:13:27 +05:30
|
|
|
it('hides pipeline components when pipeline does not exist', async () => {
|
2019-12-26 22:10:19 +05:30
|
|
|
factory(createCommitData({ pipeline: null }));
|
2019-09-30 21:07:59 +05:30
|
|
|
|
2022-04-04 11:22:00 +05:30
|
|
|
await nextTick();
|
2021-03-11 19:13:27 +05:30
|
|
|
|
|
|
|
expect(vm.find('.js-commit-pipeline').exists()).toBe(false);
|
2019-09-30 21:07:59 +05:30
|
|
|
});
|
|
|
|
|
2021-03-11 19:13:27 +05:30
|
|
|
it('renders pipeline components', async () => {
|
2019-09-30 21:07:59 +05:30
|
|
|
factory();
|
|
|
|
|
2022-04-04 11:22:00 +05:30
|
|
|
await nextTick();
|
2021-03-11 19:13:27 +05:30
|
|
|
|
|
|
|
expect(vm.find('.js-commit-pipeline').exists()).toBe(true);
|
2019-09-30 21:07:59 +05:30
|
|
|
});
|
|
|
|
|
2021-03-11 19:13:27 +05:30
|
|
|
it('hides author component when author does not exist', async () => {
|
2019-09-30 21:07:59 +05:30
|
|
|
factory(createCommitData({ author: null }));
|
|
|
|
|
2022-04-04 11:22:00 +05:30
|
|
|
await nextTick();
|
2021-03-11 19:13:27 +05:30
|
|
|
|
|
|
|
expect(vm.find('.js-user-link').exists()).toBe(false);
|
|
|
|
expect(vm.find(UserAvatarLink).exists()).toBe(false);
|
2019-09-30 21:07:59 +05:30
|
|
|
});
|
|
|
|
|
2021-03-11 19:13:27 +05:30
|
|
|
it('does not render description expander when description is null', async () => {
|
2020-10-24 23:57:45 +05:30
|
|
|
factory(createCommitData({ descriptionHtml: null }));
|
2019-09-30 21:07:59 +05:30
|
|
|
|
2022-04-04 11:22:00 +05:30
|
|
|
await nextTick();
|
2021-03-11 19:13:27 +05:30
|
|
|
|
|
|
|
expect(vm.find('.text-expander').exists()).toBe(false);
|
|
|
|
expect(vm.find('.commit-row-description').exists()).toBe(false);
|
2019-09-30 21:07:59 +05:30
|
|
|
});
|
|
|
|
|
2021-03-11 19:13:27 +05:30
|
|
|
it('expands commit description when clicking expander', async () => {
|
2020-10-24 23:57:45 +05:30
|
|
|
factory(createCommitData({ descriptionHtml: 'Test description' }));
|
2019-09-30 21:07:59 +05:30
|
|
|
|
2022-04-04 11:22:00 +05:30
|
|
|
await nextTick();
|
2021-03-11 19:13:27 +05:30
|
|
|
|
|
|
|
vm.find('.text-expander').vm.$emit('click');
|
|
|
|
|
2022-04-04 11:22:00 +05:30
|
|
|
await nextTick();
|
2021-03-11 19:13:27 +05:30
|
|
|
|
|
|
|
expect(vm.find('.commit-row-description').isVisible()).toBe(true);
|
|
|
|
expect(vm.find('.text-expander').classes('open')).toBe(true);
|
2019-09-30 21:07:59 +05:30
|
|
|
});
|
2019-12-21 20:55:43 +05:30
|
|
|
|
2021-03-08 18:12:59 +05:30
|
|
|
it('strips the first newline of the description', async () => {
|
|
|
|
factory(createCommitData({ descriptionHtml: '
Update ADOPTERS.md' }));
|
|
|
|
|
2022-04-04 11:22:00 +05:30
|
|
|
await nextTick();
|
2021-03-08 18:12:59 +05:30
|
|
|
|
|
|
|
expect(vm.find('.commit-row-description').html()).toBe(
|
|
|
|
'<pre class="commit-row-description gl-mb-3">Update ADOPTERS.md</pre>',
|
|
|
|
);
|
|
|
|
});
|
|
|
|
|
2021-03-11 19:13:27 +05:30
|
|
|
it('renders the signature HTML as returned by the backend', async () => {
|
2022-06-21 17:19:12 +05:30
|
|
|
factory(
|
|
|
|
createCommitData({
|
|
|
|
signatureHtml: `<a
|
|
|
|
class="btn gpg-status-box valid"
|
|
|
|
data-content="signature-content"
|
|
|
|
data-html="true"
|
|
|
|
data-placement="top"
|
|
|
|
data-title="signature-title"
|
|
|
|
data-toggle="popover"
|
|
|
|
role="button"
|
|
|
|
tabindex="0"
|
|
|
|
>
|
|
|
|
Verified
|
|
|
|
</a>`,
|
|
|
|
}),
|
|
|
|
);
|
2019-12-21 20:55:43 +05:30
|
|
|
|
2022-04-04 11:22:00 +05:30
|
|
|
await nextTick();
|
2021-03-11 19:13:27 +05:30
|
|
|
|
2022-06-21 17:19:12 +05:30
|
|
|
expect(vm.find('.gpg-status-box').html()).toBe(
|
|
|
|
`<a class="btn gpg-status-box valid" data-content="signature-content" data-html="true" data-placement="top" data-title="signature-title" data-toggle="popover" role="button" tabindex="0">
|
|
|
|
Verified
|
|
|
|
</a>`,
|
|
|
|
);
|
2020-03-13 15:44:24 +05:30
|
|
|
});
|
|
|
|
|
2021-03-11 19:13:27 +05:30
|
|
|
it('sets correct CSS class if the commit message is empty', async () => {
|
2020-03-13 15:44:24 +05:30
|
|
|
factory(createCommitData({ message: '' }));
|
|
|
|
|
2022-04-04 11:22:00 +05:30
|
|
|
await nextTick();
|
2021-03-11 19:13:27 +05:30
|
|
|
|
|
|
|
expect(vm.find('.item-title').classes()).toContain(emptyMessageClass);
|
2019-12-21 20:55:43 +05:30
|
|
|
});
|
2019-09-30 21:07:59 +05:30
|
|
|
});
|