[READY] Update SuperChart onRenderXXX listeners (#6376)

* Revise LoadableRenderer (+3 squashed commits)
Squashed commits:
[f1614c7c] extract createLoadableRenderer into a separate function
[8689bc94] extend LoadableRenderer
[3d04ff2b] remove skipRendering

* add number of times function was called to the test
This commit is contained in:
Krist Wongsuphasawat
2018-11-29 11:09:08 -08:00
committed by GitHub
parent 2731a010ca
commit e715cdb9ac
4 changed files with 162 additions and 17 deletions

View File

@@ -0,0 +1,94 @@
import React from 'react';
import { shallow } from 'enzyme';
import createLoadableRenderer from 'src/visualizations/core/components/createLoadableRenderer';
describe('createLoadableRenderer', () => {
function TestComponent() {
return (
<div className="test-component">test</div>
);
}
let loadChartSuccess;
let render;
let loading;
let LoadableRenderer;
beforeEach(() => {
loadChartSuccess = jest.fn(() => Promise.resolve(TestComponent));
render = jest.fn((loaded) => {
const { Chart } = loaded;
return (<Chart />);
});
loading = jest.fn(() => (<div>Loading</div>));
LoadableRenderer = createLoadableRenderer({
loader: {
Chart: loadChartSuccess,
},
loading,
render,
});
});
describe('returns a LoadableRenderer class', () => {
it('LoadableRenderer.preload() preloads the lazy-load components', () => {
expect(LoadableRenderer.preload).toBeInstanceOf(Function);
LoadableRenderer.preload();
expect(loadChartSuccess).toHaveBeenCalledTimes(1);
});
it('calls onRenderSuccess when succeeds', (done) => {
const onRenderSuccess = jest.fn();
const onRenderFailure = jest.fn();
shallow(
<LoadableRenderer
onRenderSuccess={onRenderSuccess}
onRenderFailure={onRenderFailure}
/>,
);
expect(loadChartSuccess).toHaveBeenCalled();
setTimeout(() => {
expect(render).toHaveBeenCalledTimes(1);
expect(onRenderSuccess).toHaveBeenCalledTimes(1);
expect(onRenderFailure).not.toHaveBeenCalled();
done();
}, 10);
});
it('calls onRenderFailure when fails', (done) => {
const loadChartFailure = jest.fn(() => Promise.reject('Invalid chart'));
const FailedRenderer = createLoadableRenderer({
loader: {
Chart: loadChartFailure,
},
loading,
render,
});
const onRenderSuccess = jest.fn();
const onRenderFailure = jest.fn();
shallow(
<FailedRenderer
onRenderSuccess={onRenderSuccess}
onRenderFailure={onRenderFailure}
/>,
);
expect(loadChartFailure).toHaveBeenCalledTimes(1);
setTimeout(() => {
expect(render).not.toHaveBeenCalled();
expect(onRenderSuccess).not.toHaveBeenCalled();
expect(onRenderFailure).toHaveBeenCalledTimes(1);
done();
}, 10);
});
it('renders the lazy-load components', (done) => {
const wrapper = shallow(<LoadableRenderer />);
// lazy-loaded component not rendered immediately
expect(wrapper.find(TestComponent)).toHaveLength(0);
setTimeout(() => {
// but rendered after the component is loaded.
expect(wrapper.find(TestComponent)).toHaveLength(1);
done();
}, 10);
});
});
});