/* * Copyright 2024 New Vector Ltd. * Copyright 2024 The Matrix.org Foundation C.I.C. * * SPDX-License-Identifier: AGPL-3.0-only OR GPL-3.0-only * Please see LICENSE files in the repository root for full details. */ import React from "react"; import { render, screen, waitFor, act, fireEvent } from "@testing-library/react"; import { AuthType } from "matrix-js-sdk/src/interactive-auth"; import userEvent from "@testing-library/user-event"; import { EmailIdentityAuthEntry, MasUnlockCrossSigningAuthEntry, } 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()); }); }); describe("", () => { const renderAuth = (props = {}) => { const matrixClient = createTestClient(); return render( , ); }; test("should render", () => { const { container } = renderAuth(); expect(container).toMatchSnapshot(); }); test("should open idp in new tab on click", async () => { const spy = jest.spyOn(global.window, "open"); renderAuth(); fireEvent.click(screen.getByRole("button", { name: "Go to your account" })); expect(spy).toHaveBeenCalledWith("https://example.com", "_blank"); }); test("should retry uia request on click", async () => { const submitAuthDict = jest.fn(); renderAuth({ submitAuthDict }); fireEvent.click(screen.getByRole("button", { name: "Retry" })); expect(submitAuthDict).toHaveBeenCalledWith({}); }); });