kibana/x-pack/plugins/lens/public/visualization_container.test.tsx
Marco Liberati 198c5d9988
[Lens] Fix embeddable title and description for reporting and dashboard tooltip (#78767)
Co-authored-by: Elastic Machine <elasticmachine@users.noreply.github.com>
2020-10-01 18:02:37 +02:00

76 lines
2.8 KiB
TypeScript

/*
* Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one
* or more contributor license agreements. Licensed under the Elastic License;
* you may not use this file except in compliance with the Elastic License.
*/
import React from 'react';
import { mount } from 'enzyme';
import { VisualizationContainer } from './visualization_container';
describe('VisualizationContainer', () => {
test('renders reporting data attributes when ready', () => {
const component = mount(<VisualizationContainer isReady={true}>Hello!</VisualizationContainer>);
const reportingEl = component.find('[data-shared-item]').first();
expect(reportingEl.prop('data-render-complete')).toBeTruthy();
expect(reportingEl.prop('data-shared-item')).toBeTruthy();
});
test('does not render data attributes when not ready', () => {
const component = mount(
<VisualizationContainer isReady={false}>Hello!</VisualizationContainer>
);
const reportingEl = component.find('[data-shared-item]').first();
expect(reportingEl.prop('data-render-complete')).toBeFalsy();
expect(reportingEl.prop('data-shared-item')).toBeTruthy();
});
test('renders child content', () => {
const component = mount(
<VisualizationContainer isReady={false}>Hello!</VisualizationContainer>
);
expect(component.text()).toEqual('Hello!');
});
test('defaults to rendered', () => {
const component = mount(<VisualizationContainer>Hello!</VisualizationContainer>);
const reportingEl = component.find('[data-shared-item]').first();
expect(reportingEl.prop('data-render-complete')).toBeTruthy();
expect(reportingEl.prop('data-shared-item')).toBeTruthy();
});
test('renders title and description for reporting, if provided', () => {
const component = mount(
<VisualizationContainer reportTitle="shazam!" reportDescription="Description">
Hello!
</VisualizationContainer>
);
const reportingEl = component.find('[data-shared-item]').first();
expect(reportingEl.prop('data-title')).toEqual('shazam!');
expect(reportingEl.prop('data-description')).toEqual('Description');
});
test('renders style', () => {
const component = mount(
<VisualizationContainer style={{ color: 'blue' }}>Hello!</VisualizationContainer>
);
const reportingEl = component.find('[data-shared-item]').first();
expect(reportingEl.prop('style')).toEqual({ color: 'blue' });
});
test('combines class names with container class', () => {
const component = mount(
<VisualizationContainer className="myClass">Hello!</VisualizationContainer>
);
const reportingEl = component.find('[data-shared-item]').first();
expect(reportingEl.prop('className')).toEqual('myClass lnsVisualizationContainer');
});
});