You've already forked element-web
mirror of
https://github.com/element-hq/element-web.git
synced 2025-08-09 14:42:51 +03:00
* Add report room dialog button/dialog. * Update copy * fixup tests / lint * Fix title in test. * update snapshot * Add unit tests for dialog * lint * First pass at adding a report room on invite. * Use a single line input field for reason to avoid bumping the layout. * Fixups * Embed reason to make it clear on grouping * Revert accidental commit * lint * Add some playwright tests. * tweaks * Make ignored users list more accessible. * i18n * Fix sliding sync test. * Add unit test * Even more unit tests. * move test * Update to match designs. * remove console statements * fix css * tidy up * improve comments * fix css * updates
53 lines
2.2 KiB
TypeScript
53 lines
2.2 KiB
TypeScript
/*
|
|
Copyright 2025 New Vector Ltd.
|
|
|
|
SPDX-License-Identifier: AGPL-3.0-only OR GPL-3.0-only OR LicenseRef-Element-Commercial
|
|
Please see LICENSE files in the repository root for full details.
|
|
*/
|
|
|
|
import { render } from "jest-matrix-react";
|
|
import userEvent from "@testing-library/user-event";
|
|
import React from "react";
|
|
|
|
import SdkConfig from "../../../../../src/SdkConfig";
|
|
import { DeclineAndBlockInviteDialog } from "../../../../../src/components/views/dialogs/DeclineAndBlockInviteDialog";
|
|
|
|
describe("ConfirmRejectInviteDialog", () => {
|
|
const onFinished: jest.Mock<any, any> = jest.fn();
|
|
|
|
const MY_ROOM_NAME = "foo";
|
|
|
|
beforeEach(() => {
|
|
jest.resetAllMocks();
|
|
});
|
|
|
|
afterEach(() => {
|
|
SdkConfig.reset();
|
|
});
|
|
|
|
it("can close the dialog", async () => {
|
|
const { getByTestId } = render(<DeclineAndBlockInviteDialog onFinished={onFinished} roomName={MY_ROOM_NAME} />);
|
|
await userEvent.click(getByTestId("dialog-cancel-button"));
|
|
expect(onFinished).toHaveBeenCalledWith(false, false, false);
|
|
});
|
|
|
|
it("can reject with options selected", async () => {
|
|
const { container, getByLabelText, getByRole } = render(
|
|
<DeclineAndBlockInviteDialog onFinished={onFinished} roomName={MY_ROOM_NAME} />,
|
|
);
|
|
await userEvent.click(getByRole("switch", { name: "Ignore user" }));
|
|
await userEvent.click(getByRole("switch", { name: "Report room" }));
|
|
await userEvent.type(getByLabelText("Reason"), "I want to report this room");
|
|
expect(container).toMatchSnapshot();
|
|
await userEvent.click(getByRole("button", { name: "Decline invite" }));
|
|
expect(onFinished).toHaveBeenCalledWith(true, true, "I want to report this room");
|
|
});
|
|
it("can reject without a reason", async () => {
|
|
const { getByRole } = render(<DeclineAndBlockInviteDialog onFinished={onFinished} roomName={MY_ROOM_NAME} />);
|
|
await userEvent.click(getByRole("switch", { name: "Ignore user" }));
|
|
await userEvent.click(getByRole("switch", { name: "Report room" }));
|
|
await userEvent.click(getByRole("button", { name: "Decline invite" }));
|
|
expect(onFinished).toHaveBeenCalledWith(true, true, "");
|
|
});
|
|
});
|