mirror of
https://github.com/grafana/grafana.git
synced 2025-02-20 11:48:34 -06:00
Co-authored-by: Sarah Zinger <sarahzinger@users.noreply.github.com> Co-authored-by: Yaelle Chaudy <42030685+yaelleC@users.noreply.github.com>
134 lines
3.9 KiB
TypeScript
134 lines
3.9 KiB
TypeScript
import React from 'react';
|
|
import { render, screen } from '@testing-library/react';
|
|
import { act } from 'react-dom/test-utils';
|
|
import { CloudWatchMetricsQuery, MetricEditorMode, MetricQueryType } from '../types';
|
|
import { setupMockedDataSource } from '../__mocks__/CloudWatchDataSource';
|
|
import MetricsQueryHeader from './MetricsQueryHeader';
|
|
|
|
const ds = setupMockedDataSource({
|
|
variables: [],
|
|
});
|
|
ds.datasource.getRegions = jest.fn().mockResolvedValue([]);
|
|
const query: CloudWatchMetricsQuery = {
|
|
id: '',
|
|
region: 'us-east-2',
|
|
namespace: '',
|
|
period: '',
|
|
alias: '',
|
|
metricName: '',
|
|
dimensions: {},
|
|
matchExact: true,
|
|
statistic: '',
|
|
expression: '',
|
|
refId: '',
|
|
};
|
|
|
|
describe('MetricsQueryHeader', () => {
|
|
describe('confirm modal', () => {
|
|
it('should be shown when moving from code editor to builder when in sql mode', async () => {
|
|
const onChange = jest.fn();
|
|
const onRunQuery = jest.fn();
|
|
query.metricEditorMode = MetricEditorMode.Code;
|
|
query.metricQueryType = MetricQueryType.Query;
|
|
|
|
render(
|
|
<MetricsQueryHeader
|
|
sqlCodeEditorIsDirty={true}
|
|
datasource={ds.datasource}
|
|
query={query}
|
|
onChange={onChange}
|
|
onRunQuery={onRunQuery}
|
|
/>
|
|
);
|
|
|
|
const builderElement = screen.getByLabelText('Builder');
|
|
expect(builderElement).toBeInTheDocument();
|
|
await act(async () => {
|
|
await builderElement.click();
|
|
});
|
|
|
|
const modalTitleElem = screen.getByText('Are you sure?');
|
|
expect(modalTitleElem).toBeInTheDocument();
|
|
expect(onChange).not.toHaveBeenCalled();
|
|
});
|
|
|
|
it('should not be shown when moving from builder to code when in sql mode', async () => {
|
|
const onChange = jest.fn();
|
|
const onRunQuery = jest.fn();
|
|
query.metricEditorMode = MetricEditorMode.Builder;
|
|
query.metricQueryType = MetricQueryType.Query;
|
|
|
|
render(
|
|
<MetricsQueryHeader
|
|
sqlCodeEditorIsDirty={true}
|
|
datasource={ds.datasource}
|
|
query={query}
|
|
onChange={onChange}
|
|
onRunQuery={onRunQuery}
|
|
/>
|
|
);
|
|
|
|
const builderElement = screen.getByLabelText('Code');
|
|
expect(builderElement).toBeInTheDocument();
|
|
await act(async () => {
|
|
await builderElement.click();
|
|
});
|
|
|
|
const modalTitleElem = screen.queryByText('Are you sure?');
|
|
expect(modalTitleElem).toBeNull();
|
|
expect(onChange).toHaveBeenCalled();
|
|
});
|
|
|
|
it('should not be shown when moving from code to builder when in standard mode', async () => {
|
|
const onChange = jest.fn();
|
|
const onRunQuery = jest.fn();
|
|
query.metricEditorMode = MetricEditorMode.Code;
|
|
query.metricQueryType = MetricQueryType.Search;
|
|
|
|
render(
|
|
<MetricsQueryHeader
|
|
sqlCodeEditorIsDirty={true}
|
|
datasource={ds.datasource}
|
|
query={query}
|
|
onChange={onChange}
|
|
onRunQuery={onRunQuery}
|
|
/>
|
|
);
|
|
|
|
const builderElement = screen.getByLabelText('Builder');
|
|
expect(builderElement).toBeInTheDocument();
|
|
await act(async () => {
|
|
await builderElement.click();
|
|
});
|
|
|
|
const modalTitleElem = screen.queryByText('Are you sure?');
|
|
expect(modalTitleElem).toBeNull();
|
|
expect(onChange).toHaveBeenCalled();
|
|
});
|
|
});
|
|
|
|
it('should call run query when run button is clicked when in metric query mode', async () => {
|
|
const onChange = jest.fn();
|
|
const onRunQuery = jest.fn();
|
|
query.metricEditorMode = MetricEditorMode.Code;
|
|
query.metricQueryType = MetricQueryType.Query;
|
|
|
|
render(
|
|
<MetricsQueryHeader
|
|
sqlCodeEditorIsDirty={true}
|
|
datasource={ds.datasource}
|
|
query={query}
|
|
onChange={onChange}
|
|
onRunQuery={onRunQuery}
|
|
/>
|
|
);
|
|
|
|
const runQueryButton = screen.getByText('Run query');
|
|
expect(runQueryButton).toBeInTheDocument();
|
|
await act(async () => {
|
|
await runQueryButton.click();
|
|
});
|
|
expect(onRunQuery).toHaveBeenCalled();
|
|
});
|
|
});
|