debian-mirror-gitlab/spec/javascripts/diffs/components/app_spec.js

99 lines
2.5 KiB
JavaScript
Raw Normal View History

2019-02-15 15:39:39 +05:30
import Vuex from 'vuex';
import { shallowMount, createLocalVue } from '@vue/test-utils';
2018-12-05 23:21:45 +05:30
import { TEST_HOST } from 'spec/test_constants';
import App from '~/diffs/components/app.vue';
2019-02-15 15:39:39 +05:30
import NoChanges from '~/diffs/components/no_changes.vue';
import DiffFile from '~/diffs/components/diff_file.vue';
2018-12-05 23:21:45 +05:30
import createDiffsStore from '../create_diffs_store';
describe('diffs/components/app', () => {
const oldMrTabs = window.mrTabs;
2019-02-15 15:39:39 +05:30
let store;
2019-05-30 16:15:17 +05:30
let vm;
2018-12-05 23:21:45 +05:30
2019-02-15 15:39:39 +05:30
function createComponent(props = {}, extendStore = () => {}) {
const localVue = createLocalVue();
localVue.use(Vuex);
2018-12-05 23:21:45 +05:30
2019-02-15 15:39:39 +05:30
store = createDiffsStore();
2018-12-05 23:21:45 +05:30
store.state.diffs.isLoading = false;
2019-02-15 15:39:39 +05:30
extendStore(store);
2019-05-30 16:15:17 +05:30
vm = shallowMount(localVue.extend(App), {
2019-02-15 15:39:39 +05:30
localVue,
propsData: {
2018-12-05 23:21:45 +05:30
endpoint: `${TEST_HOST}/diff/endpoint`,
projectPath: 'namespace/project',
currentUser: {},
2019-02-15 15:39:39 +05:30
changesEmptyStateIllustration: '',
...props,
2018-12-05 23:21:45 +05:30
},
2019-02-15 15:39:39 +05:30
store,
2018-12-05 23:21:45 +05:30
});
2019-02-15 15:39:39 +05:30
}
beforeEach(() => {
// setup globals (needed for component to mount :/)
window.mrTabs = jasmine.createSpyObj('mrTabs', ['resetViewContainer']);
window.mrTabs.expandViewContainer = jasmine.createSpy();
2019-05-30 16:15:17 +05:30
window.location.hash = 'ABC_123';
2018-12-05 23:21:45 +05:30
});
afterEach(() => {
// reset globals
window.mrTabs = oldMrTabs;
// reset component
2019-05-30 16:15:17 +05:30
vm.destroy();
2018-12-05 23:21:45 +05:30
});
it('does not show commit info', () => {
2019-02-15 15:39:39 +05:30
createComponent();
2019-05-30 16:15:17 +05:30
expect(vm.contains('.blob-commit-info')).toBe(false);
2018-12-05 23:21:45 +05:30
});
2019-05-30 16:15:17 +05:30
it('sets highlighted row if hash exists in location object', done => {
2019-02-15 15:39:39 +05:30
createComponent({
shouldShow: true,
});
2018-12-05 23:21:45 +05:30
2019-02-15 15:39:39 +05:30
// Component uses $nextTick so we wait until that has finished
setTimeout(() => {
2019-05-30 16:15:17 +05:30
expect(store.state.diffs.highlightedRow).toBe('ABC_123');
2019-01-03 12:48:30 +05:30
2019-02-15 15:39:39 +05:30
done();
});
2019-01-03 12:48:30 +05:30
});
2019-02-15 15:39:39 +05:30
describe('empty state', () => {
it('renders empty state when no diff files exist', () => {
createComponent();
2019-05-30 16:15:17 +05:30
expect(vm.contains(NoChanges)).toBe(true);
2019-02-15 15:39:39 +05:30
});
it('does not render empty state when diff files exist', () => {
2019-05-30 16:15:17 +05:30
createComponent({}, () => {
store.state.diffs.diffFiles.push({
2019-02-15 15:39:39 +05:30
id: 1,
});
});
2019-05-30 16:15:17 +05:30
expect(vm.contains(NoChanges)).toBe(false);
expect(vm.findAll(DiffFile).length).toBe(1);
2019-02-15 15:39:39 +05:30
});
it('does not render empty state when versions match', () => {
createComponent({}, () => {
2019-05-30 16:15:17 +05:30
store.state.diffs.startVersion = { version_index: 1 };
store.state.diffs.mergeRequestDiff = { version_index: 1 };
2019-02-15 15:39:39 +05:30
});
2019-05-30 16:15:17 +05:30
expect(vm.contains(NoChanges)).toBe(false);
2019-02-15 15:39:39 +05:30
});
2018-12-05 23:21:45 +05:30
});
});