mirror of
https://github.com/grafana/grafana.git
synced 2025-02-13 09:05:45 -06:00
* Update timeout message * Align buttons to the right * Remove test code * Update test * Add min width to error container
71 lines
2.5 KiB
TypeScript
71 lines
2.5 KiB
TypeScript
import { render, screen } from '@testing-library/react';
|
|
import userEvent from '@testing-library/user-event';
|
|
import React from 'react';
|
|
|
|
import { DataQueryResponse, LoadingState, EventBusSrv } from '@grafana/data';
|
|
|
|
import { LogsVolumePanelList } from './LogsVolumePanelList';
|
|
|
|
jest.mock('./Graph/ExploreGraph', () => {
|
|
const ExploreGraph = () => <span>ExploreGraph</span>;
|
|
return {
|
|
ExploreGraph,
|
|
};
|
|
});
|
|
|
|
function renderPanel(logsVolumeData?: DataQueryResponse, onLoadLogsVolume = () => {}) {
|
|
render(
|
|
<LogsVolumePanelList
|
|
absoluteRange={{ from: 0, to: 1 }}
|
|
timeZone="timeZone"
|
|
splitOpen={() => {}}
|
|
width={100}
|
|
onUpdateTimeRange={() => {}}
|
|
logsVolumeData={logsVolumeData}
|
|
onLoadLogsVolume={onLoadLogsVolume}
|
|
onHiddenSeriesChanged={() => null}
|
|
eventBus={new EventBusSrv()}
|
|
/>
|
|
);
|
|
}
|
|
|
|
describe('LogsVolumePanelList', () => {
|
|
it('shows loading message', () => {
|
|
renderPanel({ state: LoadingState.Loading, error: undefined, data: [] });
|
|
expect(screen.getByText('Loading...')).toBeInTheDocument();
|
|
});
|
|
|
|
it('shows short warning message', () => {
|
|
renderPanel({ state: LoadingState.Error, error: { data: { message: 'Test error message' } }, data: [] });
|
|
expect(screen.getByText('Failed to load log volume for this query')).toBeInTheDocument();
|
|
expect(screen.getByText('Test error message')).toBeInTheDocument();
|
|
});
|
|
|
|
it('shows long warning message', async () => {
|
|
// we make a long message
|
|
const messagePart = 'One two three four five six seven eight nine ten.';
|
|
const message = messagePart + ' ' + messagePart + ' ' + messagePart;
|
|
|
|
renderPanel({ state: LoadingState.Error, error: { data: { message } }, data: [] });
|
|
expect(screen.getByText('Failed to load log volume for this query')).toBeInTheDocument();
|
|
expect(screen.queryByText(message)).not.toBeInTheDocument();
|
|
await userEvent.click(screen.getByRole('button', { name: 'Show details' }));
|
|
expect(screen.getByText(message)).toBeInTheDocument();
|
|
});
|
|
|
|
it('a custom message for timeout errors', async () => {
|
|
const onLoadCallback = jest.fn();
|
|
renderPanel(
|
|
{
|
|
state: LoadingState.Error,
|
|
error: { data: { message: '{"status":"error","errorType":"timeout","error":"context deadline exceeded"}' } },
|
|
data: [],
|
|
},
|
|
onLoadCallback
|
|
);
|
|
expect(screen.getByText('The logs volume query has timed out')).toBeInTheDocument();
|
|
await userEvent.click(screen.getByRole('button', { name: 'Retry' }));
|
|
expect(onLoadCallback).toHaveBeenCalled();
|
|
});
|
|
});
|