-
Notifications
You must be signed in to change notification settings - Fork 5
Expand file tree
/
Copy pathProjectForm.test.tsx
More file actions
55 lines (48 loc) · 2.11 KB
/
Copy pathProjectForm.test.tsx
File metadata and controls
55 lines (48 loc) · 2.11 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
import { describe, it, expect, vi } from "vitest";
import { render, screen, fireEvent } from "@testing-library/react";
import { ProjectForm } from "@/components/projects/ProjectForm";
describe("ProjectForm", () => {
it("renders name, description, and status fields", () => {
render(<ProjectForm onSave={vi.fn()} />);
expect(screen.getByLabelText(/project name/i)).toBeInTheDocument();
expect(screen.getByLabelText(/description/i)).toBeInTheDocument();
expect(screen.getByLabelText(/status/i)).toBeInTheDocument();
});
it("shows validation error for short name", async () => {
render(<ProjectForm onSave={vi.fn()} />);
const nameInput = screen.getByLabelText(/project name/i);
fireEvent.change(nameInput, { target: { value: "X" } });
fireEvent.click(screen.getByRole("button", { name: /save project/i }));
expect(await screen.findByText(/at least 2 characters/i)).toBeInTheDocument();
});
it("calls onSave with correct data on valid submit", async () => {
const onSave = vi.fn();
render(<ProjectForm onSave={onSave} />);
fireEvent.change(screen.getByLabelText(/project name/i), {
target: { value: "My New Project" },
});
fireEvent.change(screen.getByLabelText(/description/i), {
target: { value: "A description" },
});
fireEvent.click(screen.getByRole("button", { name: /save project/i }));
expect(onSave).toHaveBeenCalledWith(
expect.objectContaining({ name: "My New Project", description: "A description" })
);
});
it("calls onCancel when cancel clicked", () => {
const onCancel = vi.fn();
render(<ProjectForm onSave={vi.fn()} onCancel={onCancel} />);
fireEvent.click(screen.getByRole("button", { name: /cancel/i }));
expect(onCancel).toHaveBeenCalled();
});
it("pre-fills fields from initial prop", () => {
render(
<ProjectForm
initial={{ name: "Existing", description: "Old desc", status: "archived" }}
onSave={vi.fn()}
/>
);
expect(screen.getByLabelText(/project name/i)).toHaveValue("Existing");
expect(screen.getByLabelText(/description/i)).toHaveValue("Old desc");
});
});