grafana_bak/public/app/plugins/panel/logs/useDatasourcesFromTargets.test.ts
2025-04-01 10:38:02 +09:00

45 lines
1.5 KiB
TypeScript

// CustomHook.test.js
import { renderHook, waitFor } from '@testing-library/react';
import { MockDataSourceApi, DatasourceSrvMock } from 'test/mocks/datasource_srv';
import { useDatasourcesFromTargets } from './useDatasourcesFromTargets'; // Update the path accordingly
const defaultDs = new MockDataSourceApi('default datasource', { data: ['default data'] });
const ds1 = new MockDataSourceApi('dataSource1');
const ds2 = new MockDataSourceApi('dataSource2') as MockDataSourceApi;
const datasourceSrv = new DatasourceSrvMock(defaultDs, {
dataSource1: ds1,
dataSource2: ds2,
});
const getDataSourceSrvMock = jest.fn().mockReturnValue(datasourceSrv);
jest.mock('@grafana/runtime', () => ({
...jest.requireActual('@grafana/runtime'),
getDataSourceSrv: () => getDataSourceSrvMock(),
}));
describe('useDatasourcesFromTargets', () => {
it('returns an empty map when targets are not provided', async () => {
const { result } = renderHook(() => useDatasourcesFromTargets(undefined));
await waitFor(() => {
expect(result.current.size).toBe(0);
});
});
it('fetches and returns the data sources map', async () => {
const mockTargets = [
{ refId: '1', datasource: { uid: 'dataSource1' } },
{ refId: '2', datasource: { uid: 'dataSource2' } },
];
const { result } = renderHook(() => useDatasourcesFromTargets(mockTargets));
await waitFor(() => {
expect(result.current.size).toBe(2);
expect(result.current.get('1')).toEqual(ds1);
expect(result.current.get('2')).toEqual(ds2);
});
});
});