Commit 3ac176bb authored by Vitaly Slobodin's avatar Vitaly Slobodin Committed by Paul Slaughter

Fix MetricEmbed spec with a HTML fixture

- Fix MutationObserver
- Fix ES6 mock in RelatedIssuableInput spec
- Fix GraphComponent spec with a HTML fixture
- Remove redundant timers in branches_select_spec
- Fix eslint warning about unnamed function
- Remove unneeded regenerator-runtime
- Refactor setup and teardown in mr_rules_spec
- Add MutationObserver to DOM shims
- Fix Jest mock for hoisted variable
parent 9e50721d
...@@ -38,7 +38,6 @@ describe('Branches Select', () => { ...@@ -38,7 +38,6 @@ describe('Branches Select', () => {
const search = (term = '') => { const search = (term = '') => {
$input.select2('search', term); $input.select2('search', term);
jest.runAllTimers();
}; };
beforeEach(() => { beforeEach(() => {
...@@ -48,7 +47,6 @@ describe('Branches Select', () => { ...@@ -48,7 +47,6 @@ describe('Branches Select', () => {
}); });
afterEach(() => { afterEach(() => {
jest.clearAllTimers();
wrapper.destroy(); wrapper.destroy();
}); });
......
...@@ -17,6 +17,7 @@ describe('EE Approvals MRRules', () => { ...@@ -17,6 +17,7 @@ describe('EE Approvals MRRules', () => {
let wrapper; let wrapper;
let store; let store;
let approvalRules; let approvalRules;
let OriginalMutationObserver;
const factory = () => { const factory = () => {
if (approvalRules) { if (approvalRules) {
...@@ -50,16 +51,12 @@ describe('EE Approvals MRRules', () => { ...@@ -50,16 +51,12 @@ describe('EE Approvals MRRules', () => {
return onTargetBranchMutationHandler(); return onTargetBranchMutationHandler();
}; };
let OriginalMutationObserver; beforeEach(() => {
beforeAll(() => {
OriginalMutationObserver = global.MutationObserver; OriginalMutationObserver = global.MutationObserver;
}); global.MutationObserver = jest
.fn()
afterAll(() => { .mockImplementation(args => new OriginalMutationObserver(args));
global.MutationObserver = OriginalMutationObserver;
});
beforeEach(() => {
store = createStoreOptions(MREditModule()); store = createStoreOptions(MREditModule());
store.modules.approvals.state = { store.modules.approvals.state = {
hasLoaded: true, hasLoaded: true,
...@@ -73,19 +70,14 @@ describe('EE Approvals MRRules', () => { ...@@ -73,19 +70,14 @@ describe('EE Approvals MRRules', () => {
wrapper = null; wrapper = null;
store = null; store = null;
approvalRules = null; approvalRules = null;
global.MutationObserver = OriginalMutationObserver;
}); });
describe('when editing a MR', () => { describe('when editing a MR', () => {
const initialTargetBranch = 'master'; const initialTargetBranch = 'master';
let targetBranchInputElement; let targetBranchInputElement;
let MutationObserverMock;
beforeEach(() => { beforeEach(() => {
MutationObserverMock = jest
.fn()
.mockImplementation(args => new OriginalMutationObserver(args));
global.MutationObserver = MutationObserverMock;
targetBranchInputElement = document.createElement('input'); targetBranchInputElement = document.createElement('input');
targetBranchInputElement.id = 'merge_request_target_branch'; targetBranchInputElement.id = 'merge_request_target_branch';
targetBranchInputElement.value = initialTargetBranch; targetBranchInputElement.value = initialTargetBranch;
...@@ -103,7 +95,6 @@ describe('EE Approvals MRRules', () => { ...@@ -103,7 +95,6 @@ describe('EE Approvals MRRules', () => {
afterEach(() => { afterEach(() => {
targetBranchInputElement.parentNode.removeChild(targetBranchInputElement); targetBranchInputElement.parentNode.removeChild(targetBranchInputElement);
MutationObserverMock.mockClear();
}); });
it('sets the target branch data to be the same value as the target branch dropdown', () => { it('sets the target branch data to be the same value as the target branch dropdown', () => {
...@@ -115,20 +106,20 @@ describe('EE Approvals MRRules', () => { ...@@ -115,20 +106,20 @@ describe('EE Approvals MRRules', () => {
it('updates the target branch data when the target branch dropdown is changed', () => { it('updates the target branch data when the target branch dropdown is changed', () => {
factory(); factory();
const newValue = setTargetBranchInputValue(); const newValue = setTargetBranchInputValue();
callTargetBranchHandler(MutationObserverMock); callTargetBranchHandler(global.MutationObserver);
expect(wrapper.vm.targetBranch).toBe(newValue); expect(wrapper.vm.targetBranch).toBe(newValue);
}); });
it('re-fetches rules when target branch has changed', () => { it('re-fetches rules when target branch has changed', () => {
factory(); factory();
setTargetBranchInputValue(); setTargetBranchInputValue();
callTargetBranchHandler(MutationObserverMock); callTargetBranchHandler(global.MutationObserver);
expect(store.modules.approvals.actions.fetchRules).toHaveBeenCalled(); expect(store.modules.approvals.actions.fetchRules).toHaveBeenCalled();
}); });
it('disconnects MutationObserver when component gets destroyed', () => { it('disconnects MutationObserver when component gets destroyed', () => {
const mockDisconnect = jest.fn(); const mockDisconnect = jest.fn();
MutationObserverMock.mockImplementation(() => ({ global.MutationObserver.mockImplementation(() => ({
disconnect: mockDisconnect, disconnect: mockDisconnect,
observe: jest.fn(), observe: jest.fn(),
})); }));
......
...@@ -3,15 +3,14 @@ import { TEST_HOST } from 'helpers/test_constants'; ...@@ -3,15 +3,14 @@ import { TEST_HOST } from 'helpers/test_constants';
import { issuableTypesMap, PathIdSeparator } from 'ee/related_issues/constants'; import { issuableTypesMap, PathIdSeparator } from 'ee/related_issues/constants';
import RelatedIssuableInput from 'ee/related_issues/components/related_issuable_input.vue'; import RelatedIssuableInput from 'ee/related_issues/components/related_issuable_input.vue';
jest.mock('ee_else_ce/gfm_auto_complete', () => ({ jest.mock('ee_else_ce/gfm_auto_complete', () => {
__esModule: true, return function gfmAutoComplete() {
default() {
return { return {
constructor() {}, constructor() {},
setup() {}, setup() {},
}; };
}, };
})); });
describe('RelatedIssuableInput', () => { describe('RelatedIssuableInput', () => {
let propsData; let propsData;
......
...@@ -4,9 +4,8 @@ import ClipboardButton from '~/vue_shared/components/clipboard_button.vue'; ...@@ -4,9 +4,8 @@ import ClipboardButton from '~/vue_shared/components/clipboard_button.vue';
import { Blob as MockBlob } from './mock_data'; import { Blob as MockBlob } from './mock_data';
import { numberToHumanSize } from '~/lib/utils/number_utils'; import { numberToHumanSize } from '~/lib/utils/number_utils';
const mockHumanReadableSize = 'a lot';
jest.mock('~/lib/utils/number_utils', () => ({ jest.mock('~/lib/utils/number_utils', () => ({
numberToHumanSize: jest.fn(() => mockHumanReadableSize), numberToHumanSize: jest.fn(() => 'a lot'),
})); }));
describe('Blob Header Filepath', () => { describe('Blob Header Filepath', () => {
...@@ -57,7 +56,7 @@ describe('Blob Header Filepath', () => { ...@@ -57,7 +56,7 @@ describe('Blob Header Filepath', () => {
it('renders filesize in a human-friendly format', () => { it('renders filesize in a human-friendly format', () => {
createComponent(); createComponent();
expect(numberToHumanSize).toHaveBeenCalled(); expect(numberToHumanSize).toHaveBeenCalled();
expect(wrapper.vm.blobSize).toBe(mockHumanReadableSize); expect(wrapper.vm.blobSize).toBe('a lot');
}); });
it('renders a slot and prepends its contents to the existing one', () => { it('renders a slot and prepends its contents to the existing one', () => {
......
...@@ -4,6 +4,7 @@ import './element_scroll_to'; ...@@ -4,6 +4,7 @@ import './element_scroll_to';
import './form_element'; import './form_element';
import './get_client_rects'; import './get_client_rects';
import './inner_text'; import './inner_text';
import './mutation_observer';
import './window_scroll_to'; import './window_scroll_to';
import './scroll_by'; import './scroll_by';
import './size_properties'; import './size_properties';
......
/* eslint-disable class-methods-use-this */
class MutationObserverStub {
disconnect() {}
observe() {}
}
global.MutationObserver = MutationObserverStub;
...@@ -4,6 +4,7 @@ import DashboardPanel from '~/monitoring/components/dashboard_panel.vue'; ...@@ -4,6 +4,7 @@ import DashboardPanel from '~/monitoring/components/dashboard_panel.vue';
import { TEST_HOST } from 'helpers/test_constants'; import { TEST_HOST } from 'helpers/test_constants';
import MetricEmbed from '~/monitoring/components/embeds/metric_embed.vue'; import MetricEmbed from '~/monitoring/components/embeds/metric_embed.vue';
import { groups, initialState, metricsData, metricsWithData } from './mock_data'; import { groups, initialState, metricsData, metricsWithData } from './mock_data';
import { setHTMLFixture } from 'helpers/fixtures';
const localVue = createLocalVue(); const localVue = createLocalVue();
localVue.use(Vuex); localVue.use(Vuex);
...@@ -25,6 +26,8 @@ describe('MetricEmbed', () => { ...@@ -25,6 +26,8 @@ describe('MetricEmbed', () => {
} }
beforeEach(() => { beforeEach(() => {
setHTMLFixture('<div class="layout-page"></div>');
actions = { actions = {
setInitialState: jest.fn(), setInitialState: jest.fn(),
setShowErrorBanner: jest.fn(), setShowErrorBanner: jest.fn(),
......
...@@ -7,6 +7,7 @@ import linkedPipelinesColumn from '~/pipelines/components/graph/linked_pipelines ...@@ -7,6 +7,7 @@ import linkedPipelinesColumn from '~/pipelines/components/graph/linked_pipelines
import graphJSON from './mock_data'; import graphJSON from './mock_data';
import linkedPipelineJSON from './linked_pipelines_mock_data'; import linkedPipelineJSON from './linked_pipelines_mock_data';
import PipelinesMediator from '~/pipelines/pipeline_details_mediator'; import PipelinesMediator from '~/pipelines/pipeline_details_mediator';
import { setHTMLFixture } from 'helpers/fixtures';
describe('graph component', () => { describe('graph component', () => {
const store = new PipelineStore(); const store = new PipelineStore();
...@@ -15,6 +16,10 @@ describe('graph component', () => { ...@@ -15,6 +16,10 @@ describe('graph component', () => {
let wrapper; let wrapper;
beforeEach(() => {
setHTMLFixture('<div class="layout-page"></div>');
});
afterEach(() => { afterEach(() => {
wrapper.destroy(); wrapper.destroy();
wrapper = null; wrapper = null;
......
...@@ -43,15 +43,6 @@ Object.assign(global, { ...@@ -43,15 +43,6 @@ Object.assign(global, {
preloadFixtures() {}, preloadFixtures() {},
}); });
Object.assign(global, {
MutationObserver() {
return {
disconnect() {},
observe() {},
};
},
});
// custom-jquery-matchers was written for an old Jest version, we need to make it compatible // custom-jquery-matchers was written for an old Jest version, we need to make it compatible
Object.entries(jqueryMatchers).forEach(([matcherName, matcherFactory]) => { Object.entries(jqueryMatchers).forEach(([matcherName, matcherFactory]) => {
// Don't override existing Jest matcher // Don't override existing Jest matcher
...@@ -69,12 +60,6 @@ expect.extend(customMatchers); ...@@ -69,12 +60,6 @@ expect.extend(customMatchers);
// Tech debt issue TBD // Tech debt issue TBD
testUtilsConfig.logModifiedComponents = false; testUtilsConfig.logModifiedComponents = false;
// Basic stub for MutationObserver
global.MutationObserver = () => ({
disconnect: () => {},
observe: () => {},
});
Object.assign(global, { Object.assign(global, {
requestIdleCallback(cb) { requestIdleCallback(cb) {
const start = Date.now(); const start = Date.now();
......
...@@ -9647,11 +9647,6 @@ regenerate@^1.4.0: ...@@ -9647,11 +9647,6 @@ regenerate@^1.4.0:
resolved "https://registry.yarnpkg.com/regenerate/-/regenerate-1.4.0.tgz#4a856ec4b56e4077c557589cae85e7a4c8869a11" resolved "https://registry.yarnpkg.com/regenerate/-/regenerate-1.4.0.tgz#4a856ec4b56e4077c557589cae85e7a4c8869a11"
integrity sha512-1G6jJVDWrt0rK99kBjvEtziZNCICAuvIPkSiUFIQxVP06RCVpq3dmDo2oi6ABpYaDYaTRr67BEhL8r1wgEZZKg== integrity sha512-1G6jJVDWrt0rK99kBjvEtziZNCICAuvIPkSiUFIQxVP06RCVpq3dmDo2oi6ABpYaDYaTRr67BEhL8r1wgEZZKg==
regenerator-runtime@^0.13.5:
version "0.13.5"
resolved "https://registry.yarnpkg.com/regenerator-runtime/-/regenerator-runtime-0.13.5.tgz#d878a1d094b4306d10b9096484b33ebd55e26697"
integrity sha512-ZS5w8CpKFinUzOwW3c83oPeVXoNsrLsaCoLtJvAClH135j/R77RuymhiSErhm2lKcwSCIpmvIWSbDkIfAqKQlA==
regenerator-transform@^0.14.0: regenerator-transform@^0.14.0:
version "0.14.1" version "0.14.1"
resolved "https://registry.yarnpkg.com/regenerator-transform/-/regenerator-transform-0.14.1.tgz#3b2fce4e1ab7732c08f665dfdb314749c7ddd2fb" resolved "https://registry.yarnpkg.com/regenerator-transform/-/regenerator-transform-0.14.1.tgz#3b2fce4e1ab7732c08f665dfdb314749c7ddd2fb"
......
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