mirror of
https://github.com/grafana/grafana.git
synced 2025-08-03 04:04:14 +08:00

* fix any's in tests * fix more any's in tests * more test type fixes * fixing any's in tests part 3 * more test type fixes * fixing test any's p5 * some tidy up * fix template_srv
139 lines
5.0 KiB
TypeScript
139 lines
5.0 KiB
TypeScript
import { Observable, of, throwError } from 'rxjs';
|
|
|
|
import { AnnotationQuery, DataSourceApi, getDefaultTimeRange } from '@grafana/data';
|
|
import { createDashboardModelFixture } from 'app/features/dashboard/state/__fixtures__/dashboardFixtures';
|
|
|
|
import { silenceConsoleOutput } from '../../../../../test/core/utils/silenceConsoleOutput';
|
|
import * as store from '../../../../store/store';
|
|
import * as annotationsSrv from '../../../annotations/executeAnnotationQuery';
|
|
|
|
import { AnnotationsQueryRunner } from './AnnotationsQueryRunner';
|
|
import { toAsyncOfResult } from './testHelpers';
|
|
import { AnnotationQueryRunnerOptions } from './types';
|
|
|
|
function getDefaultOptions(): AnnotationQueryRunnerOptions {
|
|
const annotation = {} as AnnotationQuery;
|
|
const dashboard = createDashboardModelFixture();
|
|
const datasource = {
|
|
annotationQuery: {},
|
|
annotations: {},
|
|
} as unknown as DataSourceApi;
|
|
const range = getDefaultTimeRange();
|
|
|
|
return { annotation, datasource, dashboard, range };
|
|
}
|
|
|
|
function getTestContext(result: Observable<any> = toAsyncOfResult({ events: [{ id: '1' }] })) {
|
|
jest.clearAllMocks();
|
|
const dispatchMock = jest.spyOn(store, 'dispatch');
|
|
const options = getDefaultOptions();
|
|
const executeAnnotationQueryMock = jest.spyOn(annotationsSrv, 'executeAnnotationQuery').mockReturnValue(result);
|
|
|
|
return { options, dispatchMock, executeAnnotationQueryMock };
|
|
}
|
|
|
|
describe('AnnotationsQueryRunner', () => {
|
|
const runner = new AnnotationsQueryRunner();
|
|
|
|
describe('when canWork is called with correct props', () => {
|
|
it('then it should return true', () => {
|
|
const datasource = {
|
|
annotationQuery: jest.fn(),
|
|
annotations: {},
|
|
} as unknown as DataSourceApi;
|
|
|
|
expect(runner.canRun(datasource)).toBe(true);
|
|
});
|
|
});
|
|
|
|
describe('when canWork is called without datasource', () => {
|
|
it('then it should return false', () => {
|
|
const datasource = undefined;
|
|
|
|
expect(runner.canRun(datasource)).toBe(false);
|
|
});
|
|
});
|
|
|
|
describe('when canWork is called with incorrect props', () => {
|
|
it('then it should return false', () => {
|
|
const datasource = {
|
|
annotationQuery: jest.fn(),
|
|
} as unknown as DataSourceApi;
|
|
|
|
expect(runner.canRun(datasource)).toBe(false);
|
|
});
|
|
});
|
|
|
|
describe('when run is called with unsupported props', () => {
|
|
it('then it should return the correct results', async () => {
|
|
const datasource = {
|
|
annotationQuery: jest.fn(),
|
|
} as unknown as DataSourceApi;
|
|
const { options, executeAnnotationQueryMock } = getTestContext();
|
|
|
|
await expect(runner.run({ ...options, datasource })).toEmitValuesWith((received) => {
|
|
expect(received).toHaveLength(1);
|
|
const results = received[0];
|
|
expect(results).toEqual([]);
|
|
expect(executeAnnotationQueryMock).toHaveBeenCalledTimes(0);
|
|
});
|
|
});
|
|
});
|
|
|
|
describe('when run is called and the request is successful', () => {
|
|
it('then it should return the correct results', async () => {
|
|
const { options, executeAnnotationQueryMock } = getTestContext();
|
|
|
|
await expect(runner.run(options)).toEmitValuesWith((received) => {
|
|
expect(received).toHaveLength(1);
|
|
const results = received[0];
|
|
expect(results).toEqual([{ id: '1' }]);
|
|
expect(executeAnnotationQueryMock).toHaveBeenCalledTimes(1);
|
|
});
|
|
});
|
|
|
|
describe('but result is missing events prop', () => {
|
|
it('then it should return the correct results', async () => {
|
|
const { options, executeAnnotationQueryMock } = getTestContext(of({ id: '1' }));
|
|
|
|
await expect(runner.run(options)).toEmitValuesWith((received) => {
|
|
expect(received).toHaveLength(1);
|
|
const results = received[0];
|
|
expect(results).toEqual([]);
|
|
expect(executeAnnotationQueryMock).toHaveBeenCalledTimes(1);
|
|
});
|
|
});
|
|
});
|
|
});
|
|
|
|
describe('when run is called and the request fails', () => {
|
|
silenceConsoleOutput();
|
|
it('then it should return the correct results', async () => {
|
|
const { options, executeAnnotationQueryMock, dispatchMock } = getTestContext(throwError({ message: 'An error' }));
|
|
|
|
await expect(runner.run(options)).toEmitValuesWith((received) => {
|
|
expect(received).toHaveLength(1);
|
|
const results = received[0];
|
|
expect(results).toEqual([]);
|
|
expect(executeAnnotationQueryMock).toHaveBeenCalledTimes(1);
|
|
expect(dispatchMock).toHaveBeenCalledTimes(1);
|
|
});
|
|
});
|
|
});
|
|
|
|
describe('when run is called and the request is cancelled', () => {
|
|
silenceConsoleOutput();
|
|
it('then it should return the correct results', async () => {
|
|
const { options, executeAnnotationQueryMock, dispatchMock } = getTestContext(throwError({ cancelled: true }));
|
|
|
|
await expect(runner.run(options)).toEmitValuesWith((received) => {
|
|
expect(received).toHaveLength(1);
|
|
const results = received[0];
|
|
expect(results).toEqual([]);
|
|
expect(executeAnnotationQueryMock).toHaveBeenCalledTimes(1);
|
|
expect(dispatchMock).not.toHaveBeenCalled();
|
|
});
|
|
});
|
|
});
|
|
});
|