91e84f7951
* Upgrade to latest compound-web package * Use a custom render function for jest tests This way we don't need to manually wrap our components with <TooltipProvider> * Pin wrap-ansi to fix broken yarn install * Add playwright helper to find tooltip from element and use it in the failing test * Exclude floating-ui divs/spans from axe testing This is rendered outside .MatrixChat by compound and contains all the tooltips. * Wrap outermost components with TooltipProvider * Remove onChange and use onSelect for toggle * Fix jest tests and update snapshots * Use vector-im/matrix-wysiwig --------- Co-authored-by: Michael Telatynski <7t3chguy@gmail.com>
123 lines
4.5 KiB
TypeScript
123 lines
4.5 KiB
TypeScript
/*
|
|
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 { mocked } from "jest-mock";
|
|
import { MatrixClient, MatrixEvent, Room } from "matrix-js-sdk/src/matrix";
|
|
import { render, screen } from "jest-matrix-react";
|
|
|
|
import EncryptionEvent from "../../../../src/components/views/messages/EncryptionEvent";
|
|
import { createTestClient, mkMessage } from "../../../test-utils";
|
|
import { MatrixClientPeg } from "../../../../src/MatrixClientPeg";
|
|
import { LocalRoom } from "../../../../src/models/LocalRoom";
|
|
import DMRoomMap from "../../../../src/utils/DMRoomMap";
|
|
import MatrixClientContext from "../../../../src/contexts/MatrixClientContext";
|
|
|
|
const renderEncryptionEvent = (client: MatrixClient, event: MatrixEvent) => {
|
|
render(
|
|
<MatrixClientContext.Provider value={client}>
|
|
<EncryptionEvent mxEvent={event} />
|
|
</MatrixClientContext.Provider>,
|
|
);
|
|
};
|
|
|
|
const checkTexts = (title: string, subTitle: string) => {
|
|
screen.getByText(title);
|
|
screen.getByText(subTitle);
|
|
};
|
|
|
|
describe("EncryptionEvent", () => {
|
|
const roomId = "!room:example.com";
|
|
const algorithm = "m.megolm.v1.aes-sha2";
|
|
let client: MatrixClient;
|
|
let event: MatrixEvent;
|
|
|
|
beforeEach(() => {
|
|
jest.clearAllMocks();
|
|
client = createTestClient();
|
|
jest.spyOn(MatrixClientPeg, "get").mockReturnValue(client);
|
|
jest.spyOn(MatrixClientPeg, "safeGet").mockReturnValue(client);
|
|
event = mkMessage({
|
|
event: true,
|
|
room: roomId,
|
|
user: client.getUserId()!,
|
|
});
|
|
jest.spyOn(DMRoomMap, "shared").mockReturnValue({
|
|
getUserIdForRoomId: jest.fn(),
|
|
} as unknown as DMRoomMap);
|
|
});
|
|
|
|
describe("for an encrypted room", () => {
|
|
beforeEach(() => {
|
|
event.event.content!.algorithm = algorithm;
|
|
mocked(client.isRoomEncrypted).mockReturnValue(true);
|
|
const room = new Room(roomId, client, client.getUserId()!);
|
|
mocked(client.getRoom).mockReturnValue(room);
|
|
});
|
|
|
|
it("should show the expected texts", () => {
|
|
renderEncryptionEvent(client, event);
|
|
checkTexts(
|
|
"Encryption enabled",
|
|
"Messages in this room are end-to-end encrypted. " +
|
|
"When people join, you can verify them in their profile, just tap on their profile picture.",
|
|
);
|
|
});
|
|
|
|
describe("with same previous algorithm", () => {
|
|
beforeEach(() => {
|
|
jest.spyOn(event, "getPrevContent").mockReturnValue({
|
|
algorithm: algorithm,
|
|
});
|
|
});
|
|
|
|
it("should show the expected texts", () => {
|
|
renderEncryptionEvent(client, event);
|
|
checkTexts("Encryption enabled", "Some encryption parameters have been changed.");
|
|
});
|
|
});
|
|
|
|
describe("with unknown algorithm", () => {
|
|
beforeEach(() => {
|
|
event.event.content!.algorithm = "unknown";
|
|
});
|
|
|
|
it("should show the expected texts", () => {
|
|
renderEncryptionEvent(client, event);
|
|
checkTexts("Encryption enabled", "Ignored attempt to disable encryption");
|
|
});
|
|
});
|
|
});
|
|
|
|
describe("for an unencrypted room", () => {
|
|
beforeEach(() => {
|
|
mocked(client.isRoomEncrypted).mockReturnValue(false);
|
|
renderEncryptionEvent(client, event);
|
|
});
|
|
|
|
it("should show the expected texts", () => {
|
|
expect(client.isRoomEncrypted).toHaveBeenCalledWith(roomId);
|
|
checkTexts("Encryption not enabled", "The encryption used by this room isn't supported.");
|
|
});
|
|
});
|
|
|
|
describe("for an encrypted local room", () => {
|
|
beforeEach(() => {
|
|
event.event.content!.algorithm = algorithm;
|
|
mocked(client.isRoomEncrypted).mockReturnValue(true);
|
|
const localRoom = new LocalRoom(roomId, client, client.getUserId()!);
|
|
mocked(client.getRoom).mockReturnValue(localRoom);
|
|
renderEncryptionEvent(client, event);
|
|
});
|
|
|
|
it("should show the expected texts", () => {
|
|
expect(client.isRoomEncrypted).toHaveBeenCalledWith(roomId);
|
|
checkTexts("Encryption enabled", "Messages in this chat will be end-to-end encrypted.");
|
|
});
|
|
});
|
|
});
|