react-day-picker / examples /CustomDropdown /CustomDropdown.test.tsx
AbdulElahGwaith's picture
Upload folder using huggingface_hub
cf86710 verified
import { render, screen } from "@testing-library/react";
import React from "react";
import { grid, monthDropdown, yearDropdown } from "@/test/elements";
import { setTestTime } from "@/test/setTestTime";
import { user } from "@/test/user";
import { CustomDropdown } from "./CustomDropdown";
// Mocks for Radix UI
window.PointerEvent =
class PointerEvent extends Event {} as unknown as typeof window.PointerEvent;
window.HTMLElement.prototype.scrollIntoView = jest.fn();
window.HTMLElement.prototype.hasPointerCapture = jest.fn();
window.HTMLElement.prototype.releasePointerCapture = jest.fn();
const today = new Date(2015, 6, 1);
setTestTime(today);
beforeEach(() => {
render(<CustomDropdown />);
});
test("should display the month dropdown", () => {
expect(monthDropdown()).toBeInTheDocument();
});
test("should display the year dropdown", () => {
expect(yearDropdown()).toBeInTheDocument();
});
test("change month", async () => {
expect(grid()).toHaveAccessibleName("July 2015");
await user.click(yearDropdown());
await user.click(screen.getByRole("option", { name: "2000" }));
await user.click(monthDropdown());
await user.click(screen.getByRole("option", { name: "December" }));
expect(grid()).toHaveAccessibleName("December 2000");
});