aboutsummaryrefslogtreecommitdiffhomepage
path: root/frontend/app/components/UserIcon.test.tsx
diff options
context:
space:
mode:
Diffstat (limited to 'frontend/app/components/UserIcon.test.tsx')
-rw-r--r--frontend/app/components/UserIcon.test.tsx62
1 files changed, 62 insertions, 0 deletions
diff --git a/frontend/app/components/UserIcon.test.tsx b/frontend/app/components/UserIcon.test.tsx
new file mode 100644
index 0000000..964aae1
--- /dev/null
+++ b/frontend/app/components/UserIcon.test.tsx
@@ -0,0 +1,62 @@
+/**
+ * @vitest-environment jsdom
+ */
+import { cleanup, render, screen } from "@testing-library/react";
+import { afterEach, describe, expect, test } from "vitest";
+import UserIcon from "./UserIcon";
+
+afterEach(() => {
+ cleanup();
+});
+
+describe("UserIcon", () => {
+ test("renders an img element", () => {
+ render(
+ <UserIcon
+ iconPath="icons/test.png"
+ displayName="TestUser"
+ className="w-16 h-16"
+ />,
+ );
+ const img = screen.getByAltText("TestUser のアイコン");
+ expect(img.tagName).toBe("IMG");
+ });
+
+ test("sets alt text with display name", () => {
+ render(
+ <UserIcon
+ iconPath="icons/test.png"
+ displayName="Alice"
+ className="w-16 h-16"
+ />,
+ );
+ expect(screen.getByAltText("Alice のアイコン")).toBeDefined();
+ });
+
+ test("applies rounded-full and border classes", () => {
+ render(
+ <UserIcon
+ iconPath="icons/test.png"
+ displayName="Bob"
+ className="w-16 h-16"
+ />,
+ );
+ const img = screen.getByAltText("Bob のアイコン");
+ expect(img.className).toContain("rounded-full");
+ expect(img.className).toContain("border-4");
+ expect(img.className).toContain("border-white");
+ });
+
+ test("applies custom className", () => {
+ render(
+ <UserIcon
+ iconPath="icons/test.png"
+ displayName="Bob"
+ className="w-48 h-48"
+ />,
+ );
+ const img = screen.getByAltText("Bob のアイコン");
+ expect(img.className).toContain("w-48");
+ expect(img.className).toContain("h-48");
+ });
+});