/* Copyright 2024 New Vector Ltd. Copyright 2022 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 { fireEvent, render, screen } from "@testing-library/react"; import { defer } from "matrix-js-sdk/src/utils"; import PowerSelector from "../../../../src/components/views/elements/PowerSelector"; describe("", () => { it("should reset back to custom value when custom input is blurred blank", async () => { const fn = jest.fn(); render(); const input = screen.getByLabelText("Power level"); fireEvent.change(input, { target: { value: "" } }); fireEvent.blur(input); await screen.findByDisplayValue(25); expect(fn).not.toHaveBeenCalled(); }); it("should reset back to preset value when custom input is blurred blank", async () => { const fn = jest.fn(); render(); const select = screen.getByLabelText("Power level"); fireEvent.change(select, { target: { value: "SELECT_VALUE_CUSTOM" } }); const input = screen.getByLabelText("Power level"); fireEvent.change(input, { target: { value: "" } }); fireEvent.blur(input); const option = await screen.findByText("Moderator"); expect(option.selected).toBeTruthy(); expect(fn).not.toHaveBeenCalled(); }); it("should call onChange when custom input is blurred with a number in it", async () => { const fn = jest.fn(); render(); const input = screen.getByLabelText("Power level"); fireEvent.change(input, { target: { value: 40 } }); fireEvent.blur(input); await screen.findByDisplayValue(40); expect(fn).toHaveBeenCalledWith(40, "key"); }); it("should reset when props get changed", async () => { const fn = jest.fn(); const { rerender } = render(); const select = screen.getByLabelText("Power level"); fireEvent.change(select, { target: { value: "SELECT_VALUE_CUSTOM" } }); rerender(); await screen.findByDisplayValue(51); rerender(); const option = await screen.findByText("Moderator"); expect(option.selected).toBeTruthy(); expect(fn).not.toHaveBeenCalled(); }); it("should reset when onChange promise rejects", async () => { const deferred = defer(); render( deferred.promise} powerLevelKey="key" />, ); const input = screen.getByLabelText("Power level"); fireEvent.change(input, { target: { value: 40 } }); fireEvent.blur(input); await screen.findByDisplayValue(40); deferred.reject("Some error"); await screen.findByDisplayValue(25); }); });