mirror of
https://github.com/grafana/grafana.git
synced 2025-02-25 18:55:37 -06:00
* Loki: Move explain to builder and code mode * Update * Update transition * Fix tests * Fix tests * Prometheus: Move explain section to builder mode (#52935) * Prometheus: Move explain section to builder mode * Show explain switch before raw query switch * Store explain switch value in localstorage * Make explain available for code mode too * Introduce useFlag hook for query editor switches * Remove Explain mode Co-authored-by: ismail simsek <ismailsimsek09@gmail.com>
49 lines
1.4 KiB
TypeScript
49 lines
1.4 KiB
TypeScript
import { render, screen } from '@testing-library/react';
|
|
import React from 'react';
|
|
|
|
import { addOperation } from 'app/plugins/datasource/prometheus/querybuilder/shared/OperationList.testUtils';
|
|
|
|
import { LokiDatasource } from '../../datasource';
|
|
|
|
import { LokiQueryBuilderContainer } from './LokiQueryBuilderContainer';
|
|
|
|
describe('LokiQueryBuilderContainer', () => {
|
|
it('translates query between string and model', async () => {
|
|
const props = {
|
|
query: {
|
|
expr: '{job="testjob"}',
|
|
refId: 'A',
|
|
},
|
|
datasource: new LokiDatasource(
|
|
{
|
|
id: 1,
|
|
uid: '',
|
|
type: 'loki',
|
|
name: 'loki-test',
|
|
access: 'proxy',
|
|
url: '',
|
|
jsonData: {},
|
|
meta: {} as any,
|
|
},
|
|
undefined,
|
|
undefined
|
|
),
|
|
onChange: jest.fn(),
|
|
onRunQuery: () => {},
|
|
showRawQuery: true,
|
|
showExplain: false,
|
|
};
|
|
props.datasource.getDataSamples = jest.fn().mockResolvedValue([]);
|
|
|
|
render(<LokiQueryBuilderContainer {...props} />);
|
|
const selector = await screen.findByLabelText('selector');
|
|
expect(selector.textContent).toBe('{job="testjob"}');
|
|
await addOperation('Range functions', 'Rate');
|
|
expect(await screen.findByText('Rate')).toBeInTheDocument();
|
|
expect(props.onChange).toBeCalledWith({
|
|
expr: 'rate({job="testjob"} [$__interval])',
|
|
refId: 'A',
|
|
});
|
|
});
|
|
});
|