/* * Copyright 2024 The Matrix.org Foundation C.I.C. * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ import React from "react"; import { render, screen, waitFor, act } from "@testing-library/react"; import { AuthType } from "matrix-js-sdk/src/interactive-auth"; import userEvent from "@testing-library/user-event"; import { EmailIdentityAuthEntry } from "../../../../src/components/views/auth/InteractiveAuthEntryComponents"; import { createTestClient } from "../../../test-utils"; describe("", () => { const renderIdentityAuth = () => { const matrixClient = createTestClient(); return render( , ); }; test("should render", () => { const { container } = renderIdentityAuth(); expect(container).toMatchSnapshot(); }); test("should clear the requested state when the button tooltip is hidden", async () => { renderIdentityAuth(); // After a click on the resend button, the button should display the resent label screen.getByRole("button", { name: "Resend" }).click(); await waitFor(() => expect(screen.queryByRole("button", { name: "Resent!" })).toBeInTheDocument()); expect(screen.queryByRole("button", { name: "Resend" })).toBeNull(); const resentButton = screen.getByRole("button", { name: "Resent!" }); // Hover briefly the button and wait for the tooltip to be displayed await userEvent.hover(resentButton); await waitFor(() => expect(screen.getByRole("tooltip", { name: "Resent!" })).toBeInTheDocument()); // On unhover, it should display again the resend button await act(() => userEvent.unhover(resentButton)); await waitFor(() => expect(screen.queryByRole("button", { name: "Resend" })).toBeInTheDocument()); }); });