160 lines
3.8 KiB
JavaScript
160 lines
3.8 KiB
JavaScript
|
import '~/boards/models/list';
|
||
|
import MockAdapter from 'axios-mock-adapter';
|
||
|
import axios from 'axios';
|
||
|
import Vuex from 'vuex';
|
||
|
import { shallowMount, createLocalVue } from '@vue/test-utils';
|
||
|
import { GlDrawer, GlLabel } from '@gitlab/ui';
|
||
|
import BoardSettingsSidebar from '~/boards/components/board_settings_sidebar.vue';
|
||
|
import boardsStore from '~/boards/stores/boards_store';
|
||
|
import sidebarEventHub from '~/sidebar/event_hub';
|
||
|
import { inactiveId } from '~/boards/constants';
|
||
|
|
||
|
const localVue = createLocalVue();
|
||
|
|
||
|
localVue.use(Vuex);
|
||
|
|
||
|
describe('BoardSettingsSidebar', () => {
|
||
|
let wrapper;
|
||
|
let mock;
|
||
|
let storeActions;
|
||
|
const labelTitle = 'test';
|
||
|
const labelColor = '#FFFF';
|
||
|
const listId = 1;
|
||
|
|
||
|
const createComponent = (state = { activeId: inactiveId }, actions = {}) => {
|
||
|
storeActions = actions;
|
||
|
|
||
|
const store = new Vuex.Store({
|
||
|
state,
|
||
|
actions: storeActions,
|
||
|
});
|
||
|
|
||
|
wrapper = shallowMount(BoardSettingsSidebar, {
|
||
|
store,
|
||
|
localVue,
|
||
|
});
|
||
|
};
|
||
|
const findLabel = () => wrapper.find(GlLabel);
|
||
|
const findDrawer = () => wrapper.find(GlDrawer);
|
||
|
|
||
|
beforeEach(() => {
|
||
|
boardsStore.create();
|
||
|
});
|
||
|
|
||
|
afterEach(() => {
|
||
|
jest.restoreAllMocks();
|
||
|
wrapper.destroy();
|
||
|
});
|
||
|
|
||
|
it('finds a GlDrawer component', () => {
|
||
|
createComponent();
|
||
|
|
||
|
expect(findDrawer().exists()).toBe(true);
|
||
|
});
|
||
|
|
||
|
describe('on close', () => {
|
||
|
it('calls closeSidebar', async () => {
|
||
|
const spy = jest.fn();
|
||
|
createComponent({ activeId: inactiveId }, { setActiveId: spy });
|
||
|
|
||
|
findDrawer().vm.$emit('close');
|
||
|
|
||
|
await wrapper.vm.$nextTick();
|
||
|
|
||
|
expect(storeActions.setActiveId).toHaveBeenCalledWith(
|
||
|
expect.anything(),
|
||
|
inactiveId,
|
||
|
undefined,
|
||
|
);
|
||
|
});
|
||
|
|
||
|
it('calls closeSidebar on sidebar.closeAll event', async () => {
|
||
|
createComponent({ activeId: inactiveId }, { setActiveId: jest.fn() });
|
||
|
|
||
|
sidebarEventHub.$emit('sidebar.closeAll');
|
||
|
|
||
|
await wrapper.vm.$nextTick();
|
||
|
|
||
|
expect(storeActions.setActiveId).toHaveBeenCalledWith(
|
||
|
expect.anything(),
|
||
|
inactiveId,
|
||
|
undefined,
|
||
|
);
|
||
|
});
|
||
|
});
|
||
|
|
||
|
describe('when activeId is zero', () => {
|
||
|
it('renders GlDrawer with open false', () => {
|
||
|
createComponent();
|
||
|
|
||
|
expect(findDrawer().props('open')).toBe(false);
|
||
|
});
|
||
|
});
|
||
|
|
||
|
describe('when activeId is greater than zero', () => {
|
||
|
beforeEach(() => {
|
||
|
mock = new MockAdapter(axios);
|
||
|
|
||
|
boardsStore.addList({
|
||
|
id: listId,
|
||
|
label: { title: labelTitle, color: labelColor },
|
||
|
list_type: 'label',
|
||
|
});
|
||
|
});
|
||
|
|
||
|
afterEach(() => {
|
||
|
boardsStore.removeList(listId);
|
||
|
});
|
||
|
|
||
|
it('renders GlDrawer with open false', () => {
|
||
|
createComponent({ activeId: 1 });
|
||
|
|
||
|
expect(findDrawer().props('open')).toBe(true);
|
||
|
});
|
||
|
});
|
||
|
|
||
|
describe('when activeId is in boardsStore', () => {
|
||
|
beforeEach(() => {
|
||
|
mock = new MockAdapter(axios);
|
||
|
|
||
|
boardsStore.addList({
|
||
|
id: listId,
|
||
|
label: { title: labelTitle, color: labelColor },
|
||
|
list_type: 'label',
|
||
|
});
|
||
|
|
||
|
createComponent({ activeId: listId });
|
||
|
});
|
||
|
|
||
|
afterEach(() => {
|
||
|
mock.restore();
|
||
|
});
|
||
|
|
||
|
it('renders label title', () => {
|
||
|
expect(findLabel().props('title')).toBe(labelTitle);
|
||
|
});
|
||
|
|
||
|
it('renders label background color', () => {
|
||
|
expect(findLabel().props('backgroundColor')).toBe(labelColor);
|
||
|
});
|
||
|
});
|
||
|
|
||
|
describe('when activeId is not in boardsStore', () => {
|
||
|
beforeEach(() => {
|
||
|
mock = new MockAdapter(axios);
|
||
|
|
||
|
boardsStore.addList({ id: listId, label: { title: labelTitle, color: labelColor } });
|
||
|
|
||
|
createComponent({ activeId: inactiveId });
|
||
|
});
|
||
|
|
||
|
afterEach(() => {
|
||
|
mock.restore();
|
||
|
});
|
||
|
|
||
|
it('does not render GlLabel', () => {
|
||
|
expect(findLabel().exists()).toBe(false);
|
||
|
});
|
||
|
});
|
||
|
});
|