2018-03-05 12:38:13 +00:00
|
|
|
import Vue from 'vue';
|
|
|
|
|
2019-12-09 12:07:58 +00:00
|
|
|
import mountComponent from 'helpers/vue_mount_component_helper';
|
2018-03-05 12:38:13 +00:00
|
|
|
import dropdownCreateLabelComponent from '~/vue_shared/components/sidebar/labels_select/dropdown_create_label.vue';
|
|
|
|
|
2020-05-11 09:09:45 +00:00
|
|
|
import { mockSuggestedColors } from './mock_data';
|
2018-03-05 12:38:13 +00:00
|
|
|
|
2020-12-23 21:10:24 +00:00
|
|
|
const createComponent = (headerTitle) => {
|
2018-03-05 12:38:13 +00:00
|
|
|
const Component = Vue.extend(dropdownCreateLabelComponent);
|
|
|
|
|
2018-03-08 12:42:37 +00:00
|
|
|
return mountComponent(Component, {
|
|
|
|
headerTitle,
|
|
|
|
});
|
2018-03-05 12:38:13 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
describe('DropdownCreateLabelComponent', () => {
|
2020-09-03 18:08:29 +00:00
|
|
|
const colorsCount = Object.keys(mockSuggestedColors).length;
|
2018-03-05 12:38:13 +00:00
|
|
|
let vm;
|
|
|
|
|
|
|
|
beforeEach(() => {
|
|
|
|
gon.suggested_label_colors = mockSuggestedColors;
|
|
|
|
vm = createComponent();
|
|
|
|
});
|
|
|
|
|
|
|
|
afterEach(() => {
|
|
|
|
vm.$destroy();
|
|
|
|
});
|
|
|
|
|
|
|
|
describe('created', () => {
|
|
|
|
it('initializes `suggestedColors` prop on component from `gon.suggested_color_labels` object', () => {
|
2020-09-03 18:08:29 +00:00
|
|
|
expect(vm.suggestedColors.length).toBe(colorsCount);
|
2018-03-05 12:38:13 +00:00
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
describe('template', () => {
|
|
|
|
it('renders component container element with classes `dropdown-page-two dropdown-new-label`', () => {
|
|
|
|
expect(vm.$el.classList.contains('dropdown-page-two', 'dropdown-new-label')).toBe(true);
|
|
|
|
});
|
|
|
|
|
|
|
|
it('renders `Go back` button on component header', () => {
|
2020-09-10 09:08:27 +00:00
|
|
|
const backButtonEl = vm.$el.querySelector('.dropdown-title .dropdown-menu-back');
|
2018-10-09 18:03:09 +00:00
|
|
|
|
2018-03-05 12:38:13 +00:00
|
|
|
expect(backButtonEl).not.toBe(null);
|
2020-09-07 15:09:04 +00:00
|
|
|
expect(backButtonEl.querySelector('[data-testid="arrow-left-icon"]')).not.toBe(null);
|
2018-03-05 12:38:13 +00:00
|
|
|
});
|
|
|
|
|
2018-03-08 12:42:37 +00:00
|
|
|
it('renders component header element as `Create new label` when `headerTitle` prop is not provided', () => {
|
2018-03-05 12:38:13 +00:00
|
|
|
const headerEl = vm.$el.querySelector('.dropdown-title');
|
2018-10-09 18:03:09 +00:00
|
|
|
|
2018-03-05 12:38:13 +00:00
|
|
|
expect(headerEl.innerText.trim()).toContain('Create new label');
|
|
|
|
});
|
|
|
|
|
2018-03-08 12:42:37 +00:00
|
|
|
it('renders component header element with value of `headerTitle` prop', () => {
|
|
|
|
const headerTitle = 'Create project label';
|
|
|
|
const vmWithHeaderTitle = createComponent(headerTitle);
|
|
|
|
const headerEl = vmWithHeaderTitle.$el.querySelector('.dropdown-title');
|
2018-10-09 18:03:09 +00:00
|
|
|
|
2018-03-08 12:42:37 +00:00
|
|
|
expect(headerEl.innerText.trim()).toContain(headerTitle);
|
|
|
|
vmWithHeaderTitle.$destroy();
|
|
|
|
});
|
|
|
|
|
2018-03-05 12:38:13 +00:00
|
|
|
it('renders `Close` button on component header', () => {
|
2020-09-10 09:08:27 +00:00
|
|
|
const closeButtonEl = vm.$el.querySelector('.dropdown-title .dropdown-menu-close');
|
2018-10-09 18:03:09 +00:00
|
|
|
|
2018-03-05 12:38:13 +00:00
|
|
|
expect(closeButtonEl).not.toBe(null);
|
|
|
|
});
|
|
|
|
|
|
|
|
it('renders `Name new label` input element', () => {
|
|
|
|
expect(vm.$el.querySelector('.dropdown-labels-error.js-label-error')).not.toBe(null);
|
|
|
|
expect(vm.$el.querySelector('input#new_label_name.default-dropdown-input')).not.toBe(null);
|
|
|
|
});
|
|
|
|
|
|
|
|
it('renders suggested colors list elements', () => {
|
|
|
|
const colorsListContainerEl = vm.$el.querySelector('.suggest-colors.suggest-colors-dropdown');
|
2018-10-09 18:03:09 +00:00
|
|
|
|
2018-03-05 12:38:13 +00:00
|
|
|
expect(colorsListContainerEl).not.toBe(null);
|
2020-09-03 18:08:29 +00:00
|
|
|
expect(colorsListContainerEl.querySelectorAll('a').length).toBe(colorsCount);
|
2018-03-05 12:38:13 +00:00
|
|
|
|
|
|
|
const colorItemEl = colorsListContainerEl.querySelectorAll('a')[0];
|
2018-10-09 18:03:09 +00:00
|
|
|
|
2020-09-03 18:08:29 +00:00
|
|
|
expect(colorItemEl.dataset.color).toBe(vm.suggestedColors[0].colorCode);
|
2021-02-16 18:09:24 +00:00
|
|
|
expect(colorItemEl.getAttribute('style')).toBe('background-color: rgb(0, 153, 102);');
|
2018-03-05 12:38:13 +00:00
|
|
|
});
|
|
|
|
|
|
|
|
it('renders color input element', () => {
|
|
|
|
expect(vm.$el.querySelector('.dropdown-label-color-input')).not.toBe(null);
|
2018-10-17 07:13:26 +00:00
|
|
|
expect(
|
|
|
|
vm.$el.querySelector('.dropdown-label-color-preview.js-dropdown-label-color-preview'),
|
|
|
|
).not.toBe(null);
|
2018-10-17 07:21:28 +00:00
|
|
|
|
2018-03-05 12:38:13 +00:00
|
|
|
expect(vm.$el.querySelector('input#new_label_color.default-dropdown-input')).not.toBe(null);
|
|
|
|
});
|
|
|
|
|
|
|
|
it('renders component action buttons', () => {
|
|
|
|
const createBtnEl = vm.$el.querySelector('button.js-new-label-btn');
|
|
|
|
const cancelBtnEl = vm.$el.querySelector('button.js-cancel-label-btn');
|
2018-10-09 18:03:09 +00:00
|
|
|
|
2018-03-05 12:38:13 +00:00
|
|
|
expect(createBtnEl).not.toBe(null);
|
|
|
|
expect(createBtnEl.innerText.trim()).toBe('Create');
|
|
|
|
expect(cancelBtnEl.innerText.trim()).toBe('Cancel');
|
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|