mirror of
https://github.com/grafana/grafana.git
synced 2025-02-13 00:55:47 -06:00
203 lines
5.6 KiB
TypeScript
203 lines
5.6 KiB
TypeScript
import { render } from '@testing-library/react';
|
|
import userEvent from '@testing-library/user-event';
|
|
import React from 'react';
|
|
import { Provider } from 'react-redux';
|
|
import { MemoryRouter } from 'react-router-dom';
|
|
import { byTestId } from 'testing-library-selector';
|
|
|
|
import { configureStore } from 'app/store/configureStore';
|
|
import { FolderState } from 'app/types';
|
|
import { CombinedRuleNamespace } from 'app/types/unified-alerting';
|
|
|
|
import { AlertsFolderView } from './AlertsFolderView';
|
|
import { mockCombinedRule } from './mocks';
|
|
import { GRAFANA_RULES_SOURCE_NAME } from './utils/datasource';
|
|
|
|
const ui = {
|
|
filter: {
|
|
name: byTestId('name-filter'),
|
|
label: byTestId('label-filter'),
|
|
},
|
|
ruleList: {
|
|
row: byTestId('alert-card-row'),
|
|
},
|
|
};
|
|
|
|
const combinedNamespaceMock = jest.fn<CombinedRuleNamespace[], any>();
|
|
jest.mock('./hooks/useCombinedRuleNamespaces', () => ({
|
|
useCombinedRuleNamespaces: () => combinedNamespaceMock(),
|
|
}));
|
|
|
|
const mockFolder = (folderOverride: Partial<FolderState> = {}): FolderState => {
|
|
return {
|
|
id: 1,
|
|
title: 'Folder with alerts',
|
|
uid: 'folder-1',
|
|
hasChanged: false,
|
|
canSave: false,
|
|
url: '/folder-1',
|
|
version: 1,
|
|
permissions: [],
|
|
canViewFolderPermissions: false,
|
|
canDelete: false,
|
|
...folderOverride,
|
|
};
|
|
};
|
|
|
|
describe('AlertsFolderView tests', () => {
|
|
it('Should display grafana alert rules when the namespace name matches the folder name', () => {
|
|
// Arrange
|
|
const store = configureStore();
|
|
const folder = mockFolder();
|
|
|
|
const grafanaNamespace: CombinedRuleNamespace = {
|
|
name: folder.title,
|
|
rulesSource: GRAFANA_RULES_SOURCE_NAME,
|
|
groups: [
|
|
{
|
|
name: 'group1',
|
|
rules: [
|
|
mockCombinedRule({ name: 'Test Alert 1' }),
|
|
mockCombinedRule({ name: 'Test Alert 2' }),
|
|
mockCombinedRule({ name: 'Test Alert 3' }),
|
|
],
|
|
},
|
|
{
|
|
name: 'group2',
|
|
rules: [
|
|
mockCombinedRule({ name: 'Test Alert 4' }),
|
|
mockCombinedRule({ name: 'Test Alert 5' }),
|
|
mockCombinedRule({ name: 'Test Alert 6' }),
|
|
],
|
|
},
|
|
],
|
|
};
|
|
|
|
combinedNamespaceMock.mockReturnValue([grafanaNamespace]);
|
|
|
|
// Act
|
|
render(
|
|
<Provider store={store}>
|
|
<MemoryRouter>
|
|
<AlertsFolderView folder={folder} />
|
|
</MemoryRouter>
|
|
</Provider>
|
|
);
|
|
|
|
// Assert
|
|
const alertRows = ui.ruleList.row.queryAll();
|
|
expect(alertRows).toHaveLength(6);
|
|
expect(alertRows[0]).toHaveTextContent('Test Alert 1');
|
|
expect(alertRows[1]).toHaveTextContent('Test Alert 2');
|
|
expect(alertRows[2]).toHaveTextContent('Test Alert 3');
|
|
expect(alertRows[3]).toHaveTextContent('Test Alert 4');
|
|
expect(alertRows[4]).toHaveTextContent('Test Alert 5');
|
|
expect(alertRows[5]).toHaveTextContent('Test Alert 6');
|
|
});
|
|
|
|
it('Should not display alert rules when the namespace name does not match the folder name', () => {
|
|
// Arrange
|
|
const store = configureStore();
|
|
const folder = mockFolder();
|
|
|
|
const grafanaNamespace: CombinedRuleNamespace = {
|
|
name: 'Folder without alerts',
|
|
rulesSource: GRAFANA_RULES_SOURCE_NAME,
|
|
groups: [
|
|
{
|
|
name: 'default',
|
|
rules: [
|
|
mockCombinedRule({ name: 'Test Alert from other folder 1' }),
|
|
mockCombinedRule({ name: 'Test Alert from other folder 2' }),
|
|
],
|
|
},
|
|
],
|
|
};
|
|
|
|
combinedNamespaceMock.mockReturnValue([grafanaNamespace]);
|
|
|
|
// Act
|
|
render(
|
|
<Provider store={store}>
|
|
<MemoryRouter>
|
|
<AlertsFolderView folder={folder} />
|
|
</MemoryRouter>
|
|
</Provider>
|
|
);
|
|
|
|
// Assert
|
|
expect(ui.ruleList.row.queryAll()).toHaveLength(0);
|
|
});
|
|
|
|
it('Should filter alert rules by the name, case insensitive', async () => {
|
|
// Arrange
|
|
const store = configureStore();
|
|
const folder = mockFolder();
|
|
|
|
const grafanaNamespace: CombinedRuleNamespace = {
|
|
name: folder.title,
|
|
rulesSource: GRAFANA_RULES_SOURCE_NAME,
|
|
groups: [
|
|
{
|
|
name: 'default',
|
|
rules: [mockCombinedRule({ name: 'CPU Alert' }), mockCombinedRule({ name: 'RAM usage alert' })],
|
|
},
|
|
],
|
|
};
|
|
|
|
combinedNamespaceMock.mockReturnValue([grafanaNamespace]);
|
|
|
|
// Act
|
|
render(
|
|
<Provider store={store}>
|
|
<MemoryRouter>
|
|
<AlertsFolderView folder={folder} />
|
|
</MemoryRouter>
|
|
</Provider>
|
|
);
|
|
|
|
await userEvent.type(ui.filter.name.get(), 'cpu');
|
|
|
|
// Assert
|
|
expect(ui.ruleList.row.queryAll()).toHaveLength(1);
|
|
expect(ui.ruleList.row.get()).toHaveTextContent('CPU Alert');
|
|
});
|
|
|
|
it('Should filter alert rule by labels', async () => {
|
|
// Arrange
|
|
const store = configureStore();
|
|
const folder = mockFolder();
|
|
|
|
const grafanaNamespace: CombinedRuleNamespace = {
|
|
name: folder.title,
|
|
rulesSource: GRAFANA_RULES_SOURCE_NAME,
|
|
groups: [
|
|
{
|
|
name: 'default',
|
|
rules: [
|
|
mockCombinedRule({ name: 'CPU Alert', labels: {} }),
|
|
mockCombinedRule({ name: 'RAM usage alert', labels: { severity: 'critical' } }),
|
|
],
|
|
},
|
|
],
|
|
};
|
|
|
|
combinedNamespaceMock.mockReturnValue([grafanaNamespace]);
|
|
|
|
// Act
|
|
render(
|
|
<Provider store={store}>
|
|
<MemoryRouter>
|
|
<AlertsFolderView folder={folder} />
|
|
</MemoryRouter>
|
|
</Provider>
|
|
);
|
|
|
|
await userEvent.type(ui.filter.label.get(), 'severity=critical');
|
|
|
|
// Assert
|
|
expect(ui.ruleList.row.queryAll()).toHaveLength(1);
|
|
expect(ui.ruleList.row.get()).toHaveTextContent('RAM usage alert');
|
|
});
|
|
});
|