52 lines
1.6 KiB
JavaScript
52 lines
1.6 KiB
JavaScript
import { shallowMount } from '@vue/test-utils';
|
|
import store from '../../../src/store';
|
|
import utils from '../../../src/services/utils';
|
|
import '../../../src/icons';
|
|
import '../../../src/components/common/vueGlobals';
|
|
|
|
const clone = object => JSON.parse(JSON.stringify(object));
|
|
|
|
const deepAssign = (target, origin) => {
|
|
Object.entries(origin).forEach(([key, value]) => {
|
|
const type = Object.prototype.toString.call(value);
|
|
if (type === '[object Object]' && Object.keys(value).length) {
|
|
deepAssign(target[key], value);
|
|
} else {
|
|
target[key] = value;
|
|
}
|
|
});
|
|
};
|
|
|
|
const freshState = clone(store.state);
|
|
|
|
beforeEach(() => {
|
|
// Restore store state before each test
|
|
deepAssign(store.state, clone(freshState));
|
|
});
|
|
|
|
export default {
|
|
checkToggler(Component, toggler, checker) {
|
|
const wrapper = shallowMount(Component, { store });
|
|
const valueBefore = checker();
|
|
toggler(wrapper);
|
|
const valueAfter = checker();
|
|
expect(valueAfter).toEqual(!valueBefore);
|
|
},
|
|
async resolveModal(type) {
|
|
const config = store.getters['modal/config'];
|
|
expect(config).toBeTruthy();
|
|
expect(config.type).toEqual(type);
|
|
config.resolve();
|
|
await new Promise(resolve => setTimeout(resolve, 1));
|
|
},
|
|
getContextMenuItem(name) {
|
|
return utils.someResult(store.state.contextMenu.items, item => item.name === name && item);
|
|
},
|
|
async resolveContextMenu(name) {
|
|
const item = this.getContextMenuItem(name);
|
|
expect(item).toBeTruthy();
|
|
store.state.contextMenu.resolve(item);
|
|
await new Promise(resolve => setTimeout(resolve, 1));
|
|
}
|
|
};
|