mirror of
https://github.com/grafana/grafana.git
synced 2025-02-25 18:55:37 -06:00
* refactor aliasBy and PopoverCtrl components * refactor Aggregations component * refactor MetricSelect component * refactor UserProvider * popoverCtr: remove redundant logic * simplified the MetricsSelect a bit. * skipping testing of internal component logic. * changed to componentWillMount. * changed elapsed time to a functional component. * rewrote the tests. * fixed missing test title. * fixed a tiny issue with elapsed time. * rename of field. Co-authored-by: Marcus Andersson <marcus.andersson@grafana.com>
71 lines
2.1 KiB
TypeScript
71 lines
2.1 KiB
TypeScript
import React from 'react';
|
|
import renderer from 'react-test-renderer';
|
|
import { shallow } from 'enzyme';
|
|
import { Segment } from '@grafana/ui';
|
|
import { Aggregations, Props } from './Aggregations';
|
|
import { ValueTypes, MetricKind } from '../constants';
|
|
import { TemplateSrvStub } from 'test/specs/helpers';
|
|
|
|
const props: Props = {
|
|
onChange: () => {},
|
|
// @ts-ignore
|
|
templateSrv: new TemplateSrvStub(),
|
|
metricDescriptor: {
|
|
valueType: '',
|
|
metricKind: '',
|
|
},
|
|
crossSeriesReducer: '',
|
|
groupBys: [],
|
|
children: renderProps => <div />,
|
|
templateVariableOptions: [],
|
|
};
|
|
|
|
describe('Aggregations', () => {
|
|
it('renders correctly', () => {
|
|
const tree = renderer.create(<Aggregations {...props} />).toJSON();
|
|
expect(tree).toMatchSnapshot();
|
|
});
|
|
|
|
describe('options', () => {
|
|
describe('when DOUBLE and GAUGE is passed as props', () => {
|
|
const nextProps = {
|
|
...props,
|
|
metricDescriptor: {
|
|
valueType: ValueTypes.DOUBLE,
|
|
metricKind: MetricKind.GAUGE,
|
|
},
|
|
};
|
|
|
|
it('should not have the reduce values', () => {
|
|
const wrapper = shallow(<Aggregations {...nextProps} />);
|
|
const { options } = wrapper.find(Segment).props() as any;
|
|
const [, aggGroup] = options;
|
|
|
|
expect(aggGroup.options.length).toEqual(11);
|
|
expect(aggGroup.options.map((o: any) => o.value)).toEqual(
|
|
expect.not.arrayContaining(['REDUCE_COUNT_TRUE', 'REDUCE_COUNT_FALSE'])
|
|
);
|
|
});
|
|
});
|
|
|
|
describe('when MONEY and CUMULATIVE is passed as props', () => {
|
|
const nextProps = {
|
|
...props,
|
|
metricDescriptor: {
|
|
valueType: ValueTypes.MONEY,
|
|
metricKind: MetricKind.CUMULATIVE,
|
|
},
|
|
};
|
|
|
|
it('should have the reduce values', () => {
|
|
const wrapper = shallow(<Aggregations {...nextProps} />);
|
|
const { options } = wrapper.find(Segment).props() as any;
|
|
const [, aggGroup] = options;
|
|
|
|
expect(aggGroup.options.length).toEqual(10);
|
|
expect(aggGroup.options.map((o: any) => o.value)).toEqual(expect.arrayContaining(['REDUCE_NONE']));
|
|
});
|
|
});
|
|
});
|
|
});
|