import Vue from 'vue'; import { createStore } from '~/ide/stores'; import modal from '~/ide/components/new_dropdown/modal.vue'; import { createComponentWithStore } from 'spec/helpers/vue_mount_component_helper'; describe('new file modal component', () => { const Component = Vue.extend(modal); let vm; afterEach(() => { vm.$destroy(); }); ['tree', 'blob'].forEach(type => { describe(type, () => { beforeEach(() => { const store = createStore(); store.state.entryModal = { type, path: '', }; vm = createComponentWithStore(Component, store).$mount(); vm.name = 'testing'; }); it(`sets modal title as ${type}`, () => { const title = type === 'tree' ? 'directory' : 'file'; expect(vm.$el.querySelector('.modal-title').textContent.trim()).toBe(`Create new ${title}`); }); it(`sets button label as ${type}`, () => { const title = type === 'tree' ? 'directory' : 'file'; expect(vm.$el.querySelector('.btn-success').textContent.trim()).toBe(`Create ${title}`); }); it(`sets form label as ${type}`, () => { expect(vm.$el.querySelector('.label-bold').textContent.trim()).toBe('Name'); }); it(`${type === 'tree' ? 'does not show' : 'shows'} file templates`, () => { const templateFilesEl = vm.$el.querySelector('.file-templates'); if (type === 'tree') { expect(templateFilesEl).toBeNull(); } else { expect(templateFilesEl instanceof Element).toBeTruthy(); } }); describe('createEntryInStore', () => { it('$emits create', () => { spyOn(vm, 'createTempEntry'); vm.submitForm(); expect(vm.createTempEntry).toHaveBeenCalledWith({ name: 'testing', type, }); }); }); }); }); describe('rename entry', () => { beforeEach(() => { const store = createStore(); store.state.entryModal = { type: 'rename', path: '', entry: { name: 'test', type: 'blob', }, }; vm = createComponentWithStore(Component, store).$mount(); }); ['tree', 'blob'].forEach(type => { it(`renders title and button for renaming ${type}`, done => { const text = type === 'tree' ? 'folder' : 'file'; vm.$store.state.entryModal.entry.type = type; vm.$nextTick(() => { expect(vm.$el.querySelector('.modal-title').textContent.trim()).toBe(`Rename ${text}`); expect(vm.$el.querySelector('.btn-success').textContent.trim()).toBe(`Rename ${text}`); done(); }); }); }); describe('entryName', () => { it('returns entries name', () => { expect(vm.entryName).toBe('test'); }); it('updated name', () => { vm.name = 'index.js'; expect(vm.entryName).toBe('index.js'); }); }); }); });