mirror of
https://github.com/grafana/grafana.git
synced 2025-02-13 00:55:47 -06:00
* user essentials mob! 🔱 * user essentials mob! 🔱 lastFile:public/app/features/query/components/QueryEditorRowHeader.test.tsx * user essentials mob! 🔱 * test variables showing in data source picker dropdown on MIXED * clean up unused imports * remove comment * remove unused mock Co-authored-by: Alexandra Vargas <alexa1866@gmail.com> Co-authored-by: Joao Silva <joao.silva@grafana.com> Co-authored-by: joshhunt <josh@trtr.co> Co-authored-by: Ashley Harrison <ashley.harrison@grafana.com>
114 lines
3.4 KiB
TypeScript
114 lines
3.4 KiB
TypeScript
import { fireEvent, render, screen } from '@testing-library/react';
|
|
import React from 'react';
|
|
import { openMenu } from 'react-select-event';
|
|
|
|
import { DataSourceInstanceSettings } from '@grafana/data';
|
|
import { selectors } from '@grafana/e2e-selectors';
|
|
import { mockDataSource } from 'app/features/alerting/unified/mocks';
|
|
import { DataSourceType } from 'app/features/alerting/unified/utils/datasource';
|
|
|
|
import { Props, QueryEditorRowHeader } from './QueryEditorRowHeader';
|
|
|
|
const mockDS = mockDataSource({
|
|
name: 'CloudManager',
|
|
type: DataSourceType.Alertmanager,
|
|
});
|
|
|
|
const mockVariable = mockDataSource({
|
|
name: '${dsVariable}',
|
|
type: 'datasource',
|
|
});
|
|
|
|
jest.mock('@grafana/runtime/src/services/dataSourceSrv', () => {
|
|
return {
|
|
getDataSourceSrv: () => ({
|
|
get: () => Promise.resolve(mockDS),
|
|
getList: ({ variables }: { variables: boolean }) => (variables ? [mockDS, mockVariable] : [mockDS]),
|
|
getInstanceSettings: () => mockDS,
|
|
}),
|
|
};
|
|
});
|
|
|
|
describe('QueryEditorRowHeader', () => {
|
|
it('Can edit title', () => {
|
|
const scenario = renderScenario({});
|
|
screen.getByTestId('query-name-div').click();
|
|
|
|
const input = screen.getByTestId('query-name-input');
|
|
fireEvent.change(input, { target: { value: 'new name' } });
|
|
fireEvent.blur(input);
|
|
|
|
expect(jest.mocked(scenario.props.onChange).mock.calls[0][0].refId).toBe('new name');
|
|
});
|
|
|
|
it('Show error when other query with same name exists', async () => {
|
|
renderScenario({});
|
|
|
|
screen.getByTestId('query-name-div').click();
|
|
const input = screen.getByTestId('query-name-input');
|
|
fireEvent.change(input, { target: { value: 'B' } });
|
|
const alert = await screen.findByRole('alert');
|
|
|
|
expect(alert.textContent).toBe('Query name already exists');
|
|
});
|
|
|
|
it('Show error when empty name is specified', async () => {
|
|
renderScenario({});
|
|
|
|
screen.getByTestId('query-name-div').click();
|
|
const input = screen.getByTestId('query-name-input');
|
|
fireEvent.change(input, { target: { value: '' } });
|
|
const alert = await screen.findByRole('alert');
|
|
|
|
expect(alert.textContent).toBe('An empty query name is not allowed');
|
|
});
|
|
|
|
it('should show data source picker when callback is passed', async () => {
|
|
renderScenario({ onChangeDataSource: () => {} });
|
|
|
|
expect(screen.queryByLabelText(selectors.components.DataSourcePicker.container)).not.toBeNull();
|
|
});
|
|
|
|
it('should not show data source picker when no callback is passed', async () => {
|
|
renderScenario({ onChangeDataSource: undefined });
|
|
|
|
expect(screen.queryByLabelText(selectors.components.DataSourcePicker.container)).toBeNull();
|
|
});
|
|
|
|
it('should render variables in the data source picker', async () => {
|
|
renderScenario({ onChangeDataSource: () => {} });
|
|
|
|
const dsSelect = screen.getByLabelText(selectors.components.DataSourcePicker.inputV2);
|
|
openMenu(dsSelect);
|
|
expect(await screen.findByText('${dsVariable}')).toBeInTheDocument();
|
|
});
|
|
});
|
|
|
|
function renderScenario(overrides: Partial<Props>) {
|
|
const props: Props = {
|
|
query: {
|
|
refId: 'A',
|
|
},
|
|
queries: [
|
|
{
|
|
refId: 'A',
|
|
},
|
|
{
|
|
refId: 'B',
|
|
},
|
|
],
|
|
dataSource: {} as DataSourceInstanceSettings,
|
|
disabled: false,
|
|
onChange: jest.fn(),
|
|
onClick: jest.fn(),
|
|
collapsedText: '',
|
|
};
|
|
|
|
Object.assign(props, overrides);
|
|
|
|
return {
|
|
props,
|
|
renderResult: render(<QueryEditorRowHeader {...props} />),
|
|
};
|
|
}
|