1
0
mirror of https://github.com/Unleash/unleash.git synced 2024-12-28 00:06:53 +01:00
unleash.unleash/frontend/src/hooks/useOnBlur.test.tsx
Nuno Góis 4167a60588
feat: biome lint frontend (#4903)
Follows up on https://github.com/Unleash/unleash/pull/4853 to add Biome
to the frontend as well.


![image](https://github.com/Unleash/unleash/assets/14320932/1906faf1-fc29-4172-a4d4-b2716d72cd65)

Added a few `biome-ignore` to speed up the process but we may want to
check and fix them in the future.
2023-10-02 13:25:46 +01:00

55 lines
1.6 KiB
TypeScript

import { render, screen, waitFor } from '@testing-library/react';
import { useRef } from 'react';
import { useOnBlur } from './useOnBlur';
function TestComponent(props: { onBlurHandler: () => void }) {
const divRef = useRef(null);
useOnBlur(divRef, props.onBlurHandler);
return (
<div data-testid='wrapper'>
{/* biome-ignore lint/a11y/noNoninteractiveTabindex: <explanation> */}
<div tabIndex={0} data-testid='inside' ref={divRef}>
Inside
</div>
{/* biome-ignore lint/a11y/noNoninteractiveTabindex: <explanation> */}
<div tabIndex={0} data-testid='outside'>
Outside
</div>
</div>
);
}
test('should not call the callback when blurring within the same container', async () => {
let mockCallbackCallCount = 0;
const mockCallback = () => mockCallbackCallCount++;
render(<TestComponent onBlurHandler={mockCallback} />);
const insideDiv = screen.getByTestId('inside');
insideDiv.focus();
insideDiv.blur();
await waitFor(() => {
expect(mockCallbackCallCount).toBe(0);
});
});
test('should call the callback when blurring outside of the container', async () => {
let mockCallbackCallCount = 0;
const mockCallback = () => mockCallbackCallCount++;
render(<TestComponent onBlurHandler={mockCallback} />);
const insideDiv = screen.getByTestId('inside');
const outsideDiv = screen.getByTestId('outside');
insideDiv.focus();
outsideDiv.focus();
await waitFor(() => {
expect(mockCallbackCallCount).toBe(1);
});
});