Files
grafana/public/app/features/explore/NodeGraph/NodeGraphContainer.test.tsx
Haris Rozajac 69c4da618c Explore: Reorganized data viz components (#68510)
* Move logs-related files to its own folder; update ownership paths

* Fix failing tests

* Put Flame graph and Node graph related files into separate folders

* Put RawPrometheus related files into a separate folder

* Put Table related files into a separate folder

* Add owners to three visualization categories

* observability-logs team owns everything under logs

* Move logs utils to their separate folder under Logs
2023-05-23 07:42:38 -06:00

61 lines
1.7 KiB
TypeScript

import { render, screen } from '@testing-library/react';
import React from 'react';
import { getDefaultTimeRange, MutableDataFrame } from '@grafana/data';
import { ExploreId } from 'app/types';
import { UnconnectedNodeGraphContainer } from './NodeGraphContainer';
describe('NodeGraphContainer', () => {
it('is collapsed if shown with traces', () => {
const { container } = render(
<UnconnectedNodeGraphContainer
dataFrames={[emptyFrame]}
exploreId={ExploreId.left}
range={getDefaultTimeRange()}
splitOpenFn={() => {}}
withTraceView={true}
datasourceType={''}
/>
);
// Make sure we only show header in the collapsible
expect(container.firstChild?.childNodes.length).toBe(1);
});
it('shows the graph if not with trace view', async () => {
const { container } = render(
<UnconnectedNodeGraphContainer
dataFrames={[nodes]}
exploreId={ExploreId.left}
range={getDefaultTimeRange()}
splitOpenFn={() => {}}
datasourceType={''}
/>
);
expect(container.firstChild?.childNodes.length).toBe(2);
expect(container.querySelector('svg')).toBeInTheDocument();
await screen.findByLabelText(/Node: tempo-querier/);
});
});
const emptyFrame = new MutableDataFrame();
const nodes = new MutableDataFrame({
fields: toFields([
['id', ['3fa414edcef6ad90']],
['title', ['tempo-querier']],
['subTitle', ['HTTP GET - api_traces_traceid']],
['mainStat', ['1049.14ms (100%)']],
['secondaryStat', ['1047.29ms (99.82%)']],
['color', [0.9982395121342127]],
]),
});
function toFields(fields: Array<[string, unknown[]]>) {
return fields.map(([name, values]) => {
return { name, values };
});
}