mirror of
https://github.com/grafana/grafana.git
synced 2024-11-29 04:04:00 -06:00
f8faacd54a
* - initial work on data source config page * - add links to test status box - add tracking function * - add test for the DataSourceConfigAlert component * - fix flicker of the alert box * - fix the build * - small improvements * - fix failing build * - fix failing unit tests * - prettier and betterer fixes * - fix failing e2e tests * - fix build again * - rewrite solution according to the PR comments * - cleanup * - fix failing e2e * - use absolute path in link * Minor fixes --------- Co-authored-by: Torkel Ödegaard <torkel@grafana.com>
107 lines
2.5 KiB
TypeScript
107 lines
2.5 KiB
TypeScript
import { Observable } from 'rxjs';
|
|
|
|
import {
|
|
DataQueryRequest,
|
|
DataQueryResponse,
|
|
TestDataSourceResponse,
|
|
DataSourceApi,
|
|
DataSourceInstanceSettings,
|
|
DataSourcePluginMeta,
|
|
DataSourceRef,
|
|
getDataSourceUID,
|
|
} from '@grafana/data';
|
|
|
|
export class DatasourceSrvMock {
|
|
constructor(private defaultDS: DataSourceApi, private datasources: { [name: string]: DataSourceApi }) {
|
|
//
|
|
}
|
|
|
|
get(ref?: DataSourceRef | string): Promise<DataSourceApi> {
|
|
if (!ref) {
|
|
return Promise.resolve(this.defaultDS);
|
|
}
|
|
const uid = getDataSourceUID(ref) ?? '';
|
|
const ds = this.datasources[uid];
|
|
if (ds) {
|
|
return Promise.resolve(ds);
|
|
}
|
|
return Promise.reject(`Unknown Datasource: ${JSON.stringify(ref)}`);
|
|
}
|
|
}
|
|
|
|
export class MockDataSourceApi extends DataSourceApi {
|
|
result: DataQueryResponse = { data: [] };
|
|
|
|
constructor(
|
|
name?: string,
|
|
result?: DataQueryResponse,
|
|
meta?: DataSourcePluginMeta,
|
|
public error: string | null = null
|
|
) {
|
|
super({ name: name ? name : 'MockDataSourceApi' } as DataSourceInstanceSettings);
|
|
if (result) {
|
|
this.result = result;
|
|
}
|
|
|
|
this.meta = meta || ({} as DataSourcePluginMeta);
|
|
}
|
|
|
|
query(request: DataQueryRequest): Promise<DataQueryResponse> {
|
|
if (this.error) {
|
|
return Promise.reject(this.error);
|
|
}
|
|
|
|
return new Promise((resolver) => {
|
|
setTimeout(() => {
|
|
resolver(this.result);
|
|
});
|
|
});
|
|
}
|
|
|
|
testDatasource(): Promise<TestDataSourceResponse> {
|
|
return Promise.resolve({ message: '', status: '' });
|
|
}
|
|
|
|
setupMixed(value: boolean) {
|
|
this.meta = this.meta || {};
|
|
this.meta.mixed = value;
|
|
return this;
|
|
}
|
|
}
|
|
|
|
export class MockObservableDataSourceApi extends DataSourceApi {
|
|
results: DataQueryResponse[] = [{ data: [] }];
|
|
|
|
constructor(
|
|
name?: string,
|
|
results?: DataQueryResponse[],
|
|
meta?: DataSourcePluginMeta,
|
|
private error: string | null = null
|
|
) {
|
|
super({ name: name ? name : 'MockDataSourceApi' } as DataSourceInstanceSettings);
|
|
|
|
if (results) {
|
|
this.results = results;
|
|
}
|
|
|
|
this.meta = meta || ({} as DataSourcePluginMeta);
|
|
}
|
|
|
|
query(request: DataQueryRequest): Observable<DataQueryResponse> {
|
|
return new Observable((observer) => {
|
|
if (this.error) {
|
|
observer.error(this.error);
|
|
}
|
|
|
|
if (this.results) {
|
|
this.results.forEach((response) => observer.next(response));
|
|
observer.complete();
|
|
}
|
|
});
|
|
}
|
|
|
|
testDatasource(): Promise<TestDataSourceResponse> {
|
|
return Promise.resolve({ message: '', status: '' });
|
|
}
|
|
}
|