2018-12-05 23:21:45 +05:30
|
|
|
import * as getters from '~/jobs/store/getters';
|
|
|
|
import state from '~/jobs/store/state';
|
|
|
|
|
|
|
|
describe('Job Store Getters', () => {
|
|
|
|
let localState;
|
|
|
|
|
|
|
|
beforeEach(() => {
|
|
|
|
localState = state();
|
|
|
|
});
|
|
|
|
|
|
|
|
describe('headerTime', () => {
|
|
|
|
describe('when the job has started key', () => {
|
|
|
|
it('returns started key', () => {
|
|
|
|
const started = '2018-08-31T16:20:49.023Z';
|
|
|
|
localState.job.started = started;
|
|
|
|
|
|
|
|
expect(getters.headerTime(localState)).toEqual(started);
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
describe('when the job does not have started key', () => {
|
|
|
|
it('returns created_at key', () => {
|
|
|
|
const created = '2018-08-31T16:20:49.023Z';
|
|
|
|
localState.job.created_at = created;
|
2018-12-13 13:39:08 +05:30
|
|
|
|
2018-12-05 23:21:45 +05:30
|
|
|
expect(getters.headerTime(localState)).toEqual(created);
|
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
describe('shouldRenderCalloutMessage', () => {
|
|
|
|
describe('with status and callout message', () => {
|
|
|
|
it('returns true', () => {
|
|
|
|
localState.job.callout_message = 'Callout message';
|
|
|
|
localState.job.status = { icon: 'passed' };
|
|
|
|
|
|
|
|
expect(getters.shouldRenderCalloutMessage(localState)).toEqual(true);
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
describe('without status & with callout message', () => {
|
|
|
|
it('returns false', () => {
|
|
|
|
localState.job.callout_message = 'Callout message';
|
2018-12-13 13:39:08 +05:30
|
|
|
|
2018-12-05 23:21:45 +05:30
|
|
|
expect(getters.shouldRenderCalloutMessage(localState)).toEqual(false);
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
describe('with status & without callout message', () => {
|
|
|
|
it('returns false', () => {
|
|
|
|
localState.job.status = { icon: 'passed' };
|
|
|
|
|
|
|
|
expect(getters.shouldRenderCalloutMessage(localState)).toEqual(false);
|
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
describe('shouldRenderTriggeredLabel', () => {
|
|
|
|
describe('when started equals null', () => {
|
|
|
|
it('returns false', () => {
|
|
|
|
localState.job.started = null;
|
2018-12-13 13:39:08 +05:30
|
|
|
|
2018-12-05 23:21:45 +05:30
|
|
|
expect(getters.shouldRenderTriggeredLabel(localState)).toEqual(false);
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
describe('when started equals string', () => {
|
|
|
|
it('returns true', () => {
|
|
|
|
localState.job.started = '2018-08-31T16:20:49.023Z';
|
2018-12-13 13:39:08 +05:30
|
|
|
|
2018-12-05 23:21:45 +05:30
|
|
|
expect(getters.shouldRenderTriggeredLabel(localState)).toEqual(true);
|
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
describe('hasEnvironment', () => {
|
|
|
|
describe('without `deployment_status`', () => {
|
|
|
|
it('returns false', () => {
|
|
|
|
expect(getters.hasEnvironment(localState)).toEqual(false);
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
describe('with an empty object for `deployment_status`', () => {
|
|
|
|
it('returns false', () => {
|
|
|
|
localState.job.deployment_status = {};
|
2018-12-13 13:39:08 +05:30
|
|
|
|
2018-12-05 23:21:45 +05:30
|
|
|
expect(getters.hasEnvironment(localState)).toEqual(false);
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
describe('when `deployment_status` is defined and not empty', () => {
|
|
|
|
it('returns true', () => {
|
|
|
|
localState.job.deployment_status = {
|
|
|
|
status: 'creating',
|
|
|
|
environment: {
|
|
|
|
last_deployment: {},
|
|
|
|
},
|
|
|
|
};
|
|
|
|
|
|
|
|
expect(getters.hasEnvironment(localState)).toEqual(true);
|
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
describe('hasTrace', () => {
|
|
|
|
describe('when has_trace is true', () => {
|
|
|
|
it('returns true', () => {
|
|
|
|
localState.job.has_trace = true;
|
|
|
|
localState.job.status = {};
|
|
|
|
|
|
|
|
expect(getters.hasTrace(localState)).toEqual(true);
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
describe('when job is running', () => {
|
|
|
|
it('returns true', () => {
|
|
|
|
localState.job.has_trace = false;
|
|
|
|
localState.job.status = { group: 'running' };
|
|
|
|
|
|
|
|
expect(getters.hasTrace(localState)).toEqual(true);
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
describe('when has_trace is false and job is not running', () => {
|
|
|
|
it('returns false', () => {
|
|
|
|
localState.job.has_trace = false;
|
|
|
|
localState.job.status = { group: 'pending' };
|
|
|
|
|
|
|
|
expect(getters.hasTrace(localState)).toEqual(false);
|
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
describe('emptyStateIllustration', () => {
|
|
|
|
describe('with defined illustration', () => {
|
|
|
|
it('returns the state illustration object', () => {
|
|
|
|
localState.job.status = {
|
|
|
|
illustration: {
|
|
|
|
path: 'foo',
|
|
|
|
},
|
|
|
|
};
|
|
|
|
|
|
|
|
expect(getters.emptyStateIllustration(localState)).toEqual({ path: 'foo' });
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
describe('when illustration is not defined', () => {
|
|
|
|
it('returns an empty object', () => {
|
|
|
|
expect(getters.emptyStateIllustration(localState)).toEqual({});
|
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
2019-05-18 00:54:41 +05:30
|
|
|
describe('shouldRenderSharedRunnerLimitWarning', () => {
|
|
|
|
describe('without runners information', () => {
|
|
|
|
it('returns false', () => {
|
|
|
|
expect(getters.shouldRenderSharedRunnerLimitWarning(localState)).toEqual(false);
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
describe('with runners information', () => {
|
|
|
|
describe('when used quota is less than limit', () => {
|
|
|
|
it('returns false', () => {
|
|
|
|
localState.job.runners = {
|
|
|
|
quota: {
|
|
|
|
used: 33,
|
|
|
|
limit: 2000,
|
|
|
|
},
|
|
|
|
available: true,
|
|
|
|
online: true,
|
|
|
|
};
|
|
|
|
|
|
|
|
expect(getters.shouldRenderSharedRunnerLimitWarning(localState)).toEqual(false);
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
describe('when used quota is equal to limit', () => {
|
|
|
|
it('returns true', () => {
|
|
|
|
localState.job.runners = {
|
|
|
|
quota: {
|
|
|
|
used: 2000,
|
|
|
|
limit: 2000,
|
|
|
|
},
|
|
|
|
available: true,
|
|
|
|
online: true,
|
|
|
|
};
|
|
|
|
|
|
|
|
expect(getters.shouldRenderSharedRunnerLimitWarning(localState)).toEqual(true);
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
describe('when used quota is bigger than limit', () => {
|
|
|
|
it('returns true', () => {
|
|
|
|
localState.job.runners = {
|
|
|
|
quota: {
|
|
|
|
used: 2002,
|
|
|
|
limit: 2000,
|
|
|
|
},
|
|
|
|
available: true,
|
|
|
|
online: true,
|
|
|
|
};
|
|
|
|
|
|
|
|
expect(getters.shouldRenderSharedRunnerLimitWarning(localState)).toEqual(true);
|
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
2018-12-13 13:39:08 +05:30
|
|
|
describe('hasRunnersForProject', () => {
|
|
|
|
describe('with available and offline runners', () => {
|
2018-12-05 23:21:45 +05:30
|
|
|
it('returns true', () => {
|
|
|
|
localState.job.runners = {
|
2018-12-13 13:39:08 +05:30
|
|
|
available: true,
|
|
|
|
online: false,
|
2018-12-05 23:21:45 +05:30
|
|
|
};
|
|
|
|
|
2018-12-13 13:39:08 +05:30
|
|
|
expect(getters.hasRunnersForProject(localState)).toEqual(true);
|
2018-12-05 23:21:45 +05:30
|
|
|
});
|
|
|
|
});
|
|
|
|
|
2018-12-13 13:39:08 +05:30
|
|
|
describe('with non available runners', () => {
|
2018-12-05 23:21:45 +05:30
|
|
|
it('returns false', () => {
|
|
|
|
localState.job.runners = {
|
|
|
|
available: false,
|
2018-12-13 13:39:08 +05:30
|
|
|
online: false,
|
2018-12-05 23:21:45 +05:30
|
|
|
};
|
|
|
|
|
2018-12-13 13:39:08 +05:30
|
|
|
expect(getters.hasRunnersForProject(localState)).toEqual(false);
|
2018-12-05 23:21:45 +05:30
|
|
|
});
|
|
|
|
});
|
|
|
|
|
2018-12-13 13:39:08 +05:30
|
|
|
describe('with online runners', () => {
|
2018-12-05 23:21:45 +05:30
|
|
|
it('returns false', () => {
|
|
|
|
localState.job.runners = {
|
2018-12-13 13:39:08 +05:30
|
|
|
available: false,
|
|
|
|
online: true,
|
2018-12-05 23:21:45 +05:30
|
|
|
};
|
|
|
|
|
2018-12-13 13:39:08 +05:30
|
|
|
expect(getters.hasRunnersForProject(localState)).toEqual(false);
|
2018-12-05 23:21:45 +05:30
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|