Merge pull request #2846 from kialam/fix-3016-missing-job-events

Fix 3016 missing job events

Reviewed-by: https://github.com/softwarefactory-project-zuul[bot]
This commit is contained in:
softwarefactory-project-zuul[bot]
2018-12-01 05:12:05 +00:00
committed by GitHub
3 changed files with 105 additions and 3 deletions

View File

@@ -8,4 +8,4 @@ import './side-nav.unit';
import './side-nav-item.unit';
import './jobs-list-split-jobs.unit';
import './job-details-split-jobs.unit';
import './stream.unit';

View File

@@ -0,0 +1,97 @@
import StreamService from '~features/output/stream.service';
describe('Output | StreamService', () => {
angular.module('test', []).service('StreamService', StreamService);
let stream;
beforeEach(() => {
angular.mock.module('test');
});
beforeEach(angular.mock.inject(($injector) => {
stream = $injector.get('StreamService');
const onFrames = angular.noop;
const onFrameRate = angular.noop;
stream.init({ onFrames, onFrameRate });
}));
describe('calcFactors', () => {
it('returns the expected values', () => {
const params = [
[-1, [1]],
[0, [1]],
[1, [1]],
[1.0, [1]],
[1.1, [1]],
[2, [1, 2]],
['1', [1]],
[{}, [1]],
[null, [1]],
[undefined, [1]],
[250, [1, 2, 5, 10, 25, 50, 125, 250]]
];
params.forEach(([size, expected]) =>
expect(stream.calcFactors(size)).toEqual(expected));
});
});
describe('setMissingCounterThreshold', () => {
it('returns the correct counter threshold', () => {
const gt = 2;
stream.setMissingCounterThreshold(gt);
expect(stream.counters.min).toEqual(gt);
const lt = -1;
stream.setMissingCounterThreshold(lt);
expect(stream.counters.min).toEqual(gt);
});
});
describe('isReadyToRender', () => {
it("it's never ready to render unless the result of getReadyCount is greater than 0", () => {
const params = [
[-1, false],
[0, false],
[1, true]
];
const spy = spyOn(stream, 'getReadyCount');
params.forEach(([readyCount, expected]) => {
spy.and.returnValue(readyCount);
expect(stream.isReadyToRender()).toEqual(expected);
});
});
});
describe('getMaxCounter', () => {
it('returns the same value as max counter', () => {
const res = stream.getMaxCounter();
expect(res).toEqual(stream.counters.max);
});
});
describe('getReadyCount', () => {
it('references min and max counters', () => {
expect(stream.getReadyCount()).toEqual(stream.counters.max - stream.counters.min + 1);
});
it('returns expected values if min or max value is a non-integer', () => {
const params = [
[null, 1, 0],
[undefined, 1, NaN],
['1', 1, 1],
[-1, -3, 3],
[0, 0, 1],
[6, 5, 2]
];
params.forEach(([max, min, expected]) => {
stream.counters.ready = max;
stream.counters.min = min;
expect(stream.getReadyCount()).toEqual(expected);
});
});
});
});