Commit f402db86 authored by Miguel Rincon's avatar Miguel Rincon

Remove dependency on store to generate test data

With this change we remove the dependency on creating a store in order
to test chart component that does not depend on the store.

Moving forward all chart components can use this mock data generator.
parent 6a9c2b82
...@@ -165,7 +165,7 @@ const mapLinksToViewModel = ({ url = null, title = '', type } = {}) => { ...@@ -165,7 +165,7 @@ const mapLinksToViewModel = ({ url = null, title = '', type } = {}) => {
* @param {Object} panel - Metrics panel * @param {Object} panel - Metrics panel
* @returns {Object} * @returns {Object}
*/ */
const mapPanelToViewModel = ({ export const mapPanelToViewModel = ({
id = null, id = null,
title = '', title = '',
type, type,
......
...@@ -9,18 +9,12 @@ import { ...@@ -9,18 +9,12 @@ import {
GlChartSeriesLabel, GlChartSeriesLabel,
GlChartLegend, GlChartLegend,
} from '@gitlab/ui/dist/charts'; } from '@gitlab/ui/dist/charts';
import { cloneDeep } from 'lodash';
import { shallowWrapperContainsSlotText } from 'helpers/vue_test_utils_helper'; import { shallowWrapperContainsSlotText } from 'helpers/vue_test_utils_helper';
import { createStore } from '~/monitoring/stores';
import { panelTypes, chartHeight } from '~/monitoring/constants'; import { panelTypes, chartHeight } from '~/monitoring/constants';
import TimeSeries from '~/monitoring/components/charts/time_series.vue'; import TimeSeries from '~/monitoring/components/charts/time_series.vue';
import * as types from '~/monitoring/stores/mutation_types'; import { deploymentData, mockProjectDir, annotationsData } from '../../mock_data';
import { deploymentData, mockProjectDir, annotationsData, metricsResult } from '../../mock_data';
import { import { timeSeriesGraphData } from '../../graph_data';
metricsDashboardPayload,
metricsDashboardViewModel,
metricResultStatus,
} from '../../fixture_data';
jest.mock('lodash/throttle', () => jest.mock('lodash/throttle', () =>
// this throttle mock executes immediately // this throttle mock executes immediately
...@@ -35,23 +29,21 @@ jest.mock('~/lib/utils/icon_utils', () => ({ ...@@ -35,23 +29,21 @@ jest.mock('~/lib/utils/icon_utils', () => ({
})); }));
describe('Time series component', () => { describe('Time series component', () => {
let mockGraphData; const defaultGraphData = timeSeriesGraphData();
let store;
let wrapper; let wrapper;
const createWrapper = ( const createWrapper = (
{ graphData = mockGraphData, ...props } = {}, { graphData = defaultGraphData, ...props } = {},
mountingMethod = shallowMount, mountingMethod = shallowMount,
) => { ) => {
wrapper = mountingMethod(TimeSeries, { wrapper = mountingMethod(TimeSeries, {
propsData: { propsData: {
graphData, graphData,
deploymentData: store.state.monitoringDashboard.deploymentData, deploymentData,
annotations: store.state.monitoringDashboard.annotations, annotations: annotationsData,
projectPath: `${TEST_HOST}${mockProjectDir}`, projectPath: `${TEST_HOST}${mockProjectDir}`,
...props, ...props,
}, },
store,
stubs: { stubs: {
GlPopover: true, GlPopover: true,
}, },
...@@ -59,27 +51,15 @@ describe('Time series component', () => { ...@@ -59,27 +51,15 @@ describe('Time series component', () => {
}); });
}; };
describe('With a single time series', () => {
beforeEach(() => { beforeEach(() => {
setTestTimeout(1000); setTestTimeout(1000);
});
store = createStore(); afterEach(() => {
wrapper.destroy();
store.commit(
`monitoringDashboard/${types.RECEIVE_METRICS_DASHBOARD_SUCCESS}`,
metricsDashboardPayload,
);
store.commit(`monitoringDashboard/${types.RECEIVE_DEPLOYMENTS_DATA_SUCCESS}`, deploymentData);
store.commit(
`monitoringDashboard/${types.RECEIVE_METRIC_RESULT_SUCCESS}`,
metricResultStatus,
);
// dashboard is a dynamically generated fixture and stored at environment_metrics_dashboard.json
[mockGraphData] = store.state.monitoringDashboard.dashboard.panelGroups[1].panels;
}); });
describe('With a single time series', () => {
describe('general functions', () => { describe('general functions', () => {
const findChart = () => wrapper.find({ ref: 'chart' }); const findChart = () => wrapper.find({ ref: 'chart' });
...@@ -88,10 +68,6 @@ describe('Time series component', () => { ...@@ -88,10 +68,6 @@ describe('Time series component', () => {
return wrapper.vm.$nextTick(); return wrapper.vm.$nextTick();
}); });
afterEach(() => {
wrapper.destroy();
});
it('allows user to override legend label texts using props', () => { it('allows user to override legend label texts using props', () => {
const legendRelatedProps = { const legendRelatedProps = {
legendMinText: 'legendMinText', legendMinText: 'legendMinText',
...@@ -231,19 +207,20 @@ describe('Time series component', () => { ...@@ -231,19 +207,20 @@ describe('Time series component', () => {
}); });
it('formats tooltip content', () => { it('formats tooltip content', () => {
const name = 'Status Code'; const name = 'Metric 1';
const value = '5.556'; const value = '5.556';
const dataIndex = 0; const dataIndex = 0;
const seriesLabel = wrapper.find(GlChartSeriesLabel); const seriesLabel = wrapper.find(GlChartSeriesLabel);
expect(seriesLabel.vm.color).toBe(''); expect(seriesLabel.vm.color).toBe('');
expect(shallowWrapperContainsSlotText(seriesLabel, 'default', name)).toBe(true); expect(shallowWrapperContainsSlotText(seriesLabel, 'default', name)).toBe(true);
expect(wrapper.vm.tooltip.content).toEqual([ expect(wrapper.vm.tooltip.content).toEqual([
{ name, value, dataIndex, color: undefined }, { name, value, dataIndex, color: undefined },
]); ]);
expect( expect(
shallowWrapperContainsSlotText(wrapper.find(GlAreaChart), 'tooltipContent', value), shallowWrapperContainsSlotText(wrapper.find(GlLineChart), 'tooltipContent', value),
).toBe(true); ).toBe(true);
}); });
...@@ -385,10 +362,8 @@ describe('Time series component', () => { ...@@ -385,10 +362,8 @@ describe('Time series component', () => {
}); });
it('utilizes all data points', () => { it('utilizes all data points', () => {
const { values } = mockGraphData.metrics[0].result[0];
expect(chartData.length).toBe(1); expect(chartData.length).toBe(1);
expect(seriesData().data.length).toBe(values.length); expect(seriesData().data.length).toBe(3);
}); });
it('creates valid data', () => { it('creates valid data', () => {
...@@ -602,14 +577,10 @@ describe('Time series component', () => { ...@@ -602,14 +577,10 @@ describe('Time series component', () => {
it('constructs a label for the chart y-axis', () => { it('constructs a label for the chart y-axis', () => {
const { yAxis } = getChartOptions(); const { yAxis } = getChartOptions();
expect(yAxis[0].name).toBe('Requests / Sec'); expect(yAxis[0].name).toBe('Y Axis');
}); });
}); });
}); });
afterEach(() => {
wrapper.destroy();
});
}); });
describe('wrapped components', () => { describe('wrapped components', () => {
...@@ -630,7 +601,7 @@ describe('Time series component', () => { ...@@ -630,7 +601,7 @@ describe('Time series component', () => {
beforeEach(() => { beforeEach(() => {
createWrapper( createWrapper(
{ graphData: { ...mockGraphData, type: dynamicComponent.chartType } }, { graphData: timeSeriesGraphData({ type: dynamicComponent.chartType }) },
mount, mount,
); );
return wrapper.vm.$nextTick(); return wrapper.vm.$nextTick();
...@@ -700,18 +671,12 @@ describe('Time series component', () => { ...@@ -700,18 +671,12 @@ describe('Time series component', () => {
describe('with multiple time series', () => { describe('with multiple time series', () => {
describe('General functions', () => { describe('General functions', () => {
beforeEach(() => { beforeEach(() => {
store = createStore(); const graphData = timeSeriesGraphData({ type: panelTypes.AREA_CHART, multiMetric: true });
const graphData = cloneDeep(metricsDashboardViewModel.panelGroups[0].panels[3]);
graphData.metrics.forEach(metric => Object.assign(metric, { result: metricsResult }));
createWrapper({ graphData: { ...graphData, type: 'area-chart' } }, mount); createWrapper({ graphData }, mount);
return wrapper.vm.$nextTick(); return wrapper.vm.$nextTick();
}); });
afterEach(() => {
wrapper.destroy();
});
describe('Color match', () => { describe('Color match', () => {
let lineColors; let lineColors;
...@@ -752,14 +717,10 @@ describe('Time series component', () => { ...@@ -752,14 +717,10 @@ describe('Time series component', () => {
const findLegend = () => wrapper.find(GlChartLegend); const findLegend = () => wrapper.find(GlChartLegend);
beforeEach(() => { beforeEach(() => {
createWrapper(mockGraphData, mount); createWrapper({}, mount);
return wrapper.vm.$nextTick(); return wrapper.vm.$nextTick();
}); });
afterEach(() => {
wrapper.destroy();
});
it('should render a tabular legend layout by default', () => { it('should render a tabular legend layout by default', () => {
expect(findLegend().props('layout')).toBe('table'); expect(findLegend().props('layout')).toBe('table');
}); });
......
import { mapPanelToViewModel, normalizeQueryResponseData } from '~/monitoring/stores/utils';
import { panelTypes, metricStates } from '~/monitoring/constants';
const initTime = 1435781451.781;
const makeValues = vals => vals.map((val, i) => [initTime + 15 * i, val]);
// Normalized Prometheus Responses
const matrixSingleResult = ({ values = ['1', '2', '3'] } = {}) =>
normalizeQueryResponseData({
resultType: 'matrix',
result: [
{
metric: {},
values: makeValues(values),
},
],
});
const matrixMultiResult = ({ values1 = ['1', '2', '3'], values2 = ['4', '5', '6'] } = {}) =>
normalizeQueryResponseData({
resultType: 'matrix',
result: [
{
metric: {
__name__: 'up',
job: 'prometheus',
instance: 'localhost:9090',
},
values: makeValues(values1),
},
{
metric: {
__name__: 'up',
job: 'node',
instance: 'localhost:9091',
},
values: makeValues(values2),
},
],
});
// GraphData factory
/**
* Generate mock graph data according to options
*
* @param {Object} panelOptions - Panel options as in YML.
* @param {Object} dataOptions
* @param {Object} dataOptions.metricCount
* @param {Object} dataOptions.isMultiSeries
*/
// eslint-disable-next-line import/prefer-default-export
export const timeSeriesGraphData = (panelOptions = {}, dataOptions = {}) => {
const { metricCount = 1, isMultiSeries = false } = dataOptions;
return mapPanelToViewModel({
title: 'Time Series Panel',
type: panelTypes.LINE_CHART,
x_label: 'X Axis',
y_label: 'Y Axis',
metrics: Array.from(Array(metricCount), (_, i) => ({
label: `Metric ${i + 1}`,
state: metricStates.OK,
result: isMultiSeries ? matrixMultiResult() : matrixSingleResult(),
})),
...panelOptions,
});
};
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment