import React, { FunctionComponent } from 'react';
import { renderHook } from '@testing-library/react-hooks';
import { ElasticsearchProvider, useDatasource, useQuery } from './ElasticsearchQueryContext';
import { ElasticsearchQuery } from '../../types';
import { ElasticDatasource } from '../../datasource';
const query: ElasticsearchQuery = {
refId: 'A',
metrics: [{ id: '1', type: 'count' }],
bucketAggs: [{ type: 'date_histogram', id: '2' }],
};
describe('ElasticsearchQueryContext', () => {
describe('useQuery Hook', () => {
it('Should throw when used outside of ElasticsearchQueryContext', () => {
const { result } = renderHook(() => useQuery());
expect(result.error).toBeTruthy();
});
it('Should return the current query object', () => {
const wrapper: FunctionComponent = ({ children }) => (
{}}>
{children}
);
const { result } = renderHook(() => useQuery(), {
wrapper,
});
expect(result.current).toBe(query);
});
});
describe('useDatasource Hook', () => {
it('Should throw when used outside of ElasticsearchQueryContext', () => {
const { result } = renderHook(() => useDatasource());
expect(result.error).toBeTruthy();
});
it('Should return the current datasource instance', () => {
const datasource = {} as ElasticDatasource;
const wrapper: FunctionComponent = ({ children }) => (
{}}>
{children}
);
const { result } = renderHook(() => useDatasource(), {
wrapper,
});
expect(result.current).toBe(datasource);
});
});
});