import * as types from '~/jobs/store/mutation_types'; import mutations from '~/jobs/store/mutations'; import state from '~/jobs/store/state'; describe('Jobs Store Mutations', () => { let stateCopy; let origGon; const html = 'I, [2018-08-17T22:57:45.707325 #1841] INFO -- : Writing /builds/ab89e95b0fa0b9272ea0c797b76908f24d36992630e9325273a4ce3.png
I'; beforeEach(() => { stateCopy = state(); origGon = window.gon; window.gon = { features: { infinitelyCollapsibleSections: false } }; }); afterEach(() => { window.gon = origGon; }); describe('SET_JOB_ENDPOINT', () => { it('should set jobEndpoint', () => { mutations[types.SET_JOB_ENDPOINT](stateCopy, 'job/21312321.json'); expect(stateCopy.jobEndpoint).toEqual('job/21312321.json'); }); }); describe('HIDE_SIDEBAR', () => { it('should set isSidebarOpen to false', () => { mutations[types.HIDE_SIDEBAR](stateCopy); expect(stateCopy.isSidebarOpen).toEqual(false); }); }); describe('SHOW_SIDEBAR', () => { it('should set isSidebarOpen to true', () => { mutations[types.SHOW_SIDEBAR](stateCopy); expect(stateCopy.isSidebarOpen).toEqual(true); }); }); describe('RECEIVE_JOB_LOG_SUCCESS', () => { describe('when job log has state', () => { it('sets jobLogState', () => { const stateLog = 'eyJvZmZzZXQiOjczNDQ1MSwibl9vcGVuX3RhZ3MiOjAsImZnX2NvbG9yIjpudWxsLCJiZ19jb2xvciI6bnVsbCwic3R5bGVfbWFzayI6MH0='; mutations[types.RECEIVE_JOB_LOG_SUCCESS](stateCopy, { state: stateLog, }); expect(stateCopy.jobLogState).toEqual(stateLog); }); }); describe('when jobLogSize is smaller than the total size', () => { it('sets isJobLogSizeVisible to true', () => { mutations[types.RECEIVE_JOB_LOG_SUCCESS](stateCopy, { total: 51184600, size: 1231 }); expect(stateCopy.isJobLogSizeVisible).toEqual(true); }); }); describe('when jobLogSize is bigger than the total size', () => { it('sets isJobLogSizeVisible to false', () => { const copy = { ...stateCopy, jobLogSize: 5118460, size: 2321312 }; mutations[types.RECEIVE_JOB_LOG_SUCCESS](copy, { total: 511846 }); expect(copy.isJobLogSizeVisible).toEqual(false); }); }); it('sets job log size and isJobLogComplete', () => { mutations[types.RECEIVE_JOB_LOG_SUCCESS](stateCopy, { append: true, html, size: 511846, complete: true, lines: [], }); expect(stateCopy.jobLogSize).toEqual(511846); expect(stateCopy.isJobLogComplete).toEqual(true); }); describe('with new job log', () => { describe('log.lines', () => { describe('when append is true', () => { it('sets the parsed log ', () => { mutations[types.RECEIVE_JOB_LOG_SUCCESS](stateCopy, { append: true, size: 511846, complete: true, lines: [ { offset: 1, content: [{ text: 'Running with gitlab-runner 11.12.1 (5a147c92)' }], }, ], }); expect(stateCopy.jobLog).toEqual([ { offset: 1, content: [{ text: 'Running with gitlab-runner 11.12.1 (5a147c92)' }], lineNumber: 0, }, ]); }); }); describe('when it is defined', () => { it('sets the parsed log ', () => { mutations[types.RECEIVE_JOB_LOG_SUCCESS](stateCopy, { append: false, size: 511846, complete: true, lines: [ { offset: 0, content: [{ text: 'Running with gitlab-runner 11.11.1 (5a147c92)' }] }, ], }); expect(stateCopy.jobLog).toEqual([ { offset: 0, content: [{ text: 'Running with gitlab-runner 11.11.1 (5a147c92)' }], lineNumber: 0, }, ]); }); }); describe('when it is null', () => { it('sets the default value', () => { mutations[types.RECEIVE_JOB_LOG_SUCCESS](stateCopy, { append: true, html, size: 511846, complete: false, lines: null, }); expect(stateCopy.jobLog).toEqual([]); }); }); }); }); }); describe('SET_JOB_LOG_TIMEOUT', () => { it('sets the jobLogTimeout id', () => { const id = 7; expect(stateCopy.jobLogTimeout).not.toEqual(id); mutations[types.SET_JOB_LOG_TIMEOUT](stateCopy, id); expect(stateCopy.jobLogTimeout).toEqual(id); }); }); describe('STOP_POLLING_JOB_LOG', () => { it('sets isJobLogComplete to true', () => { mutations[types.STOP_POLLING_JOB_LOG](stateCopy); expect(stateCopy.isJobLogComplete).toEqual(true); }); }); describe('TOGGLE_COLLAPSIBLE_LINE', () => { it('toggles the `isClosed` property of the provided object', () => { const section = { isClosed: true }; mutations[types.TOGGLE_COLLAPSIBLE_LINE](stateCopy, section); expect(section.isClosed).toEqual(false); }); }); describe('REQUEST_JOB', () => { it('sets isLoading to true', () => { mutations[types.REQUEST_JOB](stateCopy); expect(stateCopy.isLoading).toEqual(true); }); }); describe('RECEIVE_JOB_SUCCESS', () => { it('sets is loading to false', () => { mutations[types.RECEIVE_JOB_SUCCESS](stateCopy, { id: 1312321 }); expect(stateCopy.isLoading).toEqual(false); }); it('sets hasError to false', () => { mutations[types.RECEIVE_JOB_SUCCESS](stateCopy, { id: 1312321 }); expect(stateCopy.hasError).toEqual(false); }); it('sets job data', () => { mutations[types.RECEIVE_JOB_SUCCESS](stateCopy, { id: 1312321 }); expect(stateCopy.job).toEqual({ id: 1312321 }); }); it('sets selectedStage when the selectedStage is empty', () => { expect(stateCopy.selectedStage).toEqual(''); mutations[types.RECEIVE_JOB_SUCCESS](stateCopy, { id: 1312321, stage: 'deploy' }); expect(stateCopy.selectedStage).toEqual('deploy'); }); it('does not set selectedStage when the selectedStage is not More', () => { stateCopy.selectedStage = 'notify'; expect(stateCopy.selectedStage).toEqual('notify'); mutations[types.RECEIVE_JOB_SUCCESS](stateCopy, { id: 1312321, stage: 'deploy' }); expect(stateCopy.selectedStage).toEqual('notify'); }); }); describe('RECEIVE_JOB_ERROR', () => { it('resets job data', () => { mutations[types.RECEIVE_JOB_ERROR](stateCopy); expect(stateCopy.isLoading).toEqual(false); expect(stateCopy.job).toEqual({}); }); }); describe('REQUEST_JOBS_FOR_STAGE', () => { it('sets isLoadingJobs to true', () => { mutations[types.REQUEST_JOBS_FOR_STAGE](stateCopy, { name: 'deploy' }); expect(stateCopy.isLoadingJobs).toEqual(true); }); it('sets selectedStage', () => { mutations[types.REQUEST_JOBS_FOR_STAGE](stateCopy, { name: 'deploy' }); expect(stateCopy.selectedStage).toEqual('deploy'); }); }); describe('RECEIVE_JOBS_FOR_STAGE_SUCCESS', () => { beforeEach(() => { mutations[types.RECEIVE_JOBS_FOR_STAGE_SUCCESS](stateCopy, [{ name: 'karma' }]); }); it('sets isLoadingJobs to false', () => { expect(stateCopy.isLoadingJobs).toEqual(false); }); it('sets jobs', () => { expect(stateCopy.jobs).toEqual([{ name: 'karma' }]); }); }); describe('RECEIVE_JOBS_FOR_STAGE_ERROR', () => { beforeEach(() => { mutations[types.RECEIVE_JOBS_FOR_STAGE_ERROR](stateCopy); }); it('sets isLoadingJobs to false', () => { expect(stateCopy.isLoadingJobs).toEqual(false); }); it('resets jobs', () => { expect(stateCopy.jobs).toEqual([]); }); }); }); describe('Job Store mutations, feature flag ON', () => { let stateCopy; let origGon; const html = 'I, [2018-08-17T22:57:45.707325 #1841] INFO -- : Writing /builds/ab89e95b0fa0b9272ea0c797b76908f24d36992630e9325273a4ce3.png
I'; beforeEach(() => { stateCopy = state(); origGon = window.gon; window.gon = { features: { infinitelyCollapsibleSections: true } }; }); afterEach(() => { window.gon = origGon; }); describe('RECEIVE_JOB_LOG_SUCCESS', () => { describe('with new job log', () => { describe('log.lines', () => { describe('when append is true', () => { it('sets the parsed log ', () => { mutations[types.RECEIVE_JOB_LOG_SUCCESS](stateCopy, { append: true, size: 511846, complete: true, lines: [ { offset: 1, content: [{ text: 'Running with gitlab-runner 11.12.1 (5a147c92)' }], }, ], }); expect(stateCopy.jobLog).toEqual([ { offset: 1, content: [{ text: 'Running with gitlab-runner 11.12.1 (5a147c92)' }], lineNumber: 1, }, ]); }); }); describe('when lines are defined', () => { it('sets the parsed log ', () => { mutations[types.RECEIVE_JOB_LOG_SUCCESS](stateCopy, { append: false, size: 511846, complete: true, lines: [ { offset: 0, content: [{ text: 'Running with gitlab-runner 11.11.1 (5a147c92)' }] }, ], }); expect(stateCopy.jobLog).toEqual([ { offset: 0, content: [{ text: 'Running with gitlab-runner 11.11.1 (5a147c92)' }], lineNumber: 1, }, ]); }); }); describe('when lines are null', () => { it('sets the default value', () => { mutations[types.RECEIVE_JOB_LOG_SUCCESS](stateCopy, { append: true, html, size: 511846, complete: false, lines: null, }); expect(stateCopy.jobLog).toEqual([]); }); }); }); }); }); });