mirror of https://github.com/grafana/grafana.git
				
				
				
			
		
			
				
	
	
		
			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} />),
 | 
						|
  };
 | 
						|
}
 |