123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177 |
- import {act} from 'react-dom/test-utils';
- import {chart, doZoom, mockZoomRange} from 'sentry-test/charts';
- import {mountWithTheme} from 'sentry-test/enzyme';
- import {initializeOrg} from 'sentry-test/initializeOrg';
- import * as globalSelection from 'sentry/actionCreators/pageFilters';
- import EventsChart from 'sentry/components/charts/eventsChart';
- import {WorldMapChart} from 'sentry/components/charts/worldMapChart';
- import {getUtcToLocalDateObject} from 'sentry/utils/dates';
- jest.mock('sentry/components/charts/eventsRequest', () => jest.fn(() => null));
- jest.spyOn(globalSelection, 'updateDateTime');
- jest.mock(
- 'sentry/components/charts/eventsGeoRequest',
- () =>
- ({children}) =>
- children({
- errored: false,
- loading: false,
- reloading: false,
- tableData: [],
- })
- );
- describe('EventsChart', function () {
- const {router, routerContext, org} = initializeOrg();
- let render;
- let wrapper;
- function renderChart(props) {
- return mountWithTheme(
- <EventsChart
- api={new MockApiClient()}
- location={{query: {}}}
- organization={org}
- project={[]}
- environment={[]}
- period="14d"
- start={null}
- end={null}
- utc={false}
- router={router}
- {...props}
- />,
- routerContext
- );
- }
- beforeEach(function () {
- globalSelection.updateDateTime.mockClear();
- mockZoomRange(1543449600000, 1543708800000);
- wrapper = renderChart();
- // XXX: Note we spy on this AFTER it has already rendered once!
- render = jest.spyOn(wrapper.find('ChartZoom').instance(), 'render');
- });
- it('renders', function () {
- expect(render).toHaveBeenCalledTimes(0);
- });
- it('re-renders if period from props changes', function () {
- wrapper.setProps({period: '7d'});
- wrapper.update();
- expect(render).toHaveBeenCalledTimes(1);
- });
- it('re-renders if query from props changes', function () {
- wrapper.setProps({query: 'newQuery'});
- wrapper.update();
- expect(render).toHaveBeenCalledTimes(1);
- });
- it('re-renders if project from props changes', function () {
- wrapper.setProps({project: [2]});
- wrapper.update();
- expect(render).toHaveBeenCalledTimes(1);
- });
- it('has correct history entries when zooming', function () {
- const chartZoomInstance = wrapper.find('ChartZoom').instance();
- doZoom(wrapper, chart);
- expect(chartZoomInstance.history).toEqual([
- {
- period: '14d',
- start: null,
- end: null,
- },
- ]);
- expect(chartZoomInstance.currentPeriod.period).toEqual(null);
- expect(chartZoomInstance.currentPeriod.start).toEqual('2018-11-29T00:00:00');
- expect(chartZoomInstance.currentPeriod.end).toEqual('2018-12-02T00:00:00');
- // Zoom again
- mockZoomRange(1543536000000, 1543708800000);
- doZoom(wrapper, chart);
- expect(chartZoomInstance.currentPeriod.period).toEqual(null);
- expect(chartZoomInstance.currentPeriod.start).toEqual('2018-11-30T00:00:00');
- expect(chartZoomInstance.currentPeriod.end).toEqual('2018-12-02T00:00:00');
- expect(chartZoomInstance.history[0]).toEqual({
- period: '14d',
- start: null,
- end: null,
- });
- expect(chartZoomInstance.history[1].start).toEqual('2018-11-29T00:00:00');
- expect(chartZoomInstance.history[1].end).toEqual('2018-12-02T00:00:00');
- // go back in history
- mockZoomRange(null, null);
- doZoom(wrapper, chart);
- expect(chartZoomInstance.currentPeriod.period).toEqual(null);
- expect(chartZoomInstance.currentPeriod.start).toEqual('2018-11-29T00:00:00');
- expect(chartZoomInstance.currentPeriod.end).toEqual('2018-12-02T00:00:00');
- const newParams = {
- period: null,
- start: getUtcToLocalDateObject('2018-11-29T00:00:00'),
- end: getUtcToLocalDateObject('2018-12-02T00:00:00'),
- };
- expect(globalSelection.updateDateTime).toHaveBeenCalledWith(newParams, router);
- wrapper.setProps({
- period: newParams.period,
- start: newParams.start,
- end: newParams.end,
- });
- wrapper.update();
- });
- it('updates url params when restoring zoom level on chart', function () {
- doZoom(wrapper, chart);
- // Zoom again
- mockZoomRange(1543536000000, 1543708800000);
- doZoom(wrapper, chart);
- mockZoomRange(1543622400000, 1543708800000);
- doZoom(wrapper, chart);
- const chartZoomInstance = wrapper.find('ChartZoom').instance();
- expect(chartZoomInstance.history).toHaveLength(3);
- // Restore history
- chartZoomInstance.handleZoomRestore();
- chartZoomInstance.handleChartFinished({}, chart);
- expect(chartZoomInstance.currentPeriod).toEqual({
- period: '14d',
- start: null,
- end: null,
- });
- const newParams = {
- period: '14d',
- start: null,
- end: null,
- };
- expect(globalSelection.updateDateTime).toHaveBeenLastCalledWith(newParams, router);
- wrapper.setProps({
- period: '14d',
- start: null,
- end: null,
- });
- wrapper.update();
- expect(chartZoomInstance.history).toHaveLength(0);
- });
- it('renders with World Map when given WorldMapChart chartComponent', async function () {
- MockApiClient.addMockResponse({
- url: '/organizations/org-slug/releases/stats/',
- body: [],
- });
- await act(async () => {
- wrapper = renderChart({chartComponent: WorldMapChart, yAxis: ['count()']});
- await tick();
- });
- expect(wrapper.find('WorldMapChart').length).toEqual(1);
- });
- });
|