import { fireEvent, render, screen } from "@testing-library/svelte";
import { describe, expect, it, vi } from "vitest";
import Markdown from "./Markdown.svelte";
describe("Markdown", () => {
it("renders markdown into a .markdown-body container", () => {
const { container } = render(Markdown, { props: { text: "# Hello\n\n**hi**" } });
expect(container.querySelector(".markdown-body")).not.toBeNull();
expect(screen.getByRole("heading", { level: 1, name: "Hello" })).toBeInTheDocument();
expect(container.querySelector("strong")?.textContent).toBe("hi");
});
it("strips dangerous markup", () => {
const { container } = render(Markdown, {
props: { text: "before after" },
});
expect(container.querySelector("script")).toBeNull();
expect(container.textContent).toContain("before");
});
it("renders a copy button on a code block that copies the code to the clipboard", async () => {
const writeText = vi.fn().mockResolvedValue(undefined);
Object.defineProperty(navigator, "clipboard", { value: { writeText }, configurable: true });
const { container } = render(Markdown, {
props: { text: "```js\nconst x = 1;\n```" },
});
const button = container.querySelector("[data-copy]");
expect(button).not.toBeNull();
if (button === null) throw new Error("expected a copy button");
await fireEvent.click(button);
expect(writeText).toHaveBeenCalledTimes(1);
expect(writeText.mock.calls[0]?.[0]).toContain("const x = 1;");
});
});