react-day-picker / src /selection /useSingle.test.tsx
AbdulElahGwaith's picture
Upload folder using huggingface_hub
cf86710 verified
import { act, renderHook } from "@/test/render";
import { defaultDateLib } from "../classes/DateLib";
import type { DayPickerProps } from "../types";
import { useSingle } from "./useSingle";
describe("useSingle", () => {
it("uses the selected value from props when onSelect is provided", () => {
const mockOnSelect = jest.fn();
const selectedDate = new Date(2023, 9, 1);
const props: DayPickerProps = {
mode: "single",
selected: selectedDate,
onSelect: mockOnSelect,
};
const { result } = renderHook(() => useSingle(props, defaultDateLib));
expect(result.current.selected).toBe(selectedDate);
});
it("uses the internally selected value when onSelect is not provided", () => {
const initialSelectedDate = new Date(2023, 9, 1);
const props: DayPickerProps = {
mode: "single",
selected: initialSelectedDate,
};
const { result } = renderHook(() => useSingle(props, defaultDateLib));
act(() => {
result.current.select?.(new Date(2023, 9, 2), {}, {} as React.MouseEvent);
});
expect(result.current.selected).toEqual(new Date(2023, 9, 2));
});
});