Skip to content

Commit

Permalink
[Fix] The overwritten series color from the legend is not visible whe…
Browse files Browse the repository at this point in the history
…n I create a visualization from a dashboard (elastic#93435)

* [Visualizations] Fixes the overwritten series color from legend is not visible when I create a visualization from a dashboard  --no-verify

* Remove unecessary code

* Fix types

Co-authored-by: Kibana Machine <[email protected]>
  • Loading branch information
stratoula and kibanamachine committed Mar 8, 2021
1 parent 10e0350 commit 416ba1d
Show file tree
Hide file tree
Showing 2 changed files with 101 additions and 5 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -7,7 +7,16 @@
*/

import { createSavedSearchesLoader } from '../../../../discover/public';
import { getVisualizationInstance } from './get_visualization_instance';
import type {
VisualizeInput,
VisSavedObject,
Vis,
VisParams,
} from 'src/plugins/visualizations/public';
import {
getVisualizationInstance,
getVisualizationInstanceFromInput,
} from './get_visualization_instance';
import { createVisualizeServicesMock } from './mocks';
import { VisualizeServices } from '../types';
import { BehaviorSubject } from 'rxjs';
Expand All @@ -25,8 +34,8 @@ describe('getVisualizationInstance', () => {
const serializedVisMock = {
type: 'area',
};
let savedVisMock: any;
let visMock: any;
let savedVisMock: VisSavedObject;
let visMock: Vis<VisParams>;
let mockServices: jest.Mocked<VisualizeServices>;
let subj: BehaviorSubject<any>;

Expand All @@ -36,8 +45,8 @@ describe('getVisualizationInstance', () => {
visMock = {
type: {},
data: {},
};
savedVisMock = {};
} as Vis<VisParams>;
savedVisMock = {} as VisSavedObject;
// @ts-expect-error
mockServices.data.search.showError.mockImplementation(() => {});
// @ts-expect-error
Expand Down Expand Up @@ -85,6 +94,7 @@ describe('getVisualizationInstance', () => {

test('should load existing vis by id and call vis type setup if exists', async () => {
const newVisObj = { data: {} };
// @ts-expect-error
visMock.type.setup = jest.fn(() => newVisObj);
const { vis } = await getVisualizationInstance(mockServices, 'saved_vis_id');

Expand Down Expand Up @@ -113,3 +123,85 @@ describe('getVisualizationInstance', () => {
expect(mockServices.data.search.showError).toHaveBeenCalled();
});
});

describe('getVisualizationInstanceInput', () => {
const serializedVisMock = {
type: 'pie',
};
let savedVisMock: VisSavedObject;
let visMock: Vis<VisParams>;
let mockServices: jest.Mocked<VisualizeServices>;
let subj: BehaviorSubject<any>;

beforeEach(() => {
mockServices = createVisualizeServicesMock();
subj = new BehaviorSubject({});
visMock = {
type: {},
data: {},
} as Vis<VisParams>;
savedVisMock = {} as VisSavedObject;
// @ts-expect-error
mockServices.savedVisualizations.get.mockImplementation(() => savedVisMock);
// @ts-expect-error
mockServices.visualizations.createVis.mockImplementation(() => visMock);
// @ts-expect-error
mockServices.createVisEmbeddableFromObject.mockImplementation(() => ({
getOutput$: jest.fn(() => subj.asObservable()),
}));
});

test('should create new instances of savedVis, vis and embeddableHandler', async () => {
const input = ({
id: 'test-id',
savedVis: {
title: '',
description: '',
type: 'pie',
params: {
type: 'pie',
addTooltip: true,
addLegend: true,
legendPosition: 'right',
isDonut: true,
labels: {
show: false,
values: true,
last_level: true,
truncate: 100,
},
},
uiState: {
vis: {
colors: {
Count: '#1F78C1',
},
},
},
},
} as unknown) as VisualizeInput;
const {
savedVis,
savedSearch,
vis,
embeddableHandler,
} = await getVisualizationInstanceFromInput(mockServices, input);

expect(mockServices.savedVisualizations.get).toHaveBeenCalled();
expect(mockServices.visualizations.createVis).toHaveBeenCalledWith(
serializedVisMock.type,
input.savedVis
);
expect(mockServices.createVisEmbeddableFromObject).toHaveBeenCalledWith(visMock, {
timeRange: undefined,
filters: undefined,
id: '',
});

expect(vis).toBe(visMock);
expect(savedVis).toBe(savedVisMock);
expect(savedVis.uiStateJSON).toBe(JSON.stringify(input.savedVis?.uiState));
expect(embeddableHandler).toBeDefined();
expect(savedSearch).toBeUndefined();
});
});
Original file line number Diff line number Diff line change
Expand Up @@ -68,6 +68,10 @@ export const getVisualizationInstanceFromInput = async (
* state of the visualization, into a new saved object.
*/
const savedVis: VisSavedObject = await savedVisualizations.get();
if (visState.uiState && Object.keys(visState.uiState).length !== 0) {
savedVis.uiStateJSON = JSON.stringify(visState.uiState);
}

let vis = await visualizations.createVis(visState.type, cloneDeep(visState));
if (vis.type.setup) {
try {
Expand Down

0 comments on commit 416ba1d

Please sign in to comment.