mirror of
https://github.com/grafana/grafana.git
synced 2025-02-13 00:55:47 -06:00
* feat: add draft version of validate button
* feat: add some styling and basics
* temp: intermediate result
* refactor: solve TODOs
* refactor: replace string in state
* refactor: replace error message style
* refactor: set validate state on change in ds
* refactor: add QueryRunner
* refactor: add QueryRunner
* temp: temporary status
* Emit PanelData to check if the query is valid
* refactor: clean up
* refactor: improve a11y of error message and adjust test
* Remove deprecated property call, change equality
* refactor: add changes from code review
* refactor: remove memory leak
* refactor: replace query runner
* refactor: adjust error handling
* refactor: move testing to related unit test
* refactor: clean up test for QueryEditorField
* refactor: clean up test for CorrelationsPage
* refactor: repair test
* refactor: clean up
* refactor: add refId in order avoid errors when running Loki queries
* refactor: replace buildQueryTransaction + set query to invalid if query is empty
* refactor: add empty query value to test cases
* refactor: end handleValidation after setIsValidQuery()
* refactor: refactor test
* refactor: fix last two tests
* refactor: modify validation
* refactor: add happy path
* refactor: clean up
* refactor: clean up tests (not final)
* refactor: further clean up
* refactor: add condition for failing
* refactor: finish clean up
* refactor: changes from code review
* refactor: add response state to condition
Co-authored-by: Piotr Jamróz <pm.jamroz@gmail.com>
* refactor: fix prettier issue
* refactor: remove unused return
* refactor: replace change in queryAnalytics.ts
* refactor: remove correlations from query analytics
* refactor: remove unnecessary test preparation
* refactor: revert changes from commit 4997327
Co-authored-by: Piotr Jamróz <pm.jamroz@gmail.com>
Co-authored-by: Kristina Durivage <kristina.durivage@grafana.com>
86 lines
2.8 KiB
TypeScript
86 lines
2.8 KiB
TypeScript
import { PanelData, LoadingState, DataSourceApi, CoreApp, urlUtil } from '@grafana/data';
|
|
import { reportMetaAnalytics, MetaAnalyticsEventName, DataRequestEventPayload } from '@grafana/runtime';
|
|
|
|
import { getDashboardSrv } from '../../dashboard/services/DashboardSrv';
|
|
|
|
export function emitDataRequestEvent(datasource: DataSourceApi) {
|
|
let done = false;
|
|
|
|
return (data: PanelData) => {
|
|
if (!data.request || done) {
|
|
return;
|
|
}
|
|
|
|
const params = urlUtil.getUrlSearchParams();
|
|
if (params.editPanel != null) {
|
|
return;
|
|
}
|
|
|
|
if (data.state !== LoadingState.Done && data.state !== LoadingState.Error) {
|
|
return;
|
|
}
|
|
|
|
const eventData: DataRequestEventPayload = {
|
|
eventName: MetaAnalyticsEventName.DataRequest,
|
|
source: data.request.app,
|
|
datasourceName: datasource.name,
|
|
datasourceId: datasource.id,
|
|
datasourceUid: datasource.uid,
|
|
datasourceType: datasource.type,
|
|
dataSize: 0,
|
|
duration: data.request.endTime! - data.request.startTime,
|
|
};
|
|
|
|
if (data.request.app === CoreApp.Explore || data.request.app === CoreApp.Correlations) {
|
|
enrichWithInfo(eventData, data);
|
|
} else {
|
|
enrichWithDashboardInfo(eventData, data);
|
|
}
|
|
|
|
if (data.series && data.series.length > 0) {
|
|
// estimate size
|
|
eventData.dataSize = data.series.length;
|
|
}
|
|
|
|
reportMetaAnalytics(eventData);
|
|
|
|
// this done check is to make sure we do not double emit events in case
|
|
// there are multiple responses with done state
|
|
done = true;
|
|
};
|
|
|
|
function enrichWithInfo(eventData: DataRequestEventPayload, data: PanelData) {
|
|
const totalQueries = Object.keys(data.series).length;
|
|
eventData.totalQueries = totalQueries;
|
|
}
|
|
|
|
function enrichWithDashboardInfo(eventData: DataRequestEventPayload, data: PanelData) {
|
|
const queryCacheStatus: { [key: string]: boolean } = {};
|
|
for (let i = 0; i < data.series.length; i++) {
|
|
const refId = data.series[i].refId;
|
|
if (refId && !queryCacheStatus[refId]) {
|
|
queryCacheStatus[refId] = data.series[i].meta?.isCachedResponse ?? false;
|
|
}
|
|
}
|
|
const totalQueries = Object.keys(queryCacheStatus).length;
|
|
const cachedQueries = Object.values(queryCacheStatus).filter((val) => val === true).length;
|
|
|
|
eventData.panelId = data.request!.panelId;
|
|
eventData.dashboardId = data.request!.dashboardId;
|
|
eventData.totalQueries = totalQueries;
|
|
eventData.cachedQueries = cachedQueries;
|
|
|
|
const dashboard = getDashboardSrv().getCurrent();
|
|
if (dashboard) {
|
|
eventData.dashboardId = dashboard.id;
|
|
eventData.dashboardName = dashboard.title;
|
|
eventData.dashboardUid = dashboard.uid;
|
|
eventData.folderName = dashboard.meta.folderTitle;
|
|
}
|
|
|
|
if (data.error) {
|
|
eventData.error = data.error.message;
|
|
}
|
|
}
|
|
}
|