Commit e8824504 authored by Paul Slaughter's avatar Paul Slaughter

Merge branch 'dmishunov/ide_spec_to_vtu' into 'master'

Converted ide_spec to vtu

See merge request gitlab-org/gitlab!47627
parents 73ea67fc d510b75c
import Vue from 'vue'; import Vuex from 'vuex';
import { createComponentWithStore } from 'helpers/vue_mount_component_helper'; import { createLocalVue, shallowMount } from '@vue/test-utils';
import waitForPromises from 'helpers/wait_for_promises';
import { createStore } from '~/ide/stores'; import { createStore } from '~/ide/stores';
import ErrorMessage from '~/ide/components/error_message.vue';
import ide from '~/ide/components/ide.vue'; import ide from '~/ide/components/ide.vue';
import { file } from '../helpers'; import { file } from '../helpers';
import { projectData } from '../mock_data'; import { projectData } from '../mock_data';
import extendStore from '~/ide/stores/extend';
let store; const localVue = createLocalVue();
localVue.use(Vuex);
function bootstrap(projData) { describe('WebIDE', () => {
store = createStore(); const emptyProjData = { ...projectData, empty_repo: true, branches: {} };
extendStore(store, document.createElement('div')); let wrapper;
const Component = Vue.extend(ide); function createComponent({ projData = emptyProjData, state = {}, mockStubs = {} } = {}) {
const store = createStore();
store.state.currentProjectId = 'abcproject'; store.state.currentProjectId = 'abcproject';
store.state.currentBranchId = 'master'; store.state.currentBranchId = 'master';
store.state.projects.abcproject = { ...projData }; store.state.projects.abcproject = { ...projData };
Vue.set(store.state.trees, 'abcproject/master', { store.state.trees['abcproject/master'] = {
tree: [], tree: [],
loading: false, loading: false,
};
Object.keys(state).forEach(key => {
store.state[key] = state[key];
}); });
return createComponentWithStore(Component, store, { return shallowMount(ide, {
emptyStateSvgPath: 'svg', store,
noChangesStateSvgPath: 'svg', localVue,
committedStateSvgPath: 'svg', stubs: mockStubs,
}); });
} }
describe('ide component, empty repo', () => { afterEach(() => {
let vm; wrapper.destroy();
wrapper = null;
});
describe('ide component, empty repo', () => {
beforeEach(() => { beforeEach(() => {
const emptyProjData = { ...projectData, empty_repo: true, branches: {} }; wrapper = createComponent({
vm = bootstrap(emptyProjData); projData: {
vm.$mount(); empty_repo: true,
},
}); });
afterEach(() => {
vm.$destroy();
}); });
it('renders "New file" button in empty repo', async () => { it('renders "New file" button in empty repo', async () => {
await waitForPromises(); expect(wrapper.find('[title="New file"]').exists()).toBe(true);
await vm.$nextTick();
expect(vm.$el.querySelector('.ide-empty-state button[title="New file"]')).not.toBeNull();
}); });
});
describe('ide component, non-empty repo', () => {
let vm;
beforeEach(() => {
vm = bootstrap(projectData);
vm.$mount();
}); });
afterEach(() => { describe('ide component, non-empty repo', () => {
vm.$destroy(); describe('error message', () => {
it('does not show error message when it is not set', () => {
wrapper = createComponent({
state: {
errorMessage: null,
},
mockStubs: {
ErrorMessage,
},
}); });
it('shows error message when set', async () => { expect(wrapper.find(ErrorMessage).exists()).toBe(false);
expect(vm.$el.querySelector('.gl-alert')).toBe(null); });
vm.$store.state.errorMessage = { it('shows error message when set', () => {
wrapper = createComponent({
state: {
errorMessage: {
text: 'error', text: 'error',
}; },
},
await waitForPromises(); mockStubs: {
await vm.$nextTick(); ErrorMessage,
},
});
expect(vm.$el.querySelector('.gl-alert')).not.toBe(null); expect(wrapper.find(ErrorMessage).exists()).toBe(true);
});
}); });
describe('onBeforeUnload', () => { describe('onBeforeUnload', () => {
it('returns undefined when no staged files or changed files', () => { it('returns undefined when no staged files or changed files', () => {
expect(vm.onBeforeUnload()).toBe(undefined); wrapper = createComponent();
expect(wrapper.vm.onBeforeUnload()).toBe(undefined);
}); });
it('returns warning text when their are changed files', () => { it('returns warning text when their are changed files', () => {
vm.$store.state.changedFiles.push(file()); wrapper = createComponent({
state: {
changedFiles: [file()],
},
});
expect(vm.onBeforeUnload()).toBe('Are you sure you want to lose unsaved changes?'); expect(wrapper.vm.onBeforeUnload()).toBe('Are you sure you want to lose unsaved changes?');
}); });
it('returns warning text when their are staged files', () => { it('returns warning text when their are staged files', () => {
vm.$store.state.stagedFiles.push(file()); wrapper = createComponent({
state: {
stagedFiles: [file()],
},
});
expect(vm.onBeforeUnload()).toBe('Are you sure you want to lose unsaved changes?'); expect(wrapper.vm.onBeforeUnload()).toBe('Are you sure you want to lose unsaved changes?');
}); });
it('updates event object', () => { it('updates event object', () => {
const event = {}; const event = {};
vm.$store.state.stagedFiles.push(file()); wrapper = createComponent({
state: {
stagedFiles: [file()],
},
});
vm.onBeforeUnload(event); wrapper.vm.onBeforeUnload(event);
expect(event.returnValue).toBe('Are you sure you want to lose unsaved changes?'); expect(event.returnValue).toBe('Are you sure you want to lose unsaved changes?');
}); });
}); });
describe('non-existent branch', () => { describe('non-existent branch', () => {
it('does not render "New file" button for non-existent branch when repo is not empty', async () => { it('does not render "New file" button for non-existent branch when repo is not empty', () => {
await waitForPromises(); wrapper = createComponent({
await vm.$nextTick(); state: {
projects: {},
},
});
expect(vm.$el.querySelector('.ide-empty-state button[title="New file"]')).toBeNull(); expect(wrapper.find('[title="New file"]').exists()).toBe(false);
}); });
}); });
describe('branch with files', () => { describe('branch with files', () => {
beforeEach(() => { beforeEach(() => {
store.state.trees['abcproject/master'].tree = [file()]; wrapper = createComponent({
projData: {
empty_repo: false,
},
});
}); });
it('does not render "New file" button', async () => { it('does not render "New file" button', () => {
await waitForPromises(); expect(wrapper.find('[title="New file"]').exists()).toBe(false);
await vm.$nextTick(); });
expect(vm.$el.querySelector('.ide-empty-state button[title="New file"]')).toBeNull();
}); });
}); });
}); });
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment