Files
Ashley Harrison 47f8717149 React: Use new JSX transform (#88802)
* 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
2024-06-25 12:43:47 +01:00

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();
});
});