Commit 36bcbc60 authored by Enrique Alcántara's avatar Enrique Alcántara

Merge branch 'himkp-jest-vue-shared-2' into 'master'

Migrate specs in vue_shared, vuex_shared, vue_mr_widget to Jest

Closes #194258 and #194260

See merge request gitlab-org/gitlab!32751
parents b4ec979f 7f35475b
...@@ -6,7 +6,7 @@ import { ...@@ -6,7 +6,7 @@ import {
issuable3, issuable3,
issuable4, issuable4,
issuable5, issuable5,
} from 'spec/vue_shared/components/issue/related_issuable_mock_data'; } from 'jest/vue_shared/components/issue/related_issuable_mock_data';
describe('RelatedIssuesStore', () => { describe('RelatedIssuesStore', () => {
let store; let store;
......
import Vue from 'vue'; import Vue from 'vue';
import mountComponent from 'spec/helpers/vue_mount_component_helper'; import mountComponent from 'helpers/vue_mount_component_helper';
import MrWidgetAuthor from '~/vue_merge_request_widget/components/mr_widget_author.vue'; import MrWidgetAuthor from '~/vue_merge_request_widget/components/mr_widget_author.vue';
describe('MrWidgetAuthor', () => { describe('MrWidgetAuthor', () => {
......
import Vue from 'vue'; import Vue from 'vue';
import mountComponent from 'spec/helpers/vue_mount_component_helper'; import mountComponent from 'helpers/vue_mount_component_helper';
import MrWidgetAuthorTime from '~/vue_merge_request_widget/components/mr_widget_author_time.vue'; import MrWidgetAuthorTime from '~/vue_merge_request_widget/components/mr_widget_author_time.vue';
describe('MrWidgetAuthorTime', () => { describe('MrWidgetAuthorTime', () => {
......
import Vue from 'vue'; import Vue from 'vue';
import mountComponent from 'spec/helpers/vue_mount_component_helper'; import mountComponent from 'helpers/vue_mount_component_helper';
import headerComponent from '~/vue_merge_request_widget/components/mr_widget_header.vue'; import headerComponent from '~/vue_merge_request_widget/components/mr_widget_header.vue';
describe('MRWidgetHeader', () => { describe('MRWidgetHeader', () => {
......
import Vue from 'vue'; import Vue from 'vue';
import axios from 'axios';
import MockAdapter from 'axios-mock-adapter';
import MemoryUsage from '~/vue_merge_request_widget/components/deployment/memory_usage.vue'; import MemoryUsage from '~/vue_merge_request_widget/components/deployment/memory_usage.vue';
import MRWidgetService from '~/vue_merge_request_widget/services/mr_widget_service'; import MRWidgetService from '~/vue_merge_request_widget/services/mr_widget_service';
...@@ -59,12 +61,20 @@ const messages = { ...@@ -59,12 +61,20 @@ const messages = {
describe('MemoryUsage', () => { describe('MemoryUsage', () => {
let vm; let vm;
let el; let el;
let mock;
beforeEach(() => { beforeEach(() => {
mock = new MockAdapter(axios);
mock.onGet(`${url}.json`).reply(200);
vm = createComponent(); vm = createComponent();
el = vm.$el; el = vm.$el;
}); });
afterEach(() => {
mock.restore();
});
describe('data', () => { describe('data', () => {
it('should have default data', () => { it('should have default data', () => {
const data = MemoryUsage.data(); const data = MemoryUsage.data();
...@@ -127,6 +137,9 @@ describe('MemoryUsage', () => { ...@@ -127,6 +137,9 @@ describe('MemoryUsage', () => {
describe('computeGraphData', () => { describe('computeGraphData', () => {
it('should populate sparkline graph', () => { it('should populate sparkline graph', () => {
// ignore BoostrapVue warnings
jest.spyOn(console, 'warn').mockImplementation();
vm.computeGraphData(metrics, deployment_time); vm.computeGraphData(metrics, deployment_time);
const { hasMetrics, memoryMetrics, deploymentTime, memoryFrom, memoryTo } = vm; const { hasMetrics, memoryMetrics, deploymentTime, memoryFrom, memoryTo } = vm;
...@@ -147,15 +160,15 @@ describe('MemoryUsage', () => { ...@@ -147,15 +160,15 @@ describe('MemoryUsage', () => {
}); });
it('should load metrics data using MRWidgetService', done => { it('should load metrics data using MRWidgetService', done => {
spyOn(MRWidgetService, 'fetchMetrics').and.returnValue(returnServicePromise(true)); jest.spyOn(MRWidgetService, 'fetchMetrics').mockReturnValue(returnServicePromise(true));
spyOn(vm, 'computeGraphData'); jest.spyOn(vm, 'computeGraphData').mockImplementation(() => {});
vm.loadMetrics(); vm.loadMetrics();
setTimeout(() => { setImmediate(() => {
expect(MRWidgetService.fetchMetrics).toHaveBeenCalledWith(url); expect(MRWidgetService.fetchMetrics).toHaveBeenCalledWith(url);
expect(vm.computeGraphData).toHaveBeenCalledWith(metrics, deployment_time); expect(vm.computeGraphData).toHaveBeenCalledWith(metrics, deployment_time);
done(); done();
}, 333); });
}); });
}); });
}); });
...@@ -182,6 +195,9 @@ describe('MemoryUsage', () => { ...@@ -182,6 +195,9 @@ describe('MemoryUsage', () => {
}); });
it('should show deployment memory usage when metrics are loaded', done => { it('should show deployment memory usage when metrics are loaded', done => {
// ignore BoostrapVue warnings
jest.spyOn(console, 'warn').mockImplementation();
vm.loadingMetrics = false; vm.loadingMetrics = false;
vm.hasMetrics = true; vm.hasMetrics = true;
vm.loadFailed = false; vm.loadFailed = false;
......
import Vue from 'vue'; import Vue from 'vue';
import mountComponent from 'spec/helpers/vue_mount_component_helper'; import mountComponent from 'helpers/vue_mount_component_helper';
import mergeHelpComponent from '~/vue_merge_request_widget/components/mr_widget_merge_help.vue'; import mergeHelpComponent from '~/vue_merge_request_widget/components/mr_widget_merge_help.vue';
describe('MRWidgetMergeHelp', () => { describe('MRWidgetMergeHelp', () => {
......
import Vue from 'vue'; import Vue from 'vue';
import mountComponent from 'spec/helpers/vue_mount_component_helper'; import mountComponent from 'helpers/vue_mount_component_helper';
import { trimText } from 'spec/helpers/text_helper'; import { trimText } from 'helpers/text_helper';
import pipelineComponent from '~/vue_merge_request_widget/components/mr_widget_pipeline.vue'; import pipelineComponent from '~/vue_merge_request_widget/components/mr_widget_pipeline.vue';
import mockData from '../mock_data'; import mockData from '../mock_data';
......
import Vue from 'vue'; import Vue from 'vue';
import mountComponent from 'spec/helpers/vue_mount_component_helper'; import mountComponent from 'helpers/vue_mount_component_helper';
import eventHub from '~/vue_merge_request_widget/event_hub'; import eventHub from '~/vue_merge_request_widget/event_hub';
import component from '~/vue_merge_request_widget/components/states/mr_widget_rebase.vue'; import component from '~/vue_merge_request_widget/components/states/mr_widget_rebase.vue';
...@@ -105,7 +105,7 @@ describe('Merge request widget rebase component', () => { ...@@ -105,7 +105,7 @@ describe('Merge request widget rebase component', () => {
describe('methods', () => { describe('methods', () => {
it('checkRebaseStatus', done => { it('checkRebaseStatus', done => {
spyOn(eventHub, '$emit'); jest.spyOn(eventHub, '$emit').mockImplementation(() => {});
vm = mountComponent(Component, { vm = mountComponent(Component, {
mr: {}, mr: {},
service: { service: {
......
import Vue from 'vue'; import Vue from 'vue';
import mountComponent from 'spec/helpers/vue_mount_component_helper'; import mountComponent from 'helpers/vue_mount_component_helper';
import relatedLinksComponent from '~/vue_merge_request_widget/components/mr_widget_related_links.vue'; import relatedLinksComponent from '~/vue_merge_request_widget/components/mr_widget_related_links.vue';
describe('MRWidgetRelatedLinks', () => { describe('MRWidgetRelatedLinks', () => {
......
import Vue from 'vue'; import Vue from 'vue';
import mountComponent from 'spec/helpers/vue_mount_component_helper'; import mountComponent from 'helpers/vue_mount_component_helper';
import mrStatusIcon from '~/vue_merge_request_widget/components/mr_widget_status_icon.vue'; import mrStatusIcon from '~/vue_merge_request_widget/components/mr_widget_status_icon.vue';
describe('MR widget status icon component', () => { describe('MR widget status icon component', () => {
......
import Vue from 'vue'; import Vue from 'vue';
import { mockTracking, triggerEvent } from 'spec/helpers/tracking_helper'; import { mockTracking, triggerEvent } from 'helpers/tracking_helper';
import component from '~/vue_merge_request_widget/components/review_app_link.vue'; import component from '~/vue_merge_request_widget/components/review_app_link.vue';
import mountComponent from '../../helpers/vue_mount_component_helper'; import mountComponent from '../../helpers/vue_mount_component_helper';
...@@ -42,7 +42,7 @@ describe('review app link', () => { ...@@ -42,7 +42,7 @@ describe('review app link', () => {
}); });
it('tracks an event when clicked', () => { it('tracks an event when clicked', () => {
const spy = mockTracking('_category_', el, spyOn); const spy = mockTracking('_category_', el, jest.spyOn);
triggerEvent(el); triggerEvent(el);
expect(spy).toHaveBeenCalledWith('_category_', 'open_review_app', { expect(spy).toHaveBeenCalledWith('_category_', 'open_review_app', {
......
import Vue from 'vue'; import Vue from 'vue';
import mountComponent from 'spec/helpers/vue_mount_component_helper'; import mountComponent from 'helpers/vue_mount_component_helper';
import archivedComponent from '~/vue_merge_request_widget/components/states/mr_widget_archived.vue'; import archivedComponent from '~/vue_merge_request_widget/components/states/mr_widget_archived.vue';
describe('MRWidgetArchived', () => { describe('MRWidgetArchived', () => {
......
import Vue from 'vue'; import Vue from 'vue';
import mountComponent from 'spec/helpers/vue_mount_component_helper'; import mountComponent from 'helpers/vue_mount_component_helper';
import { trimText } from 'spec/helpers/text_helper'; import { trimText } from 'helpers/text_helper';
import autoMergeEnabledComponent from '~/vue_merge_request_widget/components/states/mr_widget_auto_merge_enabled.vue'; import autoMergeEnabledComponent from '~/vue_merge_request_widget/components/states/mr_widget_auto_merge_enabled.vue';
import MRWidgetService from '~/vue_merge_request_widget/services/mr_widget_service'; import MRWidgetService from '~/vue_merge_request_widget/services/mr_widget_service';
import eventHub from '~/vue_merge_request_widget/event_hub'; import eventHub from '~/vue_merge_request_widget/event_hub';
...@@ -14,7 +14,7 @@ describe('MRWidgetAutoMergeEnabled', () => { ...@@ -14,7 +14,7 @@ describe('MRWidgetAutoMergeEnabled', () => {
beforeEach(() => { beforeEach(() => {
const Component = Vue.extend(autoMergeEnabledComponent); const Component = Vue.extend(autoMergeEnabledComponent);
spyOn(eventHub, '$emit'); jest.spyOn(eventHub, '$emit').mockImplementation(() => {});
vm = mountComponent(Component, { vm = mountComponent(Component, {
mr: { mr: {
...@@ -103,7 +103,7 @@ describe('MRWidgetAutoMergeEnabled', () => { ...@@ -103,7 +103,7 @@ describe('MRWidgetAutoMergeEnabled', () => {
const mrObj = { const mrObj = {
is_new_mr_data: true, is_new_mr_data: true,
}; };
spyOn(vm.service, 'cancelAutomaticMerge').and.returnValue( jest.spyOn(vm.service, 'cancelAutomaticMerge').mockReturnValue(
new Promise(resolve => { new Promise(resolve => {
resolve({ resolve({
data: mrObj, data: mrObj,
...@@ -112,17 +112,17 @@ describe('MRWidgetAutoMergeEnabled', () => { ...@@ -112,17 +112,17 @@ describe('MRWidgetAutoMergeEnabled', () => {
); );
vm.cancelAutomaticMerge(); vm.cancelAutomaticMerge();
setTimeout(() => { setImmediate(() => {
expect(vm.isCancellingAutoMerge).toBeTruthy(); expect(vm.isCancellingAutoMerge).toBeTruthy();
expect(eventHub.$emit).toHaveBeenCalledWith('UpdateWidgetData', mrObj); expect(eventHub.$emit).toHaveBeenCalledWith('UpdateWidgetData', mrObj);
done(); done();
}, 333); });
}); });
}); });
describe('removeSourceBranch', () => { describe('removeSourceBranch', () => {
it('should set flag and call service then request main component to update the widget', done => { it('should set flag and call service then request main component to update the widget', done => {
spyOn(vm.service, 'merge').and.returnValue( jest.spyOn(vm.service, 'merge').mockReturnValue(
Promise.resolve({ Promise.resolve({
data: { data: {
status: MWPS_MERGE_STRATEGY, status: MWPS_MERGE_STRATEGY,
...@@ -131,7 +131,7 @@ describe('MRWidgetAutoMergeEnabled', () => { ...@@ -131,7 +131,7 @@ describe('MRWidgetAutoMergeEnabled', () => {
); );
vm.removeSourceBranch(); vm.removeSourceBranch();
setTimeout(() => { setImmediate(() => {
expect(eventHub.$emit).toHaveBeenCalledWith('MRWidgetUpdateRequested'); expect(eventHub.$emit).toHaveBeenCalledWith('MRWidgetUpdateRequested');
expect(vm.service.merge).toHaveBeenCalledWith({ expect(vm.service.merge).toHaveBeenCalledWith({
sha, sha,
...@@ -139,7 +139,7 @@ describe('MRWidgetAutoMergeEnabled', () => { ...@@ -139,7 +139,7 @@ describe('MRWidgetAutoMergeEnabled', () => {
should_remove_source_branch: true, should_remove_source_branch: true,
}); });
done(); done();
}, 333); });
}); });
}); });
}); });
......
import Vue from 'vue'; import Vue from 'vue';
import mountComponent from 'spec/helpers/vue_mount_component_helper'; import mountComponent from 'helpers/vue_mount_component_helper';
import checkingComponent from '~/vue_merge_request_widget/components/states/mr_widget_checking.vue'; import checkingComponent from '~/vue_merge_request_widget/components/states/mr_widget_checking.vue';
describe('MRWidgetChecking', () => { describe('MRWidgetChecking', () => {
......
import Vue from 'vue'; import Vue from 'vue';
import mountComponent from 'spec/helpers/vue_mount_component_helper'; import mountComponent from 'helpers/vue_mount_component_helper';
import closedComponent from '~/vue_merge_request_widget/components/states/mr_widget_closed.vue'; import closedComponent from '~/vue_merge_request_widget/components/states/mr_widget_closed.vue';
describe('MRWidgetClosed', () => { describe('MRWidgetClosed', () => {
......
import $ from 'jquery'; import $ from 'jquery';
import { createLocalVue, shallowMount } from '@vue/test-utils'; import { createLocalVue, shallowMount } from '@vue/test-utils';
import { removeBreakLine } from 'spec/helpers/text_helper'; import { removeBreakLine } from 'helpers/text_helper';
import ConflictsComponent from '~/vue_merge_request_widget/components/states/mr_widget_conflicts.vue'; import ConflictsComponent from '~/vue_merge_request_widget/components/states/mr_widget_conflicts.vue';
import { TEST_HOST } from 'helpers/test_constants';
describe('MRWidgetConflicts', () => { describe('MRWidgetConflicts', () => {
let vm; let vm;
...@@ -16,7 +17,7 @@ describe('MRWidgetConflicts', () => { ...@@ -16,7 +17,7 @@ describe('MRWidgetConflicts', () => {
} }
beforeEach(() => { beforeEach(() => {
spyOn($.fn, 'popover').and.callThrough(); jest.spyOn($.fn, 'popover');
}); });
afterEach(() => { afterEach(() => {
...@@ -185,7 +186,7 @@ describe('MRWidgetConflicts', () => { ...@@ -185,7 +186,7 @@ describe('MRWidgetConflicts', () => {
mr: { mr: {
canMerge: true, canMerge: true,
canPushToSourceBranch: true, canPushToSourceBranch: true,
conflictResolutionPath: gl.TEST_HOST, conflictResolutionPath: TEST_HOST,
sourceBranchProtected: true, sourceBranchProtected: true,
conflictsDocsPath: '', conflictsDocsPath: '',
}, },
...@@ -207,7 +208,7 @@ describe('MRWidgetConflicts', () => { ...@@ -207,7 +208,7 @@ describe('MRWidgetConflicts', () => {
mr: { mr: {
canMerge: true, canMerge: true,
canPushToSourceBranch: true, canPushToSourceBranch: true,
conflictResolutionPath: gl.TEST_HOST, conflictResolutionPath: TEST_HOST,
sourceBranchProtected: false, sourceBranchProtected: false,
conflictsDocsPath: '', conflictsDocsPath: '',
}, },
......
import Vue from 'vue'; import Vue from 'vue';
import mountComponent from 'spec/helpers/vue_mount_component_helper'; import mountComponent from 'helpers/vue_mount_component_helper';
import failedToMergeComponent from '~/vue_merge_request_widget/components/states/mr_widget_failed_to_merge.vue'; import failedToMergeComponent from '~/vue_merge_request_widget/components/states/mr_widget_failed_to_merge.vue';
import eventHub from '~/vue_merge_request_widget/event_hub'; import eventHub from '~/vue_merge_request_widget/event_hub';
...@@ -11,9 +11,9 @@ describe('MRWidgetFailedToMerge', () => { ...@@ -11,9 +11,9 @@ describe('MRWidgetFailedToMerge', () => {
beforeEach(() => { beforeEach(() => {
Component = Vue.extend(failedToMergeComponent); Component = Vue.extend(failedToMergeComponent);
spyOn(eventHub, '$emit'); jest.spyOn(eventHub, '$emit').mockImplementation(() => {});
spyOn(window, 'setInterval').and.returnValue(dummyIntervalId); jest.spyOn(window, 'setInterval').mockReturnValue(dummyIntervalId);
spyOn(window, 'clearInterval').and.stub(); jest.spyOn(window, 'clearInterval').mockImplementation();
mr = { mr = {
mergeError: 'Merge error happened', mergeError: 'Merge error happened',
}; };
...@@ -83,7 +83,7 @@ describe('MRWidgetFailedToMerge', () => { ...@@ -83,7 +83,7 @@ describe('MRWidgetFailedToMerge', () => {
describe('updateTimer', () => { describe('updateTimer', () => {
it('should update timer and emit event when timer end', () => { it('should update timer and emit event when timer end', () => {
spyOn(vm, 'refresh'); jest.spyOn(vm, 'refresh').mockImplementation(() => {});
expect(vm.timer).toEqual(10); expect(vm.timer).toEqual(10);
......
import Vue from 'vue'; import Vue from 'vue';
import mountComponent from 'spec/helpers/vue_mount_component_helper'; import mountComponent from 'helpers/vue_mount_component_helper';
import mergedComponent from '~/vue_merge_request_widget/components/states/mr_widget_merged.vue'; import mergedComponent from '~/vue_merge_request_widget/components/states/mr_widget_merged.vue';
import eventHub from '~/vue_merge_request_widget/event_hub'; import eventHub from '~/vue_merge_request_widget/event_hub';
...@@ -52,7 +52,7 @@ describe('MRWidgetMerged', () => { ...@@ -52,7 +52,7 @@ describe('MRWidgetMerged', () => {
removeSourceBranch() {}, removeSourceBranch() {},
}; };
spyOn(eventHub, '$emit'); jest.spyOn(eventHub, '$emit').mockImplementation(() => {});
vm = mountComponent(Component, { mr, service }); vm = mountComponent(Component, { mr, service });
}); });
...@@ -124,7 +124,7 @@ describe('MRWidgetMerged', () => { ...@@ -124,7 +124,7 @@ describe('MRWidgetMerged', () => {
describe('methods', () => { describe('methods', () => {
describe('removeSourceBranch', () => { describe('removeSourceBranch', () => {
it('should set flag and call service then request main component to update the widget', done => { it('should set flag and call service then request main component to update the widget', done => {
spyOn(vm.service, 'removeSourceBranch').and.returnValue( jest.spyOn(vm.service, 'removeSourceBranch').mockReturnValue(
new Promise(resolve => { new Promise(resolve => {
resolve({ resolve({
data: { data: {
...@@ -135,14 +135,14 @@ describe('MRWidgetMerged', () => { ...@@ -135,14 +135,14 @@ describe('MRWidgetMerged', () => {
); );
vm.removeSourceBranch(); vm.removeSourceBranch();
setTimeout(() => { setImmediate(() => {
const args = eventHub.$emit.calls.argsFor(0); const args = eventHub.$emit.mock.calls[0];
expect(vm.isMakingRequest).toEqual(true); expect(vm.isMakingRequest).toEqual(true);
expect(args[0]).toEqual('MRWidgetUpdateRequested'); expect(args[0]).toEqual('MRWidgetUpdateRequested');
expect(args[1]).not.toThrow(); expect(args[1]).not.toThrow();
done(); done();
}, 333); });
}); });
}); });
}); });
......
import Vue from 'vue'; import Vue from 'vue';
import mountComponent from 'spec/helpers/vue_mount_component_helper'; import mountComponent from 'helpers/vue_mount_component_helper';
import mergingComponent from '~/vue_merge_request_widget/components/states/mr_widget_merging.vue'; import mergingComponent from '~/vue_merge_request_widget/components/states/mr_widget_merging.vue';
describe('MRWidgetMerging', () => { describe('MRWidgetMerging', () => {
......
import Vue from 'vue'; import Vue from 'vue';
import mountComponent from 'spec/helpers/vue_mount_component_helper'; import mountComponent from 'helpers/vue_mount_component_helper';
import missingBranchComponent from '~/vue_merge_request_widget/components/states/mr_widget_missing_branch.vue'; import missingBranchComponent from '~/vue_merge_request_widget/components/states/mr_widget_missing_branch.vue';
describe('MRWidgetMissingBranch', () => { describe('MRWidgetMissingBranch', () => {
......
import Vue from 'vue'; import Vue from 'vue';
import mountComponent from 'spec/helpers/vue_mount_component_helper'; import mountComponent from 'helpers/vue_mount_component_helper';
import notAllowedComponent from '~/vue_merge_request_widget/components/states/mr_widget_not_allowed.vue'; import notAllowedComponent from '~/vue_merge_request_widget/components/states/mr_widget_not_allowed.vue';
describe('MRWidgetNotAllowed', () => { describe('MRWidgetNotAllowed', () => {
......
import Vue from 'vue'; import Vue from 'vue';
import mountComponent from 'spec/helpers/vue_mount_component_helper'; import mountComponent from 'helpers/vue_mount_component_helper';
import { removeBreakLine } from 'spec/helpers/text_helper'; import { removeBreakLine } from 'helpers/text_helper';
import pipelineBlockedComponent from '~/vue_merge_request_widget/components/states/mr_widget_pipeline_blocked.vue'; import pipelineBlockedComponent from '~/vue_merge_request_widget/components/states/mr_widget_pipeline_blocked.vue';
describe('MRWidgetPipelineBlocked', () => { describe('MRWidgetPipelineBlocked', () => {
......
import Vue from 'vue'; import Vue from 'vue';
import { removeBreakLine } from 'spec/helpers/text_helper'; import { removeBreakLine } from 'helpers/text_helper';
import PipelineFailed from '~/vue_merge_request_widget/components/states/pipeline_failed.vue'; import PipelineFailed from '~/vue_merge_request_widget/components/states/pipeline_failed.vue';
describe('PipelineFailed', () => { describe('PipelineFailed', () => {
......
...@@ -7,6 +7,15 @@ import CommitEdit from '~/vue_merge_request_widget/components/states/commit_edit ...@@ -7,6 +7,15 @@ import CommitEdit from '~/vue_merge_request_widget/components/states/commit_edit
import CommitMessageDropdown from '~/vue_merge_request_widget/components/states/commit_message_dropdown.vue'; import CommitMessageDropdown from '~/vue_merge_request_widget/components/states/commit_message_dropdown.vue';
import eventHub from '~/vue_merge_request_widget/event_hub'; import eventHub from '~/vue_merge_request_widget/event_hub';
import { MWPS_MERGE_STRATEGY, MTWPS_MERGE_STRATEGY } from '~/vue_merge_request_widget/constants'; import { MWPS_MERGE_STRATEGY, MTWPS_MERGE_STRATEGY } from '~/vue_merge_request_widget/constants';
import { refreshUserMergeRequestCounts } from '~/commons/nav/user_merge_requests';
import simplePoll from '~/lib/utils/simple_poll';
jest.mock('~/lib/utils/simple_poll', () =>
jest.fn().mockImplementation(jest.requireActual('~/lib/utils/simple_poll').default),
);
jest.mock('~/commons/nav/user_merge_requests', () => ({
refreshUserMergeRequestCounts: jest.fn(),
}));
const commitMessage = 'This is the commit message'; const commitMessage = 'This is the commit message';
const squashCommitMessage = 'This is the squash commit message'; const squashCommitMessage = 'This is the squash commit message';
...@@ -33,6 +42,7 @@ const createTestMr = customConfig => { ...@@ -33,6 +42,7 @@ const createTestMr = customConfig => {
targetBranch: 'master', targetBranch: 'master',
preferredAutoMergeStrategy: MWPS_MERGE_STRATEGY, preferredAutoMergeStrategy: MWPS_MERGE_STRATEGY,
availableAutoMergeStrategies: [MWPS_MERGE_STRATEGY], availableAutoMergeStrategies: [MWPS_MERGE_STRATEGY],
mergeImmediatelyDocsPath: 'path/to/merge/immediately/docs',
}; };
Object.assign(mr, customConfig.mr); Object.assign(mr, customConfig.mr);
...@@ -41,8 +51,8 @@ const createTestMr = customConfig => { ...@@ -41,8 +51,8 @@ const createTestMr = customConfig => {
}; };
const createTestService = () => ({ const createTestService = () => ({
merge() {}, merge: jest.fn(),
poll() {}, poll: jest.fn().mockResolvedValue(),
}); });
const createComponent = (customConfig = {}) => { const createComponent = (customConfig = {}) => {
...@@ -59,11 +69,9 @@ const createComponent = (customConfig = {}) => { ...@@ -59,11 +69,9 @@ const createComponent = (customConfig = {}) => {
describe('ReadyToMerge', () => { describe('ReadyToMerge', () => {
let vm; let vm;
let updateMrCountSpy;
beforeEach(() => { beforeEach(() => {
vm = createComponent(); vm = createComponent();
updateMrCountSpy = spyOnDependency(ReadyToMerge, 'refreshUserMergeRequestCounts');
}); });
afterEach(() => { afterEach(() => {
...@@ -347,19 +355,21 @@ describe('ReadyToMerge', () => { ...@@ -347,19 +355,21 @@ describe('ReadyToMerge', () => {
}); });
it('should handle merge when pipeline succeeds', done => { it('should handle merge when pipeline succeeds', done => {
spyOn(eventHub, '$emit'); jest.spyOn(eventHub, '$emit').mockImplementation(() => {});
spyOn(vm.service, 'merge').and.returnValue(returnPromise('merge_when_pipeline_succeeds')); jest
.spyOn(vm.service, 'merge')
.mockReturnValue(returnPromise('merge_when_pipeline_succeeds'));
vm.removeSourceBranch = false; vm.removeSourceBranch = false;
vm.handleMergeButtonClick(true); vm.handleMergeButtonClick(true);
setTimeout(() => { setImmediate(() => {
expect(vm.isMakingRequest).toBeTruthy(); expect(vm.isMakingRequest).toBeTruthy();
expect(eventHub.$emit).toHaveBeenCalledWith('MRWidgetUpdateRequested'); expect(eventHub.$emit).toHaveBeenCalledWith('MRWidgetUpdateRequested');
const params = vm.service.merge.calls.argsFor(0)[0]; const params = vm.service.merge.mock.calls[0][0];
expect(params).toEqual( expect(params).toEqual(
jasmine.objectContaining({ expect.objectContaining({
sha: vm.mr.sha, sha: vm.mr.sha,
commit_message: vm.mr.commitMessage, commit_message: vm.mr.commitMessage,
should_remove_source_branch: false, should_remove_source_branch: false,
...@@ -367,67 +377,56 @@ describe('ReadyToMerge', () => { ...@@ -367,67 +377,56 @@ describe('ReadyToMerge', () => {
}), }),
); );
done(); done();
}, 333); });
}); });
it('should handle merge failed', done => { it('should handle merge failed', done => {
spyOn(eventHub, '$emit'); jest.spyOn(eventHub, '$emit').mockImplementation(() => {});
spyOn(vm.service, 'merge').and.returnValue(returnPromise('failed')); jest.spyOn(vm.service, 'merge').mockReturnValue(returnPromise('failed'));
vm.handleMergeButtonClick(false, true); vm.handleMergeButtonClick(false, true);
setTimeout(() => { setImmediate(() => {
expect(vm.isMakingRequest).toBeTruthy(); expect(vm.isMakingRequest).toBeTruthy();
expect(eventHub.$emit).toHaveBeenCalledWith('FailedToMerge', undefined); expect(eventHub.$emit).toHaveBeenCalledWith('FailedToMerge', undefined);
const params = vm.service.merge.calls.argsFor(0)[0]; const params = vm.service.merge.mock.calls[0][0];
expect(params.should_remove_source_branch).toBeTruthy(); expect(params.should_remove_source_branch).toBeTruthy();
expect(params.auto_merge_strategy).toBeUndefined(); expect(params.auto_merge_strategy).toBeUndefined();
done(); done();
}, 333); });
}); });
it('should handle merge action accepted case', done => { it('should handle merge action accepted case', done => {
spyOn(vm.service, 'merge').and.returnValue(returnPromise('success')); jest.spyOn(vm.service, 'merge').mockReturnValue(returnPromise('success'));
spyOn(vm, 'initiateMergePolling'); jest.spyOn(vm, 'initiateMergePolling').mockImplementation(() => {});
vm.handleMergeButtonClick(); vm.handleMergeButtonClick();
setTimeout(() => { setImmediate(() => {
expect(vm.isMakingRequest).toBeTruthy(); expect(vm.isMakingRequest).toBeTruthy();
expect(vm.initiateMergePolling).toHaveBeenCalled(); expect(vm.initiateMergePolling).toHaveBeenCalled();
const params = vm.service.merge.calls.argsFor(0)[0]; const params = vm.service.merge.mock.calls[0][0];
expect(params.should_remove_source_branch).toBeTruthy(); expect(params.should_remove_source_branch).toBeTruthy();
expect(params.auto_merge_strategy).toBeUndefined(); expect(params.auto_merge_strategy).toBeUndefined();
done(); done();
}, 333);
}); });
}); });
describe('initiateMergePolling', () => {
beforeEach(() => {
jasmine.clock().install();
});
afterEach(() => {
jasmine.clock().uninstall();
}); });
describe('initiateMergePolling', () => {
it('should call simplePoll', () => { it('should call simplePoll', () => {
const simplePoll = spyOnDependency(ReadyToMerge, 'simplePoll');
vm.initiateMergePolling(); vm.initiateMergePolling();
expect(simplePoll).toHaveBeenCalledWith(jasmine.any(Function), { timeout: 0 }); expect(simplePoll).toHaveBeenCalledWith(expect.any(Function), { timeout: 0 });
}); });
it('should call handleMergePolling', () => { it('should call handleMergePolling', () => {
spyOn(vm, 'handleMergePolling'); jest.spyOn(vm, 'handleMergePolling').mockImplementation(() => {});
vm.initiateMergePolling(); vm.initiateMergePolling();
jasmine.clock().tick(2000);
expect(vm.handleMergePolling).toHaveBeenCalled(); expect(vm.handleMergePolling).toHaveBeenCalled();
}); });
}); });
...@@ -448,9 +447,9 @@ describe('ReadyToMerge', () => { ...@@ -448,9 +447,9 @@ describe('ReadyToMerge', () => {
}); });
it('should call start and stop polling when MR merged', done => { it('should call start and stop polling when MR merged', done => {
spyOn(eventHub, '$emit'); jest.spyOn(eventHub, '$emit').mockImplementation(() => {});
spyOn(vm.service, 'poll').and.returnValue(returnPromise('merged')); jest.spyOn(vm.service, 'poll').mockReturnValue(returnPromise('merged'));
spyOn(vm, 'initiateRemoveSourceBranchPolling'); jest.spyOn(vm, 'initiateRemoveSourceBranchPolling').mockImplementation(() => {});
let cpc = false; // continuePollingCalled let cpc = false; // continuePollingCalled
let spc = false; // stopPollingCalled let spc = false; // stopPollingCalled
...@@ -463,26 +462,26 @@ describe('ReadyToMerge', () => { ...@@ -463,26 +462,26 @@ describe('ReadyToMerge', () => {
spc = true; spc = true;
}, },
); );
setTimeout(() => { setImmediate(() => {
expect(vm.service.poll).toHaveBeenCalled(); expect(vm.service.poll).toHaveBeenCalled();
expect(eventHub.$emit).toHaveBeenCalledWith('MRWidgetUpdateRequested'); expect(eventHub.$emit).toHaveBeenCalledWith('MRWidgetUpdateRequested');
expect(eventHub.$emit).toHaveBeenCalledWith('FetchActionsContent'); expect(eventHub.$emit).toHaveBeenCalledWith('FetchActionsContent');
expect(vm.initiateRemoveSourceBranchPolling).toHaveBeenCalled(); expect(vm.initiateRemoveSourceBranchPolling).toHaveBeenCalled();
expect(updateMrCountSpy).toHaveBeenCalled(); expect(refreshUserMergeRequestCounts).toHaveBeenCalled();
expect(cpc).toBeFalsy(); expect(cpc).toBeFalsy();
expect(spc).toBeTruthy(); expect(spc).toBeTruthy();
done(); done();
}, 333); });
}); });
it('updates status box', done => { it('updates status box', done => {
spyOn(vm.service, 'poll').and.returnValue(returnPromise('merged')); jest.spyOn(vm.service, 'poll').mockReturnValue(returnPromise('merged'));
spyOn(vm, 'initiateRemoveSourceBranchPolling'); jest.spyOn(vm, 'initiateRemoveSourceBranchPolling').mockImplementation(() => {});
vm.handleMergePolling(() => {}, () => {}); vm.handleMergePolling(() => {}, () => {});
setTimeout(() => { setImmediate(() => {
const statusBox = document.querySelector('.status-box'); const statusBox = document.querySelector('.status-box');
expect(statusBox.classList.contains('status-box-mr-merged')).toBeTruthy(); expect(statusBox.classList.contains('status-box-mr-merged')).toBeTruthy();
...@@ -493,12 +492,12 @@ describe('ReadyToMerge', () => { ...@@ -493,12 +492,12 @@ describe('ReadyToMerge', () => {
}); });
it('hides close button', done => { it('hides close button', done => {
spyOn(vm.service, 'poll').and.returnValue(returnPromise('merged')); jest.spyOn(vm.service, 'poll').mockReturnValue(returnPromise('merged'));
spyOn(vm, 'initiateRemoveSourceBranchPolling'); jest.spyOn(vm, 'initiateRemoveSourceBranchPolling').mockImplementation(() => {});
vm.handleMergePolling(() => {}, () => {}); vm.handleMergePolling(() => {}, () => {});
setTimeout(() => { setImmediate(() => {
expect(document.querySelector('.btn-close').classList.contains('hidden')).toBeTruthy(); expect(document.querySelector('.btn-close').classList.contains('hidden')).toBeTruthy();
done(); done();
...@@ -506,12 +505,12 @@ describe('ReadyToMerge', () => { ...@@ -506,12 +505,12 @@ describe('ReadyToMerge', () => {
}); });
it('updates merge request count badge', done => { it('updates merge request count badge', done => {
spyOn(vm.service, 'poll').and.returnValue(returnPromise('merged')); jest.spyOn(vm.service, 'poll').mockReturnValue(returnPromise('merged'));
spyOn(vm, 'initiateRemoveSourceBranchPolling'); jest.spyOn(vm, 'initiateRemoveSourceBranchPolling').mockImplementation(() => {});
vm.handleMergePolling(() => {}, () => {}); vm.handleMergePolling(() => {}, () => {});
setTimeout(() => { setImmediate(() => {
expect(document.querySelector('.js-merge-counter').textContent).toBe('0'); expect(document.querySelector('.js-merge-counter').textContent).toBe('0');
done(); done();
...@@ -519,8 +518,8 @@ describe('ReadyToMerge', () => { ...@@ -519,8 +518,8 @@ describe('ReadyToMerge', () => {
}); });
it('should continue polling until MR is merged', done => { it('should continue polling until MR is merged', done => {
spyOn(vm.service, 'poll').and.returnValue(returnPromise('some_other_state')); jest.spyOn(vm.service, 'poll').mockReturnValue(returnPromise('some_other_state'));
spyOn(vm, 'initiateRemoveSourceBranchPolling'); jest.spyOn(vm, 'initiateRemoveSourceBranchPolling').mockImplementation(() => {});
let cpc = false; // continuePollingCalled let cpc = false; // continuePollingCalled
let spc = false; // stopPollingCalled let spc = false; // stopPollingCalled
...@@ -533,19 +532,18 @@ describe('ReadyToMerge', () => { ...@@ -533,19 +532,18 @@ describe('ReadyToMerge', () => {
spc = true; spc = true;
}, },
); );
setTimeout(() => { setImmediate(() => {
expect(cpc).toBeTruthy(); expect(cpc).toBeTruthy();
expect(spc).toBeFalsy(); expect(spc).toBeFalsy();
done(); done();
}, 333); });
}); });
}); });
describe('initiateRemoveSourceBranchPolling', () => { describe('initiateRemoveSourceBranchPolling', () => {
it('should emit event and call simplePoll', () => { it('should emit event and call simplePoll', () => {
spyOn(eventHub, '$emit'); jest.spyOn(eventHub, '$emit').mockImplementation(() => {});
const simplePoll = spyOnDependency(ReadyToMerge, 'simplePoll');
vm.initiateRemoveSourceBranchPolling(); vm.initiateRemoveSourceBranchPolling();
...@@ -565,8 +563,8 @@ describe('ReadyToMerge', () => { ...@@ -565,8 +563,8 @@ describe('ReadyToMerge', () => {
}); });
it('should call start and stop polling when MR merged', done => { it('should call start and stop polling when MR merged', done => {
spyOn(eventHub, '$emit'); jest.spyOn(eventHub, '$emit').mockImplementation(() => {});
spyOn(vm.service, 'poll').and.returnValue(returnPromise(false)); jest.spyOn(vm.service, 'poll').mockReturnValue(returnPromise(false));
let cpc = false; // continuePollingCalled let cpc = false; // continuePollingCalled
let spc = false; // stopPollingCalled let spc = false; // stopPollingCalled
...@@ -579,10 +577,10 @@ describe('ReadyToMerge', () => { ...@@ -579,10 +577,10 @@ describe('ReadyToMerge', () => {
spc = true; spc = true;
}, },
); );
setTimeout(() => { setImmediate(() => {
expect(vm.service.poll).toHaveBeenCalled(); expect(vm.service.poll).toHaveBeenCalled();
const args = eventHub.$emit.calls.argsFor(0); const args = eventHub.$emit.mock.calls[0];
expect(args[0]).toEqual('MRWidgetUpdateRequested'); expect(args[0]).toEqual('MRWidgetUpdateRequested');
expect(args[1]).toBeDefined(); expect(args[1]).toBeDefined();
...@@ -594,11 +592,11 @@ describe('ReadyToMerge', () => { ...@@ -594,11 +592,11 @@ describe('ReadyToMerge', () => {
expect(spc).toBeTruthy(); expect(spc).toBeTruthy();
done(); done();
}, 333); });
}); });
it('should continue polling until MR is merged', done => { it('should continue polling until MR is merged', done => {
spyOn(vm.service, 'poll').and.returnValue(returnPromise(true)); jest.spyOn(vm.service, 'poll').mockReturnValue(returnPromise(true));
let cpc = false; // continuePollingCalled let cpc = false; // continuePollingCalled
let spc = false; // stopPollingCalled let spc = false; // stopPollingCalled
...@@ -611,12 +609,12 @@ describe('ReadyToMerge', () => { ...@@ -611,12 +609,12 @@ describe('ReadyToMerge', () => {
spc = true; spc = true;
}, },
); );
setTimeout(() => { setImmediate(() => {
expect(cpc).toBeTruthy(); expect(cpc).toBeTruthy();
expect(spc).toBeFalsy(); expect(spc).toBeFalsy();
done(); done();
}, 333); });
}); });
}); });
}); });
......
import Vue from 'vue'; import Vue from 'vue';
import mountComponent from 'spec/helpers/vue_mount_component_helper'; import mountComponent from 'helpers/vue_mount_component_helper';
import { removeBreakLine } from 'spec/helpers/text_helper'; import { removeBreakLine } from 'helpers/text_helper';
import ShaMismatch from '~/vue_merge_request_widget/components/states/sha_mismatch.vue'; import ShaMismatch from '~/vue_merge_request_widget/components/states/sha_mismatch.vue';
describe('ShaMismatch', () => { describe('ShaMismatch', () => {
......
import Vue from 'vue'; import Vue from 'vue';
import mountComponent from 'spec/helpers/vue_mount_component_helper'; import mountComponent from 'helpers/vue_mount_component_helper';
import UnresolvedDiscussions from '~/vue_merge_request_widget/components/states/unresolved_discussions.vue'; import UnresolvedDiscussions from '~/vue_merge_request_widget/components/states/unresolved_discussions.vue';
import { TEST_HOST } from 'helpers/test_constants';
describe('UnresolvedDiscussions', () => { describe('UnresolvedDiscussions', () => {
const Component = Vue.extend(UnresolvedDiscussions); const Component = Vue.extend(UnresolvedDiscussions);
...@@ -14,7 +15,7 @@ describe('UnresolvedDiscussions', () => { ...@@ -14,7 +15,7 @@ describe('UnresolvedDiscussions', () => {
beforeEach(() => { beforeEach(() => {
vm = mountComponent(Component, { vm = mountComponent(Component, {
mr: { mr: {
createIssueToResolveDiscussionsPath: gl.TEST_HOST, createIssueToResolveDiscussionsPath: TEST_HOST,
}, },
}); });
}); });
...@@ -25,7 +26,7 @@ describe('UnresolvedDiscussions', () => { ...@@ -25,7 +26,7 @@ describe('UnresolvedDiscussions', () => {
); );
expect(vm.$el.innerText).toContain('Create an issue to resolve them later'); expect(vm.$el.innerText).toContain('Create an issue to resolve them later');
expect(vm.$el.querySelector('.js-create-issue').getAttribute('href')).toEqual(gl.TEST_HOST); expect(vm.$el.querySelector('.js-create-issue').getAttribute('href')).toEqual(TEST_HOST);
}); });
}); });
......
import Vue from 'vue'; import Vue from 'vue';
import WorkInProgress from '~/vue_merge_request_widget/components/states/work_in_progress.vue'; import WorkInProgress from '~/vue_merge_request_widget/components/states/work_in_progress.vue';
import eventHub from '~/vue_merge_request_widget/event_hub'; import eventHub from '~/vue_merge_request_widget/event_hub';
import createFlash from '~/flash';
jest.mock('~/flash');
const createComponent = () => { const createComponent = () => {
const Component = Vue.extend(WorkInProgress); const Component = Vue.extend(WorkInProgress);
...@@ -47,9 +50,8 @@ describe('Wip', () => { ...@@ -47,9 +50,8 @@ describe('Wip', () => {
it('should make a request to service and handle response', done => { it('should make a request to service and handle response', done => {
const vm = createComponent(); const vm = createComponent();
const flashSpy = spyOnDependency(WorkInProgress, 'createFlash').and.returnValue(true); jest.spyOn(eventHub, '$emit').mockImplementation(() => {});
spyOn(eventHub, '$emit'); jest.spyOn(vm.service, 'removeWIP').mockReturnValue(
spyOn(vm.service, 'removeWIP').and.returnValue(
new Promise(resolve => { new Promise(resolve => {
resolve({ resolve({
data: mrObj, data: mrObj,
...@@ -58,12 +60,15 @@ describe('Wip', () => { ...@@ -58,12 +60,15 @@ describe('Wip', () => {
); );
vm.handleRemoveWIP(); vm.handleRemoveWIP();
setTimeout(() => { setImmediate(() => {
expect(vm.isMakingRequest).toBeTruthy(); expect(vm.isMakingRequest).toBeTruthy();
expect(eventHub.$emit).toHaveBeenCalledWith('UpdateWidgetData', mrObj); expect(eventHub.$emit).toHaveBeenCalledWith('UpdateWidgetData', mrObj);
expect(flashSpy).toHaveBeenCalledWith('The merge request can now be merged.', 'notice'); expect(createFlash).toHaveBeenCalledWith(
'The merge request can now be merged.',
'notice',
);
done(); done();
}, 333); });
}); });
}); });
}); });
......
import Vue from 'vue'; import Vue from 'vue';
import Mousetrap from 'mousetrap'; import Mousetrap from 'mousetrap';
import { file } from 'jest/ide/helpers'; import { file } from 'jest/ide/helpers';
import timeoutPromise from 'spec/helpers/set_timeout_promise_helper'; import waitForPromises from 'helpers/wait_for_promises';
import FindFileComponent from '~/vue_shared/components/file_finder/index.vue'; import FindFileComponent from '~/vue_shared/components/file_finder/index.vue';
import { UP_KEY_CODE, DOWN_KEY_CODE, ENTER_KEY_CODE, ESC_KEY_CODE } from '~/lib/utils/keycodes'; import { UP_KEY_CODE, DOWN_KEY_CODE, ENTER_KEY_CODE, ESC_KEY_CODE } from '~/lib/utils/keycodes';
...@@ -48,7 +48,7 @@ describe('File finder item spec', () => { ...@@ -48,7 +48,7 @@ describe('File finder item spec', () => {
], ],
}); });
setTimeout(done); setImmediate(done);
}); });
it('renders list of blobs', () => { it('renders list of blobs', () => {
...@@ -60,7 +60,7 @@ describe('File finder item spec', () => { ...@@ -60,7 +60,7 @@ describe('File finder item spec', () => {
it('filters entries', done => { it('filters entries', done => {
vm.searchText = 'index'; vm.searchText = 'index';
setTimeout(() => { setImmediate(() => {
expect(vm.$el.textContent).toContain('index.js'); expect(vm.$el.textContent).toContain('index.js');
expect(vm.$el.textContent).not.toContain('component.js'); expect(vm.$el.textContent).not.toContain('component.js');
...@@ -71,7 +71,7 @@ describe('File finder item spec', () => { ...@@ -71,7 +71,7 @@ describe('File finder item spec', () => {
it('shows clear button when searchText is not empty', done => { it('shows clear button when searchText is not empty', done => {
vm.searchText = 'index'; vm.searchText = 'index';
setTimeout(() => { setImmediate(() => {
expect(vm.$el.querySelector('.dropdown-input').classList).toContain('has-value'); expect(vm.$el.querySelector('.dropdown-input').classList).toContain('has-value');
expect(vm.$el.querySelector('.dropdown-input-search').classList).toContain('hidden'); expect(vm.$el.querySelector('.dropdown-input-search').classList).toContain('hidden');
...@@ -82,11 +82,11 @@ describe('File finder item spec', () => { ...@@ -82,11 +82,11 @@ describe('File finder item spec', () => {
it('clear button resets searchText', done => { it('clear button resets searchText', done => {
vm.searchText = 'index'; vm.searchText = 'index';
timeoutPromise() waitForPromises()
.then(() => { .then(() => {
vm.$el.querySelector('.dropdown-input-clear').click(); vm.$el.querySelector('.dropdown-input-clear').click();
}) })
.then(timeoutPromise) .then(waitForPromises)
.then(() => { .then(() => {
expect(vm.searchText).toBe(''); expect(vm.searchText).toBe('');
}) })
...@@ -95,14 +95,14 @@ describe('File finder item spec', () => { ...@@ -95,14 +95,14 @@ describe('File finder item spec', () => {
}); });
it('clear button focues search input', done => { it('clear button focues search input', done => {
spyOn(vm.$refs.searchInput, 'focus'); jest.spyOn(vm.$refs.searchInput, 'focus').mockImplementation(() => {});
vm.searchText = 'index'; vm.searchText = 'index';
timeoutPromise() waitForPromises()
.then(() => { .then(() => {
vm.$el.querySelector('.dropdown-input-clear').click(); vm.$el.querySelector('.dropdown-input-clear').click();
}) })
.then(timeoutPromise) .then(waitForPromises)
.then(() => { .then(() => {
expect(vm.$refs.searchInput.focus).toHaveBeenCalled(); expect(vm.$refs.searchInput.focus).toHaveBeenCalled();
}) })
...@@ -114,7 +114,7 @@ describe('File finder item spec', () => { ...@@ -114,7 +114,7 @@ describe('File finder item spec', () => {
it('returns 1 when no filtered entries exist', done => { it('returns 1 when no filtered entries exist', done => {
vm.searchText = 'testing 123'; vm.searchText = 'testing 123';
setTimeout(() => { setImmediate(() => {
expect(vm.listShowCount).toBe(1); expect(vm.listShowCount).toBe(1);
done(); done();
...@@ -134,7 +134,7 @@ describe('File finder item spec', () => { ...@@ -134,7 +134,7 @@ describe('File finder item spec', () => {
it('returns 33 when entries dont exist', done => { it('returns 33 when entries dont exist', done => {
vm.searchText = 'testing 123'; vm.searchText = 'testing 123';
setTimeout(() => { setImmediate(() => {
expect(vm.listHeight).toBe(33); expect(vm.listHeight).toBe(33);
done(); done();
...@@ -146,7 +146,7 @@ describe('File finder item spec', () => { ...@@ -146,7 +146,7 @@ describe('File finder item spec', () => {
it('returns length of filtered blobs', done => { it('returns length of filtered blobs', done => {
vm.searchText = 'index'; vm.searchText = 'index';
setTimeout(() => { setImmediate(() => {
expect(vm.filteredBlobsLength).toBe(1); expect(vm.filteredBlobsLength).toBe(1);
done(); done();
...@@ -160,7 +160,7 @@ describe('File finder item spec', () => { ...@@ -160,7 +160,7 @@ describe('File finder item spec', () => {
vm.focusedIndex = 1; vm.focusedIndex = 1;
vm.searchText = 'test'; vm.searchText = 'test';
setTimeout(() => { setImmediate(() => {
expect(vm.focusedIndex).toBe(0); expect(vm.focusedIndex).toBe(0);
done(); done();
...@@ -173,11 +173,11 @@ describe('File finder item spec', () => { ...@@ -173,11 +173,11 @@ describe('File finder item spec', () => {
vm.searchText = 'test'; vm.searchText = 'test';
vm.visible = true; vm.visible = true;
timeoutPromise() waitForPromises()
.then(() => { .then(() => {
vm.visible = false; vm.visible = false;
}) })
.then(timeoutPromise) .then(waitForPromises)
.then(() => { .then(() => {
expect(vm.searchText).toBe(''); expect(vm.searchText).toBe('');
}) })
...@@ -189,7 +189,7 @@ describe('File finder item spec', () => { ...@@ -189,7 +189,7 @@ describe('File finder item spec', () => {
describe('openFile', () => { describe('openFile', () => {
beforeEach(() => { beforeEach(() => {
spyOn(vm, '$emit'); jest.spyOn(vm, '$emit').mockImplementation(() => {});
}); });
it('closes file finder', () => { it('closes file finder', () => {
...@@ -210,11 +210,11 @@ describe('File finder item spec', () => { ...@@ -210,11 +210,11 @@ describe('File finder item spec', () => {
const event = new CustomEvent('keyup'); const event = new CustomEvent('keyup');
event.keyCode = ENTER_KEY_CODE; event.keyCode = ENTER_KEY_CODE;
spyOn(vm, 'openFile'); jest.spyOn(vm, 'openFile').mockImplementation(() => {});
vm.$refs.searchInput.dispatchEvent(event); vm.$refs.searchInput.dispatchEvent(event);
setTimeout(() => { setImmediate(() => {
expect(vm.openFile).toHaveBeenCalledWith(vm.files[0]); expect(vm.openFile).toHaveBeenCalledWith(vm.files[0]);
done(); done();
...@@ -225,11 +225,11 @@ describe('File finder item spec', () => { ...@@ -225,11 +225,11 @@ describe('File finder item spec', () => {
const event = new CustomEvent('keyup'); const event = new CustomEvent('keyup');
event.keyCode = ESC_KEY_CODE; event.keyCode = ESC_KEY_CODE;
spyOn(vm, '$emit'); jest.spyOn(vm, '$emit').mockImplementation(() => {});
vm.$refs.searchInput.dispatchEvent(event); vm.$refs.searchInput.dispatchEvent(event);
setTimeout(() => { setImmediate(() => {
expect(vm.$emit).toHaveBeenCalledWith('toggle', false); expect(vm.$emit).toHaveBeenCalledWith('toggle', false);
done(); done();
...@@ -303,7 +303,7 @@ describe('File finder item spec', () => { ...@@ -303,7 +303,7 @@ describe('File finder item spec', () => {
beforeEach(done => { beforeEach(done => {
createComponent(); createComponent();
spyOn(vm, 'toggle'); jest.spyOn(vm, 'toggle').mockImplementation(() => {});
vm.$nextTick(done); vm.$nextTick(done);
}); });
......
import Vue from 'vue'; import Vue from 'vue';
import { mount } from '@vue/test-utils'; import { mount } from '@vue/test-utils';
import mountComponent from 'spec/helpers/vue_mount_component_helper'; import mountComponent from 'helpers/vue_mount_component_helper';
import Icon from '~/vue_shared/components/icon.vue'; import Icon from '~/vue_shared/components/icon.vue';
import iconsPath from '@gitlab/svgs/dist/icons.svg';
describe('Sprite Icon Component', function() { jest.mock('@gitlab/svgs/dist/icons.svg', () => 'testing');
describe('Initialization', function() {
describe('Sprite Icon Component', () => {
describe('Initialization', () => {
let icon; let icon;
beforeEach(function() { beforeEach(() => {
const IconComponent = Vue.extend(Icon); const IconComponent = Vue.extend(Icon);
icon = mountComponent(IconComponent, { icon = mountComponent(IconComponent, {
...@@ -20,20 +23,20 @@ describe('Sprite Icon Component', function() { ...@@ -20,20 +23,20 @@ describe('Sprite Icon Component', function() {
icon.$destroy(); icon.$destroy();
}); });
it('should return a defined Vue component', function() { it('should return a defined Vue component', () => {
expect(icon).toBeDefined(); expect(icon).toBeDefined();
}); });
it('should have <svg> as a child element', function() { it('should have <svg> as a child element', () => {
expect(icon.$el.tagName).toBe('svg'); expect(icon.$el.tagName).toBe('svg');
}); });
it('should have <use> as a child element with the correct href', function() { it('should have <use> as a child element with the correct href', () => {
expect(icon.$el.firstChild.tagName).toBe('use'); expect(icon.$el.firstChild.tagName).toBe('use');
expect(icon.$el.firstChild.getAttribute('xlink:href')).toBe(`${gon.sprite_icons}#commit`); expect(icon.$el.firstChild.getAttribute('xlink:href')).toBe(`${iconsPath}#commit`);
}); });
it('should properly compute iconSizeClass', function() { it('should properly compute iconSizeClass', () => {
expect(icon.iconSizeClass).toBe('s32'); expect(icon.iconSizeClass).toBe('s32');
}); });
...@@ -43,7 +46,7 @@ describe('Sprite Icon Component', function() { ...@@ -43,7 +46,7 @@ describe('Sprite Icon Component', function() {
expect(icon.$options.props.size.validator(9001)).toBeFalsy(); expect(icon.$options.props.size.validator(9001)).toBeFalsy();
}); });
it('should properly render img css', function() { it('should properly render img css', () => {
const { classList } = icon.$el; const { classList } = icon.$el;
const containsSizeClass = classList.contains('s32'); const containsSizeClass = classList.contains('s32');
...@@ -51,16 +54,18 @@ describe('Sprite Icon Component', function() { ...@@ -51,16 +54,18 @@ describe('Sprite Icon Component', function() {
}); });
it('`name` validator should return false for non existing icons', () => { it('`name` validator should return false for non existing icons', () => {
jest.spyOn(console, 'warn').mockImplementation();
expect(Icon.props.name.validator('non_existing_icon_sprite')).toBe(false); expect(Icon.props.name.validator('non_existing_icon_sprite')).toBe(false);
}); });
it('`name` validator should return false for existing icons', () => { it('`name` validator should return true for existing icons', () => {
expect(Icon.props.name.validator('commit')).toBe(true); expect(Icon.props.name.validator('commit')).toBe(true);
}); });
}); });
it('should call registered listeners when they are triggered', () => { it('should call registered listeners when they are triggered', () => {
const clickHandler = jasmine.createSpy('clickHandler'); const clickHandler = jest.fn();
const wrapper = mount(Icon, { const wrapper = mount(Icon, {
propsData: { name: 'commit' }, propsData: { name: 'commit' },
listeners: { click: clickHandler }, listeners: { click: clickHandler },
......
import Vue from 'vue'; import Vue from 'vue';
import mountComponent from 'spec/helpers/vue_mount_component_helper'; import mountComponent from 'helpers/vue_mount_component_helper';
import panelResizer from '~/vue_shared/components/panel_resizer.vue'; import panelResizer from '~/vue_shared/components/panel_resizer.vue';
describe('Panel Resizer component', () => { describe('Panel Resizer component', () => {
...@@ -69,12 +69,12 @@ describe('Panel Resizer component', () => { ...@@ -69,12 +69,12 @@ describe('Panel Resizer component', () => {
side: 'left', side: 'left',
}); });
spyOn(vm, '$emit'); jest.spyOn(vm, '$emit').mockImplementation(() => {});
triggerEvent('mousedown', vm.$el); triggerEvent('mousedown', vm.$el);
triggerEvent('mousemove', document); triggerEvent('mousemove', document);
triggerEvent('mouseup', document); triggerEvent('mouseup', document);
expect(vm.$emit.calls.allArgs()).toEqual([ expect(vm.$emit.mock.calls).toEqual([
['resize-start', 100], ['resize-start', 100],
['update:size', 100], ['update:size', 100],
['resize-end', 100], ['resize-end', 100],
......
import Vue from 'vue'; import Vue from 'vue';
import mountComponent from 'spec/helpers/vue_mount_component_helper'; import { mount } from '@vue/test-utils';
import SmartVirtualScrollList from '~/vue_shared/components/smart_virtual_list.vue'; import SmartVirtualScrollList from '~/vue_shared/components/smart_virtual_list.vue';
describe('Toggle Button', () => { describe('Toggle Button', () => {
...@@ -28,7 +28,7 @@ describe('Toggle Button', () => { ...@@ -28,7 +28,7 @@ describe('Toggle Button', () => {
</smart-virtual-scroll-list>`, </smart-virtual-scroll-list>`,
}); });
return mountComponent(Component); return mount(Component).vm;
}; };
afterEach(() => { afterEach(() => {
......
...@@ -9,13 +9,21 @@ describe('AutofocusOnShow directive', () => { ...@@ -9,13 +9,21 @@ describe('AutofocusOnShow directive', () => {
describe('with input invisible on component render', () => { describe('with input invisible on component render', () => {
let el; let el;
beforeAll(() => { beforeEach(() => {
setFixtures('<div id="container" style="display: none;"><input id="inputel"/></div>'); setFixtures('<div id="container" style="display: none;"><input id="inputel"/></div>');
el = document.querySelector('#inputel'); el = document.querySelector('#inputel');
window.IntersectionObserver = class {
observe = jest.fn();
};
});
afterEach(() => {
delete window.IntersectionObserver;
}); });
it('should bind IntersectionObserver on input element', () => { it('should bind IntersectionObserver on input element', () => {
spyOn(el, 'focus'); jest.spyOn(el, 'focus').mockImplementation(() => {});
autofocusonshow.inserted(el); autofocusonshow.inserted(el);
...@@ -27,7 +35,7 @@ describe('AutofocusOnShow directive', () => { ...@@ -27,7 +35,7 @@ describe('AutofocusOnShow directive', () => {
el.visibilityObserver = { el.visibilityObserver = {
disconnect: () => {}, disconnect: () => {},
}; };
spyOn(el.visibilityObserver, 'disconnect'); jest.spyOn(el.visibilityObserver, 'disconnect').mockImplementation(() => {});
autofocusonshow.unbind(el); autofocusonshow.unbind(el);
......
import testAction from 'spec/helpers/vuex_action_helper'; import testAction from 'helpers/vuex_action_helper';
import * as types from '~/vuex_shared/modules/modal/mutation_types'; import * as types from '~/vuex_shared/modules/modal/mutation_types';
import * as actions from '~/vuex_shared/modules/modal/actions'; import * as actions from '~/vuex_shared/modules/modal/actions';
......
export { default } from '../../frontend/vue_mr_widget/mock_data';
export * from '../../frontend/vue_mr_widget/mock_data';
export * from '../../../../frontend/vue_shared/components/issue/related_issuable_mock_data';
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