import { render, screen } from '@testing-library/react'; import React from 'react'; import { DataQueryResponse, LoadingState } from '@grafana/data'; import { LogsVolumePanel } from './LogsVolumePanel'; jest.mock('./ExploreGraph', () => { const ExploreGraph = () => ExploreGraph; return { ExploreGraph, }; }); function renderPanel(logsVolumeData?: DataQueryResponse) { render( {}} width={100} onUpdateTimeRange={() => {}} logsVolumeData={logsVolumeData} onLoadLogsVolume={() => {}} /> ); } describe('LogsVolumePanel', () => { it('shows loading message', () => { renderPanel({ state: LoadingState.Loading, error: undefined, data: [] }); expect(screen.getByText('Log volume is loading...')).toBeInTheDocument(); }); it('shows no volume data', () => { renderPanel({ state: LoadingState.Done, error: undefined, data: [] }); expect(screen.getByText('No volume data.')).toBeInTheDocument(); }); it('renders logs volume histogram graph', () => { renderPanel({ state: LoadingState.Done, error: undefined, data: [{}] }); expect(screen.getByText('ExploreGraph')).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', () => { // 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(); const button = screen.getByText('Show details'); button.click(); expect(screen.getByText(message)).toBeInTheDocument(); }); it('does not show the panel when there is no volume data', () => { renderPanel(undefined); expect(screen.queryByText('Log volume')).not.toBeInTheDocument(); }); });