From 8ba39936c5573e84ec20a53941dd1d8c3c6dd6f8 Mon Sep 17 00:00:00 2001 From: SeonjaeLee Date: Sat, 16 Nov 2024 14:24:30 +0900 Subject: [PATCH] test: Button Component --- src/components/Button/Button.test.tsx | 48 +++++++++++++++++++++++++++ 1 file changed, 48 insertions(+) create mode 100644 src/components/Button/Button.test.tsx diff --git a/src/components/Button/Button.test.tsx b/src/components/Button/Button.test.tsx new file mode 100644 index 00000000..1e19a9df --- /dev/null +++ b/src/components/Button/Button.test.tsx @@ -0,0 +1,48 @@ +import { fireEvent, render, screen } from "@testing-library/react"; +import { afterEach, beforeEach, expect, test, vi } from "vitest"; + +import Button from "./Button"; +import styles from "./Button.module.css"; + +beforeEach(() => { + vi.useFakeTimers(); +}); +afterEach(() => { + vi.restoreAllMocks(); +}); + +test("render primary button", () => { + render(); + + const button = screen.getByRole("button", { name: "test" }); + + expect(button.className).includes(styles.primary); +}); + +test("render secondary button", () => { + render(); + + const button = screen.getByRole("button", { name: "test" }); + + expect(button.className).includes(styles.secondary); +}); + +test("debounce 300ms one click", async () => { + const mockOnClick = vi.fn(); + + render( + , + ); + + const button = screen.getByRole("button", { name: "test" }); + + fireEvent.click(button); + fireEvent.click(button); + fireEvent.click(button); + + await vi.advanceTimersByTimeAsync(300); + + expect(mockOnClick).toHaveBeenCalledOnce(); +});