66 lines
2.3 KiB
JavaScript
66 lines
2.3 KiB
JavaScript
import Vue from 'vue';
|
|
import issueWarning from '~/vue_shared/components/issue/issue_warning.vue';
|
|
import mountComponent from 'helpers/vue_mount_component_helper';
|
|
|
|
const IssueWarning = Vue.extend(issueWarning);
|
|
|
|
function formatWarning(string) {
|
|
// Replace newlines with a space then replace multiple spaces with one space
|
|
return string
|
|
.trim()
|
|
.replace(/\n/g, ' ')
|
|
.replace(/\s\s+/g, ' ');
|
|
}
|
|
|
|
describe('Issue Warning Component', () => {
|
|
describe('isLocked', () => {
|
|
it('should render locked issue warning information', () => {
|
|
const props = {
|
|
isLocked: true,
|
|
lockedIssueDocsPath: 'docs/issues/locked',
|
|
};
|
|
const vm = mountComponent(IssueWarning, props);
|
|
|
|
expect(
|
|
vm.$el.querySelector('.icon use').getAttributeNS('http://www.w3.org/1999/xlink', 'href'),
|
|
).toMatch(/lock$/);
|
|
expect(formatWarning(vm.$el.querySelector('span').textContent)).toEqual(
|
|
'This issue is locked. Only project members can comment. Learn more',
|
|
);
|
|
expect(vm.$el.querySelector('a').href).toContain(props.lockedIssueDocsPath);
|
|
});
|
|
});
|
|
|
|
describe('isConfidential', () => {
|
|
it('should render confidential issue warning information', () => {
|
|
const props = {
|
|
isConfidential: true,
|
|
confidentialIssueDocsPath: '/docs/issues/confidential',
|
|
};
|
|
const vm = mountComponent(IssueWarning, props);
|
|
|
|
expect(
|
|
vm.$el.querySelector('.icon use').getAttributeNS('http://www.w3.org/1999/xlink', 'href'),
|
|
).toMatch(/eye-slash$/);
|
|
expect(formatWarning(vm.$el.querySelector('span').textContent)).toEqual(
|
|
'This is a confidential issue. People without permission will never get a notification. Learn more',
|
|
);
|
|
expect(vm.$el.querySelector('a').href).toContain(props.confidentialIssueDocsPath);
|
|
});
|
|
});
|
|
|
|
describe('isLocked and isConfidential', () => {
|
|
it('should render locked and confidential issue warning information', () => {
|
|
const vm = mountComponent(IssueWarning, {
|
|
isLocked: true,
|
|
isConfidential: true,
|
|
});
|
|
|
|
expect(vm.$el.querySelector('.icon')).toBeFalsy();
|
|
expect(formatWarning(vm.$el.querySelector('span').textContent)).toEqual(
|
|
"This issue is confidential and locked. People without permission will never get a notification and won't be able to comment.",
|
|
);
|
|
});
|
|
});
|
|
});
|