image-preview.test.tsx 1.2 KB

12345678910111213141516171819202122232425262728293031323334353637
  1. import { render, screen } from "@testing-library/react";
  2. import userEvent from "@testing-library/user-event";
  3. import { describe, expect, it, vi } from "vitest";
  4. import { ImagePreview } from "#/components/image-preview";
  5. describe("ImagePreview", () => {
  6. it("should render an image", () => {
  7. render(
  8. <ImagePreview src="https://example.com/image.jpg" onRemove={vi.fn} />,
  9. );
  10. const img = screen.getByRole("img");
  11. expect(screen.getByTestId("image-preview")).toBeInTheDocument();
  12. expect(img).toHaveAttribute("src", "https://example.com/image.jpg");
  13. });
  14. it("should call onRemove when the close button is clicked", async () => {
  15. const user = userEvent.setup();
  16. const onRemoveMock = vi.fn();
  17. render(
  18. <ImagePreview
  19. src="https://example.com/image.jpg"
  20. onRemove={onRemoveMock}
  21. />,
  22. );
  23. const closeButton = screen.getByRole("button");
  24. await user.click(closeButton);
  25. expect(onRemoveMock).toHaveBeenCalledOnce();
  26. });
  27. it("shoud not display the close button when onRemove is not provided", () => {
  28. render(<ImagePreview src="https://example.com/image.jpg" />);
  29. expect(screen.queryByRole("button")).not.toBeInTheDocument();
  30. });
  31. });