215 lines
5.8 KiB
JavaScript
215 lines
5.8 KiB
JavaScript
import Vue from 'vue';
|
|
import { createComponentWithStore } from 'helpers/vue_mount_component_helper';
|
|
import createFlash from '~/flash';
|
|
import modal from '~/ide/components/new_dropdown/modal.vue';
|
|
import { createStore } from '~/ide/stores';
|
|
|
|
jest.mock('~/flash');
|
|
|
|
describe('new file modal component', () => {
|
|
const Component = Vue.extend(modal);
|
|
let vm;
|
|
|
|
afterEach(() => {
|
|
vm.$destroy();
|
|
});
|
|
|
|
describe.each`
|
|
entryType | modalTitle | btnTitle | showsFileTemplates
|
|
${'tree'} | ${'Create new directory'} | ${'Create directory'} | ${false}
|
|
${'blob'} | ${'Create new file'} | ${'Create file'} | ${true}
|
|
`('$entryType', ({ entryType, modalTitle, btnTitle, showsFileTemplates }) => {
|
|
beforeEach((done) => {
|
|
const store = createStore();
|
|
|
|
vm = createComponentWithStore(Component, store).$mount();
|
|
vm.open(entryType);
|
|
vm.name = 'testing';
|
|
|
|
vm.$nextTick(done);
|
|
});
|
|
|
|
afterEach(() => {
|
|
vm.close();
|
|
});
|
|
|
|
it(`sets modal title as ${entryType}`, () => {
|
|
expect(document.querySelector('.modal-title').textContent.trim()).toBe(modalTitle);
|
|
});
|
|
|
|
it(`sets button label as ${entryType}`, () => {
|
|
expect(document.querySelector('.btn-success').textContent.trim()).toBe(btnTitle);
|
|
});
|
|
|
|
it(`sets form label as ${entryType}`, () => {
|
|
expect(document.querySelector('.label-bold').textContent.trim()).toBe('Name');
|
|
});
|
|
|
|
it(`shows file templates: ${showsFileTemplates}`, () => {
|
|
const templateFilesEl = document.querySelector('.file-templates');
|
|
expect(Boolean(templateFilesEl)).toBe(showsFileTemplates);
|
|
});
|
|
});
|
|
|
|
describe('rename entry', () => {
|
|
beforeEach(() => {
|
|
const store = createStore();
|
|
store.state.entries = {
|
|
'test-path': {
|
|
name: 'test',
|
|
type: 'blob',
|
|
path: 'test-path',
|
|
},
|
|
};
|
|
|
|
vm = createComponentWithStore(Component, store).$mount();
|
|
});
|
|
|
|
it.each`
|
|
entryType | modalTitle | btnTitle
|
|
${'tree'} | ${'Rename folder'} | ${'Rename folder'}
|
|
${'blob'} | ${'Rename file'} | ${'Rename file'}
|
|
`(
|
|
'renders title and button for renaming $entryType',
|
|
({ entryType, modalTitle, btnTitle }, done) => {
|
|
vm.$store.state.entries['test-path'].type = entryType;
|
|
vm.open('rename', 'test-path');
|
|
|
|
vm.$nextTick(() => {
|
|
expect(document.querySelector('.modal-title').textContent.trim()).toBe(modalTitle);
|
|
expect(document.querySelector('.btn-success').textContent.trim()).toBe(btnTitle);
|
|
|
|
done();
|
|
});
|
|
},
|
|
);
|
|
|
|
describe('entryName', () => {
|
|
it('returns entries name', () => {
|
|
vm.open('rename', 'test-path');
|
|
|
|
expect(vm.entryName).toBe('test-path');
|
|
});
|
|
|
|
it('does not reset entryName to its old value if empty', () => {
|
|
vm.entryName = 'hello';
|
|
vm.entryName = '';
|
|
|
|
expect(vm.entryName).toBe('');
|
|
});
|
|
});
|
|
|
|
describe('open', () => {
|
|
it('sets entryName to path provided if modalType is rename', () => {
|
|
vm.open('rename', 'test-path');
|
|
|
|
expect(vm.entryName).toBe('test-path');
|
|
});
|
|
|
|
it("appends '/' to the path if modalType isn't rename", () => {
|
|
vm.open('blob', 'test-path');
|
|
|
|
expect(vm.entryName).toBe('test-path/');
|
|
});
|
|
|
|
it('leaves entryName blank if no path is provided', () => {
|
|
vm.open('blob');
|
|
|
|
expect(vm.entryName).toBe('');
|
|
});
|
|
});
|
|
});
|
|
|
|
describe('createFromTemplate', () => {
|
|
let store;
|
|
|
|
beforeEach(() => {
|
|
store = createStore();
|
|
store.state.entries = {
|
|
'test-path/test': {
|
|
name: 'test',
|
|
deleted: false,
|
|
},
|
|
};
|
|
|
|
vm = createComponentWithStore(Component, store).$mount();
|
|
vm.open('blob');
|
|
|
|
jest.spyOn(vm, 'createTempEntry').mockImplementation();
|
|
});
|
|
|
|
it.each`
|
|
entryName | newFilePath
|
|
${''} | ${'.gitignore'}
|
|
${'README.md'} | ${'.gitignore'}
|
|
${'test-path/test/'} | ${'test-path/test/.gitignore'}
|
|
${'test-path/test'} | ${'test-path/.gitignore'}
|
|
${'test-path/test/abc.md'} | ${'test-path/test/.gitignore'}
|
|
`(
|
|
'creates a new file with the given template name in appropriate directory for path: $path',
|
|
({ entryName, newFilePath }) => {
|
|
vm.entryName = entryName;
|
|
|
|
vm.createFromTemplate({ name: '.gitignore' });
|
|
|
|
expect(vm.createTempEntry).toHaveBeenCalledWith({
|
|
name: newFilePath,
|
|
type: 'blob',
|
|
});
|
|
},
|
|
);
|
|
});
|
|
|
|
describe('submitForm', () => {
|
|
let store;
|
|
|
|
beforeEach(() => {
|
|
store = createStore();
|
|
store.state.entries = {
|
|
'test-path/test': {
|
|
name: 'test',
|
|
deleted: false,
|
|
},
|
|
};
|
|
|
|
vm = createComponentWithStore(Component, store).$mount();
|
|
});
|
|
|
|
it('throws an error when target entry exists', () => {
|
|
vm.open('rename', 'test-path/test');
|
|
|
|
expect(createFlash).not.toHaveBeenCalled();
|
|
|
|
vm.submitForm();
|
|
|
|
expect(createFlash).toHaveBeenCalledWith({
|
|
message: 'The name "test-path/test" is already taken in this directory.',
|
|
type: 'alert',
|
|
parent: expect.anything(),
|
|
actionConfig: null,
|
|
fadeTransition: false,
|
|
addBodyClass: true,
|
|
});
|
|
});
|
|
|
|
it('does not throw error when target entry does not exist', () => {
|
|
jest.spyOn(vm, 'renameEntry').mockImplementation();
|
|
|
|
vm.open('rename', 'test-path/test');
|
|
vm.entryName = 'test-path/test2';
|
|
vm.submitForm();
|
|
|
|
expect(createFlash).not.toHaveBeenCalled();
|
|
});
|
|
|
|
it('removes leading/trailing found in the new name', () => {
|
|
vm.open('rename', 'test-path/test');
|
|
|
|
vm.entryName = 'test-path /test';
|
|
|
|
vm.submitForm();
|
|
|
|
expect(vm.entryName).toBe('test-path/test');
|
|
});
|
|
});
|
|
});
|