mirror of
https://github.com/grafana/grafana.git
synced 2025-08-01 20:22:19 +08:00

* update eslint, tsconfig + esbuild to handle new jsx transform * remove thing that breaks the new jsx transform * remove react imports * adjust grafana-icons build * is this the correct syntax? * try this * well this was much easier than expected... * change grafana-plugin-configs webpack config * fixes * fix lockfile * fix 2 more violations * use path.resolve instead of require.resolve * remove react import * fix react imports * more fixes * remove React import * remove import React from docs * remove another react import
48 lines
1.2 KiB
TypeScript
48 lines
1.2 KiB
TypeScript
import { render, screen } from '@testing-library/react';
|
|
|
|
import { FuncInstance } from '../gfunc';
|
|
|
|
import { FunctionEditor } from './FunctionEditor';
|
|
|
|
function mockFunctionInstance(name: string, unknown?: boolean): FuncInstance {
|
|
const def = {
|
|
category: 'category',
|
|
defaultParams: [],
|
|
fake: false,
|
|
name: name,
|
|
params: [],
|
|
unknown: unknown,
|
|
};
|
|
return new FuncInstance(def);
|
|
}
|
|
|
|
describe('FunctionEditor', () => {
|
|
it('should display a defined function with name and no icon', () => {
|
|
render(
|
|
<FunctionEditor
|
|
func={mockFunctionInstance('foo')}
|
|
onMoveLeft={() => {}}
|
|
onMoveRight={() => {}}
|
|
onRemove={() => {}}
|
|
/>
|
|
);
|
|
|
|
expect(screen.getByText('foo')).toBeInTheDocument();
|
|
expect(screen.queryByTestId('warning-icon')).not.toBeInTheDocument();
|
|
});
|
|
|
|
it('should display an unknown function with name and warning icon', () => {
|
|
render(
|
|
<FunctionEditor
|
|
func={mockFunctionInstance('bar', true)}
|
|
onMoveLeft={jest.fn()}
|
|
onMoveRight={jest.fn()}
|
|
onRemove={jest.fn()}
|
|
/>
|
|
);
|
|
|
|
expect(screen.getByText('bar')).toBeInTheDocument();
|
|
expect(screen.getByTestId('warning-icon')).toBeInTheDocument();
|
|
});
|
|
});
|