Mats Bosson 8f075f1792 feat: add 12 components — Tooltip, Popover, HoverCard, Alert, Badge,
Skeleton, Breadcrumbs, Link, Button, Image, Meter, NumberField
Floating components: Tooltip (hover/focus), Popover (click, with focus
trap and dismiss), HoverCard (hover with safe area).
Simple components: Alert (role=alert), Badge (role=status), Skeleton
(loading placeholder with data attributes).
Navigation: Breadcrumbs (nav>ol>li with separators), Link (accessible
anchor with disabled), Button (with disabled click suppression).
Data/Form: Image (Img+Fallback with loading status), Meter (like
Progress for known ranges), NumberField (spinbutton with inc/dec).
302 tests across 46 files, typecheck clean, build produces 176 files.
2026-03-29 19:34:13 +07:00

35 lines
1.1 KiB
TypeScript

import { fireEvent, render, screen } from "@solidjs/testing-library";
import { describe, expect, it, vi } from "vitest";
import { Button } from "../../../src/components/button/index";
describe("Button", () => {
it("renders as button element", () => {
render(() => <Button>Click</Button>);
expect(screen.getByRole("button")).toBeTruthy();
});
it("has type=button by default", () => {
render(() => <Button>Click</Button>);
expect(screen.getByRole("button").getAttribute("type")).toBe("button");
});
it("disabled button", () => {
render(() => <Button disabled>Click</Button>);
expect(screen.getByRole("button")).toBeDisabled();
});
it("fires onClick", () => {
const onClick = vi.fn();
render(() => <Button onClick={onClick}>Click</Button>);
fireEvent.click(screen.getByRole("button"));
expect(onClick).toHaveBeenCalled();
});
it("does not fire onClick when disabled", () => {
const onClick = vi.fn();
render(() => (
<Button disabled onClick={onClick}>
Click
</Button>
));
fireEvent.click(screen.getByRole("button"));
expect(onClick).not.toHaveBeenCalled();
});
});