UNPKG

monday-ui-react-core

Version:

Official monday.com UI resources for application development in React.js

34 lines (31 loc) 1.2 kB
import React from "react"; import { render, screen, waitFor, waitForElementToBeRemoved, fireEvent } from "@testing-library/react"; import Tooltip from "../Tooltip"; describe("Tooltip Tests", () => { describe("Integration Tests", () => { it("Should trigger onTooltipShow", async () => { const onTooltipShow = jest.fn() const { getByText } = render( <Tooltip content={"content"} onTooltipShow={onTooltipShow}> <div>hello</div> </Tooltip> ); fireEvent.mouseOver(getByText('hello')) await waitFor(() => screen.getByText('content')) expect(onTooltipShow).toHaveBeenCalledTimes(1) }) it("Should trigger onTooltipHide", async () => { const onTooltipHide = jest.fn() const { getByText } = render( <Tooltip content={"content"} onTooltipHide={onTooltipHide}> <div>hello</div> </Tooltip> ); fireEvent.mouseOver(getByText('hello')) await waitFor(() => screen.getByText('content')) fireEvent.mouseLeave(getByText('hello')) await waitForElementToBeRemoved(() => screen.getByText('content')) expect(onTooltipHide).toHaveBeenCalledTimes(1) }) }); });