Add UIFeature to hide public space and room creation (#30708)
* Add settings to hide public room & space creation. * Add space changes. * Add room changes. * lint * Add playwright tests * don't specialcase 1 join rule * Ensure mocks get cleared * Fixup test * Add SpaceCreateMenu component unit-tests * Fixup create room test asserts * fix import
This commit is contained in:
@@ -17,25 +17,30 @@ import { UIFeature } from "../../../../../src/settings/UIFeature";
|
||||
|
||||
describe("<CreateRoomDialog />", () => {
|
||||
const userId = "@alice:server.org";
|
||||
const mockClient = getMockClientWithEventEmitter({
|
||||
...mockClientMethodsUser(userId),
|
||||
getDomain: jest.fn().mockReturnValue("server.org"),
|
||||
getClientWellKnown: jest.fn(),
|
||||
doesServerForceEncryptionForPreset: jest.fn(),
|
||||
// make every alias available
|
||||
getRoomIdForAlias: jest.fn().mockRejectedValue(new MatrixError({ errcode: "M_NOT_FOUND" })),
|
||||
});
|
||||
|
||||
const getE2eeEnableToggleInputElement = () => screen.getByLabelText("Enable end-to-end encryption");
|
||||
// labelled toggle switch doesn't set the disabled attribute, only aria-disabled
|
||||
const getE2eeEnableToggleIsDisabled = () =>
|
||||
getE2eeEnableToggleInputElement().getAttribute("aria-disabled") === "true";
|
||||
|
||||
let mockClient: ReturnType<typeof getMockClientWithEventEmitter>;
|
||||
beforeEach(() => {
|
||||
mockClient = getMockClientWithEventEmitter({
|
||||
...mockClientMethodsUser(userId),
|
||||
getDomain: jest.fn().mockReturnValue("server.org"),
|
||||
getClientWellKnown: jest.fn(),
|
||||
doesServerForceEncryptionForPreset: jest.fn(),
|
||||
// make every alias available
|
||||
getRoomIdForAlias: jest.fn().mockRejectedValue(new MatrixError({ errcode: "M_NOT_FOUND" })),
|
||||
});
|
||||
mockClient.doesServerForceEncryptionForPreset.mockResolvedValue(false);
|
||||
mockClient.getClientWellKnown.mockReturnValue({});
|
||||
});
|
||||
|
||||
afterEach(() => {
|
||||
jest.restoreAllMocks();
|
||||
});
|
||||
|
||||
const getComponent = (props = {}) => render(<CreateRoomDialog onFinished={jest.fn()} {...props} />);
|
||||
|
||||
it("should default to private room", async () => {
|
||||
|
||||
121
test/unit-tests/components/views/spaces/SpaceCreateMenu-test.tsx
Normal file
121
test/unit-tests/components/views/spaces/SpaceCreateMenu-test.tsx
Normal file
@@ -0,0 +1,121 @@
|
||||
/*
|
||||
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 OR LicenseRef-Element-Commercial
|
||||
Please see LICENSE files in the repository root for full details.
|
||||
*/
|
||||
|
||||
import React from "react";
|
||||
import { render, cleanup } from "jest-matrix-react";
|
||||
import { type MatrixClient } from "matrix-js-sdk/src/matrix";
|
||||
import userEvent from "@testing-library/user-event";
|
||||
import { MatrixError } from "matrix-js-sdk/src/matrix";
|
||||
import { type MockedObject } from "jest-mock";
|
||||
|
||||
import SpaceCreateMenu from "../../../../../src/components/views/spaces/SpaceCreateMenu";
|
||||
import {
|
||||
getMockClientWithEventEmitter,
|
||||
mockClientMethodsRooms,
|
||||
mockClientMethodsServer,
|
||||
mockClientMethodsUser,
|
||||
withClientContextRenderOptions,
|
||||
} from "../../../../test-utils";
|
||||
import { UIFeature } from "../../../../../src/settings/UIFeature";
|
||||
import SettingsStore from "../../../../../src/settings/SettingsStore";
|
||||
|
||||
describe("<SpaceCreateMenu />", () => {
|
||||
let client: MockedObject<MatrixClient>;
|
||||
|
||||
beforeEach(() => {
|
||||
client = getMockClientWithEventEmitter({
|
||||
...mockClientMethodsUser(),
|
||||
...mockClientMethodsServer(),
|
||||
...mockClientMethodsRooms(),
|
||||
createRoom: jest.fn(),
|
||||
getRoomIdForAlias: jest.fn().mockImplementation(async () => {
|
||||
throw new MatrixError({ errcode: "M_NOT_FOUND", error: "Test says no alias found" }, 404);
|
||||
}),
|
||||
});
|
||||
});
|
||||
|
||||
afterEach(() => {
|
||||
cleanup();
|
||||
jest.restoreAllMocks();
|
||||
});
|
||||
|
||||
it("should render", async () => {
|
||||
const { asFragment } = render(
|
||||
<SpaceCreateMenu onFinished={jest.fn()} />,
|
||||
withClientContextRenderOptions(client),
|
||||
);
|
||||
expect(asFragment()).toMatchSnapshot();
|
||||
});
|
||||
|
||||
it("should be able to create a public space", async () => {
|
||||
const onFinished = jest.fn();
|
||||
client.createRoom.mockResolvedValue({ room_id: "!room:id" });
|
||||
const { getByText, getByLabelText } = render(
|
||||
<SpaceCreateMenu onFinished={onFinished} />,
|
||||
withClientContextRenderOptions(client),
|
||||
);
|
||||
await userEvent.click(getByText("Public"));
|
||||
await userEvent.type(getByLabelText("Name"), "My Name");
|
||||
await userEvent.type(getByLabelText("Address"), "foobar");
|
||||
await userEvent.type(getByLabelText("Description"), "A description");
|
||||
await userEvent.click(getByText("Create"));
|
||||
expect(onFinished).toHaveBeenCalledTimes(1);
|
||||
expect(client.createRoom).toHaveBeenCalledWith({
|
||||
creation_content: { type: "m.space" },
|
||||
initial_state: [
|
||||
{ content: { guest_access: "can_join" }, state_key: "", type: "m.room.guest_access" },
|
||||
{ content: { history_visibility: "world_readable" }, type: "m.room.history_visibility" },
|
||||
],
|
||||
name: "My Name",
|
||||
power_level_content_override: {
|
||||
events_default: 100,
|
||||
invite: 0,
|
||||
},
|
||||
preset: "public_chat",
|
||||
room_alias_name: "my-namefoobar",
|
||||
topic: "A description",
|
||||
visibility: "private",
|
||||
});
|
||||
});
|
||||
|
||||
it("should be prompted to automatically create a private space when configured", async () => {
|
||||
const realGetValue = SettingsStore.getValue;
|
||||
jest.spyOn(SettingsStore, "getValue").mockImplementation((name, roomId) => {
|
||||
if (name === UIFeature.AllowCreatingPublicSpaces) {
|
||||
return false;
|
||||
}
|
||||
return realGetValue(name, roomId);
|
||||
});
|
||||
const onFinished = jest.fn();
|
||||
client.createRoom.mockResolvedValue({ room_id: "!room:id" });
|
||||
const { getByText, getByLabelText } = render(
|
||||
<SpaceCreateMenu onFinished={onFinished} />,
|
||||
withClientContextRenderOptions(client),
|
||||
);
|
||||
await userEvent.type(getByLabelText("Name"), "My Name");
|
||||
await userEvent.type(getByLabelText("Description"), "A description");
|
||||
await userEvent.click(getByText("Create"));
|
||||
expect(onFinished).toHaveBeenCalledTimes(1);
|
||||
expect(client.createRoom).toHaveBeenCalledWith({
|
||||
creation_content: { type: "m.space" },
|
||||
initial_state: [
|
||||
{ content: { guest_access: "can_join" }, state_key: "", type: "m.room.guest_access" },
|
||||
{ content: { history_visibility: "invited" }, type: "m.room.history_visibility" },
|
||||
],
|
||||
name: "My Name",
|
||||
power_level_content_override: {
|
||||
events_default: 100,
|
||||
invite: 50,
|
||||
},
|
||||
room_alias_name: undefined,
|
||||
preset: "private_chat",
|
||||
topic: "A description",
|
||||
visibility: "private",
|
||||
});
|
||||
});
|
||||
});
|
||||
@@ -0,0 +1,3 @@
|
||||
// Jest Snapshot v1, https://goo.gl/fbAQLP
|
||||
|
||||
exports[`<SpaceCreateMenu /> should render 1`] = `<DocumentFragment />`;
|
||||
Reference in New Issue
Block a user