diff options
Diffstat (limited to 'frontend/app/components/InputText.test.tsx')
| -rw-r--r-- | frontend/app/components/InputText.test.tsx | 36 |
1 files changed, 36 insertions, 0 deletions
diff --git a/frontend/app/components/InputText.test.tsx b/frontend/app/components/InputText.test.tsx new file mode 100644 index 0000000..2072b37 --- /dev/null +++ b/frontend/app/components/InputText.test.tsx @@ -0,0 +1,36 @@ +/** + * @vitest-environment jsdom + */ +import { cleanup, render, screen } from "@testing-library/react"; +import { afterEach, describe, expect, test } from "vitest"; +import InputText from "./InputText"; + +afterEach(() => { + cleanup(); +}); + +describe("InputText", () => { + test("renders an input element", () => { + render(<InputText data-testid="input" />); + const input = screen.getByTestId("input"); + expect(input.tagName).toBe("INPUT"); + }); + + test("passes placeholder prop", () => { + render(<InputText placeholder="Enter text" data-testid="input" />); + const input = screen.getByTestId("input") as HTMLInputElement; + expect(input.placeholder).toBe("Enter text"); + }); + + test("passes type prop", () => { + render(<InputText type="password" data-testid="input" />); + const input = screen.getByTestId("input") as HTMLInputElement; + expect(input.type).toBe("password"); + }); + + test("has border styling", () => { + render(<InputText data-testid="input" />); + const input = screen.getByTestId("input"); + expect(input.className).toContain("border-sky-600"); + }); +}); |
