2023-04-20 14:57:22 +02:00
|
|
|
import userEvent from "@testing-library/user-event";
|
|
|
|
|
import React from "react";
|
|
|
|
|
import { render, screen } from "@testing-library/react";
|
2023-09-11 11:40:15 +02:00
|
|
|
import { FieldProps } from "../Field";
|
|
|
|
|
import {
|
|
|
|
|
Checkbox,
|
|
|
|
|
CheckboxGroup,
|
|
|
|
|
CheckboxOnlyProps,
|
|
|
|
|
} from ":/components/Forms/Checkbox/index";
|
|
|
|
|
|
|
|
|
|
const spyError = vi.spyOn(global.console, "error");
|
2023-04-20 14:57:22 +02:00
|
|
|
|
|
|
|
|
describe("<Checkbox/>", () => {
|
2023-09-11 11:40:15 +02:00
|
|
|
afterAll(() => {
|
|
|
|
|
spyError.mockRestore();
|
|
|
|
|
});
|
|
|
|
|
|
2023-04-20 14:57:22 +02:00
|
|
|
it("renders and can be checked", async () => {
|
|
|
|
|
const user = userEvent.setup();
|
|
|
|
|
render(<Checkbox label="Agree" />);
|
|
|
|
|
const input: HTMLInputElement = screen.getByRole("checkbox", {
|
|
|
|
|
name: "Agree",
|
|
|
|
|
});
|
|
|
|
|
expect(input.checked).toEqual(false);
|
|
|
|
|
await user.click(input);
|
|
|
|
|
expect(input.checked).toEqual(true);
|
|
|
|
|
});
|
|
|
|
|
it("renders with default value and can be unchecked", async () => {
|
|
|
|
|
const user = userEvent.setup();
|
|
|
|
|
render(<Checkbox label="Agree" checked={true} />);
|
|
|
|
|
const input: HTMLInputElement = screen.getByRole("checkbox", {
|
|
|
|
|
name: "Agree",
|
|
|
|
|
});
|
|
|
|
|
expect(input.checked).toEqual(true);
|
|
|
|
|
await user.click(input);
|
|
|
|
|
expect(input.checked).toEqual(false);
|
|
|
|
|
});
|
|
|
|
|
it("renders with indeterminate state", async () => {
|
|
|
|
|
render(<Checkbox label="Agree" indeterminate={true} />);
|
|
|
|
|
expect(document.querySelector("svg.indeterminate")).toBeInTheDocument();
|
|
|
|
|
});
|
|
|
|
|
it("renders disabled", async () => {
|
|
|
|
|
render(<Checkbox label="Agree" disabled={true} />);
|
|
|
|
|
expect(screen.getByRole("checkbox", { name: "Agree" })).toBeDisabled();
|
|
|
|
|
// Click and expect the checkbox does not get checked
|
|
|
|
|
const user = userEvent.setup();
|
|
|
|
|
const input: HTMLInputElement = screen.getByRole("checkbox", {
|
|
|
|
|
name: "Agree",
|
|
|
|
|
});
|
|
|
|
|
expect(input.checked).toEqual(false);
|
|
|
|
|
await user.click(input);
|
|
|
|
|
expect(input.checked).toEqual(false);
|
|
|
|
|
});
|
|
|
|
|
it("renders with text", async () => {
|
|
|
|
|
render(<Checkbox label="Agree" text="Text" />);
|
|
|
|
|
expect(screen.getByText("Text")).toBeInTheDocument();
|
|
|
|
|
});
|
|
|
|
|
it("renders with state=success", async () => {
|
|
|
|
|
render(<Checkbox label="Agree" state="success" text="Success text" />);
|
|
|
|
|
expect(screen.getByText("Success text")).toBeInTheDocument();
|
|
|
|
|
expect(
|
2023-07-18 15:43:56 +02:00
|
|
|
document.querySelector(".c__field.c__field--success"),
|
2023-04-20 14:57:22 +02:00
|
|
|
).toBeInTheDocument();
|
|
|
|
|
});
|
|
|
|
|
it("renders with state=error", async () => {
|
|
|
|
|
render(<Checkbox label="Agree" state="error" text="Error text" />);
|
|
|
|
|
expect(screen.getByText("Error text")).toBeInTheDocument();
|
|
|
|
|
expect(
|
2023-07-18 15:43:56 +02:00
|
|
|
document.querySelector(".c__field.c__field--error"),
|
2023-04-20 14:57:22 +02:00
|
|
|
).toBeInTheDocument();
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
it("renders with group", async () => {
|
|
|
|
|
render(
|
|
|
|
|
<CheckboxGroup>
|
|
|
|
|
<Checkbox label="Agree" />
|
|
|
|
|
<Checkbox label="Disagree" />
|
2023-07-18 15:43:56 +02:00
|
|
|
</CheckboxGroup>,
|
2023-04-20 14:57:22 +02:00
|
|
|
);
|
|
|
|
|
screen.getByRole("checkbox", {
|
|
|
|
|
name: "Agree",
|
|
|
|
|
});
|
|
|
|
|
screen.getByRole("checkbox", {
|
|
|
|
|
name: "Disagree",
|
|
|
|
|
});
|
|
|
|
|
});
|
|
|
|
|
it("renders with group text", async () => {
|
|
|
|
|
render(
|
|
|
|
|
<CheckboxGroup text="Text">
|
|
|
|
|
<Checkbox label="Agree" />
|
|
|
|
|
<Checkbox label="Disagree" />
|
2023-07-18 15:43:56 +02:00
|
|
|
</CheckboxGroup>,
|
2023-04-20 14:57:22 +02:00
|
|
|
);
|
|
|
|
|
expect(screen.getByText("Text")).toBeInTheDocument();
|
|
|
|
|
});
|
|
|
|
|
it("renders with group state=success", async () => {
|
|
|
|
|
render(
|
|
|
|
|
<CheckboxGroup state="success" text="Success text">
|
|
|
|
|
<Checkbox label="Agree" />
|
|
|
|
|
<Checkbox label="Disagree" />
|
2023-07-18 15:43:56 +02:00
|
|
|
</CheckboxGroup>,
|
2023-04-20 14:57:22 +02:00
|
|
|
);
|
|
|
|
|
expect(screen.getByText("Success text")).toBeInTheDocument();
|
|
|
|
|
expect(
|
2023-07-18 15:43:56 +02:00
|
|
|
document.querySelector(".c__checkbox__group.c__field.c__field--success"),
|
2023-04-20 14:57:22 +02:00
|
|
|
).toBeInTheDocument();
|
|
|
|
|
});
|
|
|
|
|
it("renders with group state=error", async () => {
|
|
|
|
|
render(
|
|
|
|
|
<CheckboxGroup state="error" text="Error text">
|
|
|
|
|
<Checkbox label="Agree" />
|
|
|
|
|
<Checkbox label="Disagree" />
|
2023-07-18 15:43:56 +02:00
|
|
|
</CheckboxGroup>,
|
2023-04-20 14:57:22 +02:00
|
|
|
);
|
|
|
|
|
expect(screen.getByText("Error text")).toBeInTheDocument();
|
|
|
|
|
expect(
|
2023-07-18 15:43:56 +02:00
|
|
|
document.querySelector(".c__checkbox__group.c__field.c__field--error"),
|
2023-04-20 14:57:22 +02:00
|
|
|
).toBeInTheDocument();
|
|
|
|
|
});
|
2023-09-11 11:40:15 +02:00
|
|
|
|
|
|
|
|
it("checks the props doesn't create error warning", async () => {
|
|
|
|
|
const propsInput: Required<FieldProps & CheckboxOnlyProps> = {
|
|
|
|
|
label: "First name",
|
|
|
|
|
fullWidth: true,
|
|
|
|
|
className: "c__field--full-width",
|
|
|
|
|
compact: false,
|
|
|
|
|
state: "default",
|
|
|
|
|
text: "my text",
|
|
|
|
|
textItems: ["my text item 1", "my text item 2"],
|
|
|
|
|
rightText: "my right text",
|
|
|
|
|
indeterminate: true,
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
render(<Checkbox {...propsInput} />);
|
|
|
|
|
expect(spyError).not.toHaveBeenCalled();
|
|
|
|
|
});
|
2023-04-20 14:57:22 +02:00
|
|
|
});
|