Commit 331fc541 authored by Natalia Tepluhina's avatar Natalia Tepluhina

Merge branch 'jdb/jestodus-tree-list-spec' into 'master'

Migrate tree_list_spec from karma to jest

See merge request gitlab-org/gitlab!26681
parents de66a69b 58196322
import Vue from 'vue';
import Vuex from 'vuex'; import Vuex from 'vuex';
import { mountComponentWithStore } from 'spec/helpers/vue_mount_component_helper'; import { mount, createLocalVue } from '@vue/test-utils';
import TreeList from '~/diffs/components/tree_list.vue'; import TreeList from '~/diffs/components/tree_list.vue';
import createStore from '~/diffs/store/modules'; import createStore from '~/diffs/store/modules';
describe('Diffs tree list component', () => { describe('Diffs tree list component', () => {
let Component; let wrapper;
let vm; const getFileRows = () => wrapper.findAll('.file-row');
const localVue = createLocalVue();
beforeAll(() => { localVue.use(Vuex);
Component = Vue.extend(TreeList);
});
beforeEach(() => {
Vue.use(Vuex);
const createComponent = state => {
const store = new Vuex.Store({ const store = new Vuex.Store({
modules: { modules: {
diffs: createStore(), diffs: createStore(),
...@@ -22,26 +17,38 @@ describe('Diffs tree list component', () => { ...@@ -22,26 +17,38 @@ describe('Diffs tree list component', () => {
}); });
// Setup initial state // Setup initial state
store.state.diffs.addedLines = 10;
store.state.diffs.removedLines = 20;
store.state.diffs.diffFiles.push('test'); store.state.diffs.diffFiles.push('test');
store.state.diffs = {
addedLines: 10,
removedLines: 20,
...store.state.diffs,
...state,
};
wrapper = mount(TreeList, {
store,
localVue,
propsData: { hideFileStats: false },
});
};
beforeEach(() => {
localStorage.removeItem('mr_diff_tree_list'); localStorage.removeItem('mr_diff_tree_list');
vm = mountComponentWithStore(Component, { store, props: { hideFileStats: false } }); createComponent();
}); });
afterEach(() => { afterEach(() => {
vm.$destroy(); wrapper.destroy();
}); });
it('renders empty text', () => { it('renders empty text', () => {
expect(vm.$el.textContent).toContain('No files found'); expect(wrapper.text()).toContain('No files found');
}); });
describe('with files', () => { describe('with files', () => {
beforeEach(done => { beforeEach(() => {
Object.assign(vm.$store.state.diffs.treeEntries, { const treeEntries = {
'index.js': { 'index.js': {
addedLines: 0, addedLines: 0,
changed: true, changed: true,
...@@ -62,64 +69,69 @@ describe('Diffs tree list component', () => { ...@@ -62,64 +69,69 @@ describe('Diffs tree list component', () => {
type: 'tree', type: 'tree',
tree: [], tree: [],
}, },
};
createComponent({
treeEntries,
tree: [treeEntries['index.js'], treeEntries.app],
}); });
vm.$store.state.diffs.tree = [
vm.$store.state.diffs.treeEntries['index.js'],
vm.$store.state.diffs.treeEntries.app,
];
vm.$nextTick(done); return wrapper.vm.$nextTick();
}); });
it('renders tree', () => { it('renders tree', () => {
expect(vm.$el.querySelectorAll('.file-row').length).toBe(2); expect(getFileRows()).toHaveLength(2);
expect(vm.$el.querySelectorAll('.file-row')[0].textContent).toContain('index.js'); expect(
expect(vm.$el.querySelectorAll('.file-row')[1].textContent).toContain('app'); getFileRows()
.at(0)
.text(),
).toContain('index.js');
expect(
getFileRows()
.at(1)
.text(),
).toContain('app');
}); });
it('hides file stats', done => { it('hides file stats', () => {
vm.hideFileStats = true; wrapper.setProps({ hideFileStats: true });
vm.$nextTick(() => { return wrapper.vm.$nextTick().then(() => {
expect(vm.$el.querySelector('.file-row-stats')).toBe(null); expect(wrapper.find('.file-row-stats').exists()).toBe(false);
done();
}); });
}); });
it('calls toggleTreeOpen when clicking folder', () => { it('calls toggleTreeOpen when clicking folder', () => {
spyOn(vm.$store, 'dispatch').and.stub(); jest.spyOn(wrapper.vm.$store, 'dispatch').mockReturnValue(undefined);
vm.$el.querySelectorAll('.file-row')[1].click(); getFileRows()
.at(1)
.trigger('click');
expect(vm.$store.dispatch).toHaveBeenCalledWith('diffs/toggleTreeOpen', 'app'); expect(wrapper.vm.$store.dispatch).toHaveBeenCalledWith('diffs/toggleTreeOpen', 'app');
}); });
it('calls scrollToFile when clicking blob', () => { it('calls scrollToFile when clicking blob', () => {
spyOn(vm.$store, 'dispatch').and.stub(); jest.spyOn(wrapper.vm.$store, 'dispatch').mockReturnValue(undefined);
vm.$el.querySelector('.file-row').click(); wrapper.find('.file-row').trigger('click');
expect(vm.$store.dispatch).toHaveBeenCalledWith('diffs/scrollToFile', 'app/index.js'); expect(wrapper.vm.$store.dispatch).toHaveBeenCalledWith('diffs/scrollToFile', 'app/index.js');
}); });
it('renders as file list when renderTreeList is false', done => { it('renders as file list when renderTreeList is false', () => {
vm.$store.state.diffs.renderTreeList = false; wrapper.vm.$store.state.diffs.renderTreeList = false;
vm.$nextTick(() => {
expect(vm.$el.querySelectorAll('.file-row').length).toBe(1);
done(); return wrapper.vm.$nextTick().then(() => {
expect(getFileRows()).toHaveLength(1);
}); });
}); });
it('renders file paths when renderTreeList is false', done => { it('renders file paths when renderTreeList is false', () => {
vm.$store.state.diffs.renderTreeList = false; wrapper.vm.$store.state.diffs.renderTreeList = false;
vm.$nextTick(() => {
expect(vm.$el.querySelector('.file-row').textContent).toContain('index.js');
done(); return wrapper.vm.$nextTick().then(() => {
expect(wrapper.find('.file-row').text()).toContain('index.js');
}); });
}); });
}); });
......
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