89 lines
1.9 KiB
JavaScript
89 lines
1.9 KiB
JavaScript
import { createLocalVue, shallowMount } from '@vue/test-utils';
|
|
import Vuex from 'vuex';
|
|
|
|
import BoardCard from '~/boards/components/board_card.vue';
|
|
import BoardList from '~/boards/components/board_list.vue';
|
|
import BoardNewIssue from '~/boards/components/board_new_issue.vue';
|
|
import defaultState from '~/boards/stores/state';
|
|
import { mockList, mockIssuesByListId, issues } from './mock_data';
|
|
|
|
export default function createComponent({
|
|
listIssueProps = {},
|
|
componentProps = {},
|
|
listProps = {},
|
|
actions = {},
|
|
getters = {},
|
|
provide = {},
|
|
state = defaultState,
|
|
stubs = {
|
|
BoardNewIssue,
|
|
BoardCard,
|
|
},
|
|
} = {}) {
|
|
const localVue = createLocalVue();
|
|
localVue.use(Vuex);
|
|
|
|
const store = new Vuex.Store({
|
|
state: {
|
|
boardItemsByListId: mockIssuesByListId,
|
|
boardItems: issues,
|
|
pageInfoByListId: {
|
|
'gid://gitlab/List/1': { hasNextPage: true },
|
|
'gid://gitlab/List/2': {},
|
|
},
|
|
listsFlags: {
|
|
'gid://gitlab/List/1': {},
|
|
'gid://gitlab/List/2': {},
|
|
},
|
|
selectedBoardItems: [],
|
|
...state,
|
|
},
|
|
getters: {
|
|
isGroupBoard: () => false,
|
|
isProjectBoard: () => true,
|
|
isEpicBoard: () => false,
|
|
...getters,
|
|
},
|
|
actions,
|
|
});
|
|
|
|
const list = {
|
|
...mockList,
|
|
...listProps,
|
|
};
|
|
const issue = {
|
|
title: 'Testing',
|
|
id: 1,
|
|
iid: 1,
|
|
confidential: false,
|
|
labels: [],
|
|
assignees: [],
|
|
...listIssueProps,
|
|
};
|
|
if (!Object.prototype.hasOwnProperty.call(listProps, 'issuesCount')) {
|
|
list.issuesCount = 1;
|
|
}
|
|
|
|
const component = shallowMount(BoardList, {
|
|
localVue,
|
|
store,
|
|
propsData: {
|
|
disabled: false,
|
|
list,
|
|
boardItems: [issue],
|
|
canAdminList: true,
|
|
...componentProps,
|
|
},
|
|
provide: {
|
|
groupId: null,
|
|
rootPath: '/',
|
|
weightFeatureAvailable: false,
|
|
boardWeight: null,
|
|
canAdminList: true,
|
|
...provide,
|
|
},
|
|
stubs,
|
|
});
|
|
|
|
return component;
|
|
}
|