mirror of
https://github.com/grafana/grafana.git
synced 2025-02-20 11:48:34 -06:00
* Chore: Enable eslint react/display-name Enable react/display-name and fixed the corresponding linting issue part of: #29201 * Chore: Enable eslint react/no-deprecated Enable react/no-deprecated and add the UNSAFE_ prefix for deprected methods part of: #29201 * Chore: Enable eslint react/no-find-dom-node Enable react/no-find-dom-node rule and use ref instead part of: #29201 * Test: Update TeamGroupSync test snapshot Since we added the displayName for ToolTip compontent and tag name is changed. * Fix: Fixed ClickOutsideWrapper render The props.children might contains numbers of nodes which make cloneElement failed. Change to simply use a div to wrapper the children and assign the ref to div for this feature * Style: Use shorthand method definition style for inline component * Fix: Rebase master and fix linting Rebase from master branch and fix new displayName linting warning
73 lines
2.1 KiB
TypeScript
73 lines
2.1 KiB
TypeScript
import React from 'react';
|
|
import { render, screen } from '@testing-library/react';
|
|
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: '',
|
|
} as any,
|
|
crossSeriesReducer: '',
|
|
groupBys: [],
|
|
children(renderProps) {
|
|
return <div />;
|
|
},
|
|
templateVariableOptions: [],
|
|
};
|
|
|
|
describe('Aggregations', () => {
|
|
it('renders correctly', () => {
|
|
render(<Aggregations {...props} />);
|
|
expect(screen.getByTestId('aggregations')).toBeInTheDocument();
|
|
});
|
|
|
|
describe('options', () => {
|
|
describe('when DOUBLE and GAUGE is passed as props', () => {
|
|
const nextProps = {
|
|
...props,
|
|
metricDescriptor: {
|
|
valueType: ValueTypes.DOUBLE,
|
|
metricKind: MetricKind.GAUGE,
|
|
} as any,
|
|
};
|
|
|
|
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,
|
|
} as any,
|
|
};
|
|
|
|
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(11);
|
|
expect(aggGroup.options.map((o: any) => o.value)).toEqual(expect.arrayContaining(['REDUCE_NONE']));
|
|
});
|
|
});
|
|
});
|
|
});
|