| 12345678910111213141516171819202122232425262728293031323334353637 |
- import { render, screen } from "@testing-library/react";
- import userEvent from "@testing-library/user-event";
- import { describe, expect, it, vi } from "vitest";
- import { ImagePreview } from "#/components/image-preview";
- describe("ImagePreview", () => {
- it("should render an image", () => {
- render(
- <ImagePreview src="https://example.com/image.jpg" onRemove={vi.fn} />,
- );
- const img = screen.getByRole("img");
- expect(screen.getByTestId("image-preview")).toBeInTheDocument();
- expect(img).toHaveAttribute("src", "https://example.com/image.jpg");
- });
- it("should call onRemove when the close button is clicked", async () => {
- const user = userEvent.setup();
- const onRemoveMock = vi.fn();
- render(
- <ImagePreview
- src="https://example.com/image.jpg"
- onRemove={onRemoveMock}
- />,
- );
- const closeButton = screen.getByRole("button");
- await user.click(closeButton);
- expect(onRemoveMock).toHaveBeenCalledOnce();
- });
- it("shoud not display the close button when onRemove is not provided", () => {
- render(<ImagePreview src="https://example.com/image.jpg" />);
- expect(screen.queryByRole("button")).not.toBeInTheDocument();
- });
- });
|