2021-03-23 05:58:09 -05:00
|
|
|
import React from 'react';
|
|
|
|
import { Provider } from 'react-redux';
|
|
|
|
import { render, screen } from '@testing-library/react';
|
|
|
|
import { DataQueryError, LoadingState } from '@grafana/data';
|
2021-11-17 07:45:45 -06:00
|
|
|
import { selectors } from '@grafana/e2e-selectors';
|
|
|
|
|
|
|
|
import { configureStore } from '../../store/configureStore';
|
|
|
|
import { ResponseErrorContainer } from './ResponseErrorContainer';
|
|
|
|
import { ExploreId } from '../../types';
|
2021-03-23 05:58:09 -05:00
|
|
|
|
|
|
|
describe('ResponseErrorContainer', () => {
|
|
|
|
it('shows error message if it does not contain refId', async () => {
|
2021-09-22 04:33:31 -05:00
|
|
|
const errorMessage = 'test error';
|
2021-03-23 05:58:09 -05:00
|
|
|
setup({
|
2021-09-22 04:33:31 -05:00
|
|
|
message: errorMessage,
|
2021-03-23 05:58:09 -05:00
|
|
|
});
|
2021-11-17 07:45:45 -06:00
|
|
|
const errorEl = screen.getByTestId(selectors.components.Alert.alertV2('error'));
|
2021-09-22 04:33:31 -05:00
|
|
|
expect(errorEl).toBeInTheDocument();
|
|
|
|
expect(errorEl).toHaveTextContent(errorMessage);
|
2021-03-23 05:58:09 -05:00
|
|
|
});
|
|
|
|
|
2021-09-22 04:33:31 -05:00
|
|
|
it('shows error if there is refID', async () => {
|
|
|
|
const errorMessage = 'test error';
|
2021-03-23 05:58:09 -05:00
|
|
|
setup({
|
|
|
|
refId: 'someId',
|
2021-09-22 04:33:31 -05:00
|
|
|
message: errorMessage,
|
2021-03-23 05:58:09 -05:00
|
|
|
});
|
2021-11-17 07:45:45 -06:00
|
|
|
const errorEl = screen.getByTestId(selectors.components.Alert.alertV2('error'));
|
2021-09-22 04:33:31 -05:00
|
|
|
expect(errorEl).toBeInTheDocument();
|
|
|
|
expect(errorEl).toHaveTextContent(errorMessage);
|
2021-03-23 05:58:09 -05:00
|
|
|
});
|
|
|
|
|
2021-09-22 04:33:31 -05:00
|
|
|
it('shows error.data.message if error.message does not exist', async () => {
|
|
|
|
const errorMessage = 'test error';
|
2021-03-23 05:58:09 -05:00
|
|
|
setup({
|
2021-09-22 04:33:31 -05:00
|
|
|
data: {
|
|
|
|
message: 'test error',
|
|
|
|
},
|
2021-03-23 05:58:09 -05:00
|
|
|
});
|
2021-11-17 07:45:45 -06:00
|
|
|
const errorEl = screen.getByTestId(selectors.components.Alert.alertV2('error'));
|
2021-09-22 04:33:31 -05:00
|
|
|
expect(errorEl).toBeInTheDocument();
|
|
|
|
expect(errorEl).toHaveTextContent(errorMessage);
|
2021-03-23 05:58:09 -05:00
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
function setup(error: DataQueryError) {
|
|
|
|
const store = configureStore();
|
|
|
|
store.getState().explore[ExploreId.left].queryResponse = {
|
|
|
|
timeRange: {} as any,
|
|
|
|
series: [],
|
|
|
|
state: LoadingState.Error,
|
|
|
|
error,
|
2022-03-03 02:54:06 -06:00
|
|
|
graphFrames: [],
|
|
|
|
logsFrames: [],
|
|
|
|
tableFrames: [],
|
|
|
|
traceFrames: [],
|
|
|
|
nodeGraphFrames: [],
|
|
|
|
graphResult: null,
|
|
|
|
logsResult: null,
|
|
|
|
tableResult: null,
|
2021-03-23 05:58:09 -05:00
|
|
|
};
|
|
|
|
render(
|
|
|
|
<Provider store={store}>
|
|
|
|
<ResponseErrorContainer exploreId={ExploreId.left} />
|
|
|
|
</Provider>
|
|
|
|
);
|
|
|
|
}
|