debian-mirror-gitlab/spec/frontend/sidebar/components/severity/sidebar_severity_spec.js

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

176 lines
5.4 KiB
JavaScript
Raw Normal View History

2020-11-24 15:15:51 +05:30
import { GlDropdown, GlDropdownItem, GlLoadingIcon, GlTooltip, GlSprintf } from '@gitlab/ui';
2021-10-27 15:23:28 +05:30
import { nextTick } from 'vue';
import { shallowMountExtended } from 'helpers/vue_test_utils_helper';
2020-11-24 15:15:51 +05:30
import waitForPromises from 'helpers/wait_for_promises';
2022-11-25 23:54:43 +05:30
import { createAlert } from '~/flash';
2023-03-04 22:38:38 +05:30
import { INCIDENT_SEVERITY, ISSUABLE_TYPES } from '~/sidebar/constants';
import updateIssuableSeverity from '~/sidebar/queries/update_issuable_severity.mutation.graphql';
2021-03-11 19:13:27 +05:30
import SeverityToken from '~/sidebar/components/severity/severity.vue';
import SidebarSeverity from '~/sidebar/components/severity/sidebar_severity.vue';
2020-11-24 15:15:51 +05:30
jest.mock('~/flash');
describe('SidebarSeverity', () => {
let wrapper;
let mutate;
const projectPath = 'gitlab-org/gitlab-test';
const iid = '1';
const severity = 'CRITICAL';
2021-10-27 15:23:28 +05:30
let canUpdate = true;
2020-11-24 15:15:51 +05:30
function createComponent(props = {}) {
const propsData = {
projectPath,
iid,
issuableType: ISSUABLE_TYPES.INCIDENT,
initialSeverity: severity,
...props,
};
mutate = jest.fn();
2021-10-27 15:23:28 +05:30
wrapper = shallowMountExtended(SidebarSeverity, {
2020-11-24 15:15:51 +05:30
propsData,
2021-10-27 15:23:28 +05:30
provide: {
canUpdate,
},
2020-11-24 15:15:51 +05:30
mocks: {
$apollo: {
mutate,
},
},
stubs: {
GlSprintf,
},
});
}
beforeEach(() => {
createComponent();
});
afterEach(() => {
if (wrapper) {
wrapper.destroy();
}
});
2021-10-27 15:23:28 +05:30
const findSeverityToken = () => wrapper.findAllComponents(SeverityToken);
const findEditBtn = () => wrapper.findByTestId('editButton');
const findDropdown = () => wrapper.findComponent(GlDropdown);
const findCriticalSeverityDropdownItem = () => wrapper.findComponent(GlDropdownItem);
const findLoadingIcon = () => wrapper.findComponent(GlLoadingIcon);
const findTooltip = () => wrapper.findComponent(GlTooltip);
2022-11-25 23:54:43 +05:30
const findCollapsedSeverity = () => wrapper.findComponent({ ref: 'severity' });
2020-11-24 15:15:51 +05:30
2021-10-27 15:23:28 +05:30
describe('Severity widget', () => {
it('renders severity dropdown and token', () => {
expect(findSeverityToken().exists()).toBe(true);
expect(findDropdown().exists()).toBe(true);
});
describe('edit button', () => {
it('is rendered when `canUpdate` provided as `true`', () => {
expect(findEditBtn().exists()).toBe(true);
});
it('is NOT rendered when `canUpdate` provided as `false`', () => {
canUpdate = false;
createComponent();
expect(findEditBtn().exists()).toBe(false);
});
});
2020-11-24 15:15:51 +05:30
});
describe('Update severity', () => {
it('calls `$apollo.mutate` with `updateIssuableSeverity`', () => {
jest
.spyOn(wrapper.vm.$apollo, 'mutate')
.mockResolvedValueOnce({ data: { issueSetSeverity: { issue: { severity } } } });
findCriticalSeverityDropdownItem().vm.$emit('click');
expect(wrapper.vm.$apollo.mutate).toHaveBeenCalledWith({
mutation: updateIssuableSeverity,
variables: {
iid,
projectPath,
severity,
},
});
});
2022-10-11 01:57:18 +05:30
it('shows error alert when severity update fails', async () => {
2020-11-24 15:15:51 +05:30
const errorMsg = 'Something went wrong';
jest.spyOn(wrapper.vm.$apollo, 'mutate').mockRejectedValueOnce(errorMsg);
findCriticalSeverityDropdownItem().vm.$emit('click');
2022-04-04 11:22:00 +05:30
await waitForPromises();
2022-11-25 23:54:43 +05:30
expect(createAlert).toHaveBeenCalled();
2020-11-24 15:15:51 +05:30
});
it('shows loading icon while updating', async () => {
let resolvePromise;
wrapper.vm.$apollo.mutate = jest.fn(
() =>
2021-03-08 18:12:59 +05:30
new Promise((resolve) => {
2020-11-24 15:15:51 +05:30
resolvePromise = resolve;
}),
);
findCriticalSeverityDropdownItem().vm.$emit('click');
2021-10-27 15:23:28 +05:30
await nextTick();
2020-11-24 15:15:51 +05:30
expect(findLoadingIcon().exists()).toBe(true);
resolvePromise();
await waitForPromises();
expect(findLoadingIcon().exists()).toBe(false);
});
});
describe('Switch between collapsed/expanded view of the sidebar', () => {
const HIDDDEN_CLASS = 'gl-display-none';
const SHOWN_CLASS = 'show';
describe('collapsed', () => {
it('should have collapsed icon class', () => {
expect(findCollapsedSeverity().classes('sidebar-collapsed-icon')).toBe(true);
});
it('should display only icon with a tooltip', () => {
2021-03-08 18:12:59 +05:30
expect(findSeverityToken().at(0).attributes('icononly')).toBe('true');
expect(findSeverityToken().at(0).attributes('iconsize')).toBe('14');
expect(findTooltip().text().replace(/\s+/g, ' ')).toContain(
`Severity: ${INCIDENT_SEVERITY[severity].label}`,
);
2020-11-24 15:15:51 +05:30
});
it('should expand the dropdown on collapsed icon click', async () => {
wrapper.vm.isDropdownShowing = false;
2021-10-27 15:23:28 +05:30
await nextTick();
2020-11-24 15:15:51 +05:30
expect(findDropdown().classes(HIDDDEN_CLASS)).toBe(true);
findCollapsedSeverity().trigger('click');
2021-10-27 15:23:28 +05:30
await nextTick();
2020-11-24 15:15:51 +05:30
expect(findDropdown().classes(SHOWN_CLASS)).toBe(true);
});
});
describe('expanded', () => {
it('toggles dropdown with edit button', async () => {
2021-10-27 15:23:28 +05:30
canUpdate = true;
createComponent();
2020-11-24 15:15:51 +05:30
wrapper.vm.isDropdownShowing = false;
2021-10-27 15:23:28 +05:30
await nextTick();
2020-11-24 15:15:51 +05:30
expect(findDropdown().classes(HIDDDEN_CLASS)).toBe(true);
findEditBtn().vm.$emit('click');
2021-10-27 15:23:28 +05:30
await nextTick();
2020-11-24 15:15:51 +05:30
expect(findDropdown().classes(SHOWN_CLASS)).toBe(true);
findEditBtn().vm.$emit('click');
2021-10-27 15:23:28 +05:30
await nextTick();
2020-11-24 15:15:51 +05:30
expect(findDropdown().classes(HIDDDEN_CLASS)).toBe(true);
});
});
});
});