grafana/public/app/features/trails/DataTrail.test.tsx
Darren Janeczek a5377f85ce
data-trails: hightlight current node and its ancestry (#78660)
* feat: data-trails: show current node and ancestry
2023-11-28 13:16:22 -05:00

130 lines
3.9 KiB
TypeScript

import { locationService, setDataSourceSrv } from '@grafana/runtime';
import { getUrlSyncManager } from '@grafana/scenes';
import { MockDataSourceSrv, mockDataSource } from '../alerting/unified/mocks';
import { DataSourceType } from '../alerting/unified/utils/datasource';
import { activateFullSceneTree } from '../dashboard-scene/utils/test-utils';
import { DataTrail } from './DataTrail';
import { MetricScene } from './MetricScene';
import { MetricSelectScene } from './MetricSelectScene';
import { MetricSelectedEvent } from './shared';
describe('DataTrail', () => {
beforeAll(() => {
setDataSourceSrv(
new MockDataSourceSrv({
prom: mockDataSource({
name: 'Prometheus',
type: DataSourceType.Prometheus,
}),
})
);
});
describe('Given starting trail with url sync and no url state', () => {
let trail: DataTrail;
beforeEach(() => {
trail = new DataTrail({});
locationService.push('/');
getUrlSyncManager().initSync(trail);
activateFullSceneTree(trail);
});
it('Should default to metric select scene', () => {
expect(trail.state.topScene).toBeInstanceOf(MetricSelectScene);
});
it('Should set stepIndex to 0', () => {
expect(trail.state.stepIndex).toBe(0);
});
it('Should set parentIndex to -1', () => {
expect(trail.state.parentIndex).toBe(-1);
});
it('Should set history currentStep to 0', () => {
expect(trail.state.history.state.currentStep).toBe(0);
});
describe('And metric is selected', () => {
beforeEach(() => {
trail.publishEvent(new MetricSelectedEvent('metric_bucket'));
});
it('should switch scene to MetricScene', () => {
expect(trail.state.metric).toBe('metric_bucket');
expect(trail.state.topScene).toBeInstanceOf(MetricScene);
});
it('should sync state with url', () => {
expect(locationService.getSearchObject().metric).toBe('metric_bucket');
});
it('should add history step', () => {
expect(trail.state.history.state.steps[1].type).toBe('metric');
});
it('Should set stepIndex to 1', () => {
expect(trail.state.stepIndex).toBe(1);
});
it('Should set history currentStep to 1', () => {
expect(trail.state.history.state.currentStep).toBe(1);
});
it('Should set parentIndex to 0', () => {
expect(trail.state.parentIndex).toBe(0);
});
});
describe('When going back to history step 1', () => {
beforeEach(() => {
trail.publishEvent(new MetricSelectedEvent('first_metric'));
trail.publishEvent(new MetricSelectedEvent('second_metric'));
trail.goBackToStep(trail.state.history.state.steps[1]);
});
it('Should restore state and url', () => {
expect(trail.state.metric).toBe('first_metric');
expect(locationService.getSearchObject().metric).toBe('first_metric');
});
it('Should set stepIndex to 1', () => {
expect(trail.state.stepIndex).toBe(1);
});
it('Should set history currentStep to 1', () => {
expect(trail.state.history.state.currentStep).toBe(1);
});
it('Should not create another history step', () => {
expect(trail.state.history.state.steps.length).toBe(3);
});
describe('But then selecting a new metric', () => {
beforeEach(() => {
trail.publishEvent(new MetricSelectedEvent('third_metric'));
});
it('Should create another history step', () => {
expect(trail.state.history.state.steps.length).toBe(4);
});
it('Should set stepIndex to 3', () => {
expect(trail.state.stepIndex).toBe(3);
});
it('Should set history currentStep to 1', () => {
expect(trail.state.history.state.currentStep).toBe(3);
});
it('Should set parentIndex to 1', () => {
expect(trail.state.parentIndex).toBe(1);
});
});
});
});
});