Browse Source

Explore: Fix empty result from datasource should render logs container (#16999)

Make sure to return an empty logs model instead of undefined so that 
the logs container renders an empty graph and log result in Explore.

Fixes #16997
Marcus Efraimsson 6 years ago
parent
commit
8eb78ea931
2 changed files with 21 additions and 9 deletions
  1. 6 1
      public/app/core/logs_model.ts
  2. 15 8
      public/app/core/specs/logs_model.test.ts

+ 6 - 1
public/app/core/logs_model.ts

@@ -356,7 +356,12 @@ export function seriesDataToLogsModel(seriesData: SeriesData[], intervalMs: numb
     return logsModel;
     return logsModel;
   }
   }
 
 
-  return undefined;
+  return {
+    hasUniqueLabels: false,
+    rows: [],
+    meta: [],
+    series: [],
+  };
 }
 }
 
 
 export function logSeriesToLogsModel(logSeries: SeriesData[]): LogsModel {
 export function logSeriesToLogsModel(logSeries: SeriesData[]): LogsModel {

+ 15 - 8
public/app/core/specs/logs_model.test.ts

@@ -333,22 +333,29 @@ describe('LogsParsers', () => {
   });
   });
 });
 });
 
 
+const emptyLogsModel = {
+  hasUniqueLabels: false,
+  rows: [],
+  meta: [],
+  series: [],
+};
+
 describe('seriesDataToLogsModel', () => {
 describe('seriesDataToLogsModel', () => {
-  it('given empty series should return undefined', () => {
-    expect(seriesDataToLogsModel([] as SeriesData[], 0)).toBeUndefined();
+  it('given empty series should return empty logs model', () => {
+    expect(seriesDataToLogsModel([] as SeriesData[], 0)).toMatchObject(emptyLogsModel);
   });
   });
 
 
-  it('given series without correct series name should not be processed', () => {
+  it('given series without correct series name should return empty logs model', () => {
     const series: SeriesData[] = [
     const series: SeriesData[] = [
       {
       {
         fields: [],
         fields: [],
         rows: [],
         rows: [],
       },
       },
     ];
     ];
-    expect(seriesDataToLogsModel(series, 0)).toBeUndefined();
+    expect(seriesDataToLogsModel(series, 0)).toMatchObject(emptyLogsModel);
   });
   });
 
 
-  it('given series without a time field should not be processed', () => {
+  it('given series without a time field should return empty logs model', () => {
     const series: SeriesData[] = [
     const series: SeriesData[] = [
       {
       {
         fields: [
         fields: [
@@ -360,10 +367,10 @@ describe('seriesDataToLogsModel', () => {
         rows: [],
         rows: [],
       },
       },
     ];
     ];
-    expect(seriesDataToLogsModel(series, 0)).toBeUndefined();
+    expect(seriesDataToLogsModel(series, 0)).toMatchObject(emptyLogsModel);
   });
   });
 
 
-  it('given series without a string field should not be processed', () => {
+  it('given series without a string field should return empty logs model', () => {
     const series: SeriesData[] = [
     const series: SeriesData[] = [
       {
       {
         fields: [
         fields: [
@@ -375,7 +382,7 @@ describe('seriesDataToLogsModel', () => {
         rows: [],
         rows: [],
       },
       },
     ];
     ];
-    expect(seriesDataToLogsModel(series, 0)).toBeUndefined();
+    expect(seriesDataToLogsModel(series, 0)).toMatchObject(emptyLogsModel);
   });
   });
 
 
   it('given one series should return expected logs model', () => {
   it('given one series should return expected logs model', () => {