summaryrefslogtreecommitdiffhomepage
path: root/src/features/views/ui/ViewSidebar.test.ts
blob: 8a0049cba77c54e75c103c99a687a1ef3abe64e3 (plain)
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
56
57
58
import { render, screen } from "@testing-library/svelte";
import userEvent from "@testing-library/user-event";
import { createRawSnippet } from "svelte";
import { describe, expect, it } from "vitest";
import ViewSidebar from "./ViewSidebar.svelte";

const kinds = [
	{ id: "surfaces", label: "Surfaces" },
	{ id: "tasks", label: "Tasks" },
];

// A raw snippet that echoes the kind it was rendered for, so tests can assert
// which view-kind content each panel shows.
const content = createRawSnippet<[string]>((kind) => ({
	render: () => `<div data-testid="view-content">kind:${kind()}</div>`,
}));

describe("ViewSidebar", () => {
	it("opens one panel seeded with the first kind and renders its content", () => {
		render(ViewSidebar, { props: { kinds, content } });
		expect(screen.getAllByRole("combobox")).toHaveLength(1);
		expect(screen.getByTestId("view-content")).toHaveTextContent("kind:surfaces");
	});

	it("the first panel has no remove button", () => {
		render(ViewSidebar, { props: { kinds, content } });
		expect(screen.queryByRole("button", { name: "Remove view" })).toBeNull();
	});

	it("the add button appends a new empty panel", async () => {
		const user = userEvent.setup();
		render(ViewSidebar, { props: { kinds, content } });
		await user.click(screen.getByRole("button", { name: "Add view" }));
		expect(screen.getAllByRole("combobox")).toHaveLength(2);
		// the new panel is empty → only the first panel renders content
		expect(screen.getAllByTestId("view-content")).toHaveLength(1);
	});

	it("non-first panels can be removed", async () => {
		const user = userEvent.setup();
		render(ViewSidebar, { props: { kinds, content } });
		await user.click(screen.getByRole("button", { name: "Add view" }));
		const removeButtons = screen.getAllByRole("button", { name: "Remove view" });
		expect(removeButtons).toHaveLength(1);
		const target = removeButtons[0];
		if (target === undefined) throw new Error("expected a remove button");
		await user.click(target);
		expect(screen.getAllByRole("combobox")).toHaveLength(1);
	});

	it("selecting a kind renders that kind's content", async () => {
		const user = userEvent.setup();
		render(ViewSidebar, { props: { kinds, content, initial: [null] } });
		expect(screen.queryByTestId("view-content")).toBeNull();
		await user.selectOptions(screen.getByRole("combobox"), "tasks");
		expect(screen.getByTestId("view-content")).toHaveTextContent("kind:tasks");
	});
});