51 lines
1.1 KiB
JavaScript
51 lines
1.1 KiB
JavaScript
|
import { shallowMount } from '@vue/test-utils';
|
||
|
import BlobEditHeader from '~/blob/components/blob_edit_header.vue';
|
||
|
import { GlFormInput } from '@gitlab/ui';
|
||
|
|
||
|
describe('Blob Header Editing', () => {
|
||
|
let wrapper;
|
||
|
const value = 'foo.md';
|
||
|
|
||
|
function createComponent() {
|
||
|
wrapper = shallowMount(BlobEditHeader, {
|
||
|
propsData: {
|
||
|
value,
|
||
|
},
|
||
|
});
|
||
|
}
|
||
|
|
||
|
beforeEach(() => {
|
||
|
createComponent();
|
||
|
});
|
||
|
|
||
|
afterEach(() => {
|
||
|
wrapper.destroy();
|
||
|
});
|
||
|
|
||
|
describe('rendering', () => {
|
||
|
it('matches the snapshot', () => {
|
||
|
expect(wrapper.element).toMatchSnapshot();
|
||
|
});
|
||
|
|
||
|
it('contains a form input field', () => {
|
||
|
expect(wrapper.contains(GlFormInput)).toBe(true);
|
||
|
});
|
||
|
});
|
||
|
|
||
|
describe('functionality', () => {
|
||
|
it('emits input event when the blob name is changed', () => {
|
||
|
const inputComponent = wrapper.find(GlFormInput);
|
||
|
const newValue = 'bar.txt';
|
||
|
|
||
|
wrapper.setData({
|
||
|
name: newValue,
|
||
|
});
|
||
|
inputComponent.vm.$emit('change');
|
||
|
|
||
|
return wrapper.vm.$nextTick().then(() => {
|
||
|
expect(wrapper.emitted().input[0]).toEqual([newValue]);
|
||
|
});
|
||
|
});
|
||
|
});
|
||
|
});
|