grafana/public/app/features/alerting/state/selectors.test.ts

99 lines
2.2 KiB
TypeScript
Raw Normal View History

2018-09-03 09:58:11 -05:00
import { getSearchQuery, getAlertRuleItems } from './selectors';
describe('Get search query', () => {
it('should get search query', () => {
const state = { searchQuery: 'dashboard' };
2019-05-13 02:38:19 -05:00
const result = getSearchQuery(state as any);
2018-09-03 09:58:11 -05:00
expect(result).toEqual(state.searchQuery);
});
});
describe('Get alert rule items', () => {
it('should get alert rule items', () => {
const state = {
alertRules: {
items: [
{
id: 1,
dashboardId: 1,
panelId: 1,
name: '',
state: '',
stateText: '',
stateIcon: '',
stateClass: '',
stateAge: '',
url: '',
},
],
searchQuery: '',
},
};
2018-09-03 09:58:11 -05:00
2019-05-13 02:38:19 -05:00
const result = getAlertRuleItems(state as any);
expect(result.length).toEqual(1);
});
it('should filter rule items based on search query', () => {
const state = {
alertRules: {
items: [
{
id: 1,
dashboardId: 1,
panelId: 1,
name: 'dashboard',
state: '',
stateText: '',
stateIcon: '',
stateClass: '',
stateAge: '',
url: '',
},
{
id: 2,
dashboardId: 3,
panelId: 1,
name: 'dashboard2',
state: '',
stateText: '',
stateIcon: '',
stateClass: '',
stateAge: '',
url: '',
},
{
id: 3,
dashboardId: 5,
panelId: 1,
name: 'hello',
state: '',
stateText: '',
stateIcon: '',
stateClass: '',
stateAge: '',
url: '',
},
{
id: 4,
dashboardId: 7,
panelId: 1,
name: 'test',
state: '',
stateText: 'dashboard',
stateIcon: '',
stateClass: '',
stateAge: '',
url: '',
},
],
searchQuery: 'dashboard',
},
};
2018-09-03 09:58:11 -05:00
2019-05-13 02:38:19 -05:00
const result = getAlertRuleItems(state as any);
expect(result.length).toEqual(3);
2018-09-03 09:58:11 -05:00
});
});