import { jest } from '@jest/globals';
import { act, waitFor } from '@testing-library/react';
import type { ComponentType } from 'react';
import React, { useState } from 'react';
import { runInDom } from '../../__test_dependency__/run-in-dom.js';
import { useBinding } from '../use-binding.js';
describe('useBinding', () => {
it('basic use should work', () =>
runInDom(({ onMount }) => {
const MyComponent: ComponentType = jest.fn(() => {
const b = useBinding(() => 0, { id: 'test' });
return <>{b.get()}>;
});
onMount(() => {
expect(MyComponent).toHaveBeenCalledTimes(1);
});
return ;
}));
it('deps use should work', () =>
runInDom(({ onMount }) => {
let stateSetter: (value: number) => void;
let instanceNumber = 0;
const MyComponent: ComponentType = jest.fn(() => {
const [state, setState] = useState(0);
stateSetter = setState;
const b = useBinding(() => instanceNumber++, { id: 'test', deps: [state] });
return <>{b.get()}>;
});
onMount(async () => {
expect(MyComponent).toHaveBeenCalledTimes(1);
expect(instanceNumber).toBe(1);
act(() => stateSetter(1));
await waitFor(() => expect(instanceNumber).toBe(2));
expect(MyComponent).toHaveBeenCalledTimes(2);
act(() => stateSetter(1)); // same state value again
await waitFor(() => expect(MyComponent).toHaveBeenCalledTimes(3));
expect(instanceNumber).toBe(2);
});
return ;
}));
});