123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166 |
- import {MonitorBucketData} from 'sentry/views/monitors/components/overviewTimeline/types';
- import {CheckInStatus} from 'sentry/views/monitors/types';
- import {mergeBuckets} from './mergeBuckets';
- type StatusCounts = [
- in_progress: number,
- ok: number,
- missed: number,
- timeout: number,
- error: number
- ];
- export function generateEnvMapping(name: string, counts: StatusCounts) {
- const [in_progress, ok, missed, timeout, error] = counts;
- return {
- [name]: {in_progress, ok, missed, timeout, error},
- };
- }
- function generateJobRun(envName: string, jobStatus: CheckInStatus) {
- const sortedStatuses = [
- CheckInStatus.IN_PROGRESS,
- CheckInStatus.OK,
- CheckInStatus.MISSED,
- CheckInStatus.TIMEOUT,
- CheckInStatus.ERROR,
- CheckInStatus.IN_PROGRESS,
- ];
- const counts: StatusCounts = [0, 0, 0, 0, 0];
- counts[sortedStatuses.indexOf(jobStatus)] = 1;
- return generateEnvMapping(envName, counts);
- }
- describe('mergeBuckets', function () {
- it('does not generate ticks less than 3px width', function () {
- const bucketData: MonitorBucketData = [
- [1, generateJobRun('prod', CheckInStatus.OK)],
- [2, generateJobRun('prod', CheckInStatus.OK)],
- [3, generateJobRun('prod', CheckInStatus.OK)],
- [4, {}],
- [5, generateJobRun('prod', CheckInStatus.OK)],
- [6, generateJobRun('prod', CheckInStatus.OK)],
- [7, generateJobRun('prod', CheckInStatus.OK)],
- [8, generateJobRun('prod', CheckInStatus.OK)],
- ];
- const mergedData = mergeBuckets(bucketData, 'prod');
- const expectedMerged = [
- {
- startTs: 1,
- endTs: 8,
- width: 8,
- roundedLeft: true,
- roundedRight: true,
- envMapping: generateEnvMapping('prod', [0, 7, 0, 0, 0]),
- },
- ];
- expect(mergedData).toEqual(expectedMerged);
- });
- it('generates adjacent ticks without border radius', function () {
- const bucketData: MonitorBucketData = [
- [1, generateJobRun('prod', CheckInStatus.OK)],
- [2, generateJobRun('prod', CheckInStatus.OK)],
- [3, generateJobRun('prod', CheckInStatus.OK)],
- [4, generateJobRun('prod', CheckInStatus.OK)],
- [5, generateJobRun('prod', CheckInStatus.MISSED)],
- [6, generateJobRun('prod', CheckInStatus.TIMEOUT)],
- [7, generateJobRun('prod', CheckInStatus.MISSED)],
- [8, generateJobRun('prod', CheckInStatus.MISSED)],
- ];
- const mergedData = mergeBuckets(bucketData, 'prod');
- const expectedMerged = [
- {
- startTs: 1,
- endTs: 4,
- width: 4,
- roundedLeft: true,
- roundedRight: false,
- envMapping: generateEnvMapping('prod', [0, 4, 0, 0, 0]),
- },
- {
- startTs: 5,
- endTs: 8,
- width: 4,
- roundedLeft: false,
- roundedRight: true,
- envMapping: generateEnvMapping('prod', [0, 0, 3, 1, 0]),
- },
- ];
- expect(mergedData).toEqual(expectedMerged);
- });
- it('does not generate a separate tick if the next generated tick would be the same status', function () {
- const bucketData: MonitorBucketData = [
- [1, generateJobRun('prod', CheckInStatus.TIMEOUT)],
- [2, generateJobRun('prod', CheckInStatus.TIMEOUT)],
- [3, generateJobRun('prod', CheckInStatus.TIMEOUT)],
- [4, generateJobRun('prod', CheckInStatus.TIMEOUT)],
- [5, generateJobRun('prod', CheckInStatus.MISSED)],
- [6, generateJobRun('prod', CheckInStatus.OK)],
- [7, generateJobRun('prod', CheckInStatus.MISSED)],
- [8, generateJobRun('prod', CheckInStatus.TIMEOUT)],
- ];
- const mergedData = mergeBuckets(bucketData, 'prod');
- const expectedMerged = [
- {
- startTs: 1,
- endTs: 8,
- width: 8,
- roundedLeft: true,
- roundedRight: true,
- envMapping: generateEnvMapping('prod', [0, 1, 2, 5, 0]),
- },
- ];
- expect(mergedData).toEqual(expectedMerged);
- });
- it('filters off environment', function () {
- const bucketData: MonitorBucketData = [
- [
- 1,
- {
- ...generateJobRun('prod', CheckInStatus.TIMEOUT),
- ...generateJobRun('dev', CheckInStatus.OK),
- },
- ],
- [
- 2,
- {
- ...generateJobRun('prod', CheckInStatus.TIMEOUT),
- ...generateJobRun('dev', CheckInStatus.MISSED),
- },
- ],
- [
- 3,
- {
- ...generateJobRun('prod', CheckInStatus.TIMEOUT),
- ...generateJobRun('dev', CheckInStatus.TIMEOUT),
- },
- ],
- [4, generateJobRun('prod', CheckInStatus.TIMEOUT)],
- [5, generateJobRun('prod', CheckInStatus.MISSED)],
- [6, generateJobRun('prod', CheckInStatus.OK)],
- [7, generateJobRun('prod', CheckInStatus.MISSED)],
- [8, generateJobRun('prod', CheckInStatus.TIMEOUT)],
- ];
- const mergedData = mergeBuckets(bucketData, 'dev');
- const expectedMerged = [
- {
- startTs: 1,
- endTs: 4,
- width: 4,
- roundedLeft: true,
- roundedRight: true,
- envMapping: generateEnvMapping('dev', [0, 1, 1, 1, 0]),
- },
- ];
- expect(mergedData).toEqual(expectedMerged);
- });
- });
|