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
* remove resetCrossSigning flag, which is no longer in use * drop unnecessary check for cross-signing The only place where verifyUser is called already checks that cross-signing is set up. (The function name is also incorrect, since it checks for the cross-signing key, and not for 4S.) * avoid calling accessSecretStorage to set up cross-signing or 4S Send the user to the Encryption settings tab instead * only create secret storage when specifically asked to * deprecate using accessSecretStorage to create new 4S * also remove the obsolete snapshot * add tests * Tweak comment Co-authored-by: Richard van der Hoff <1389908+richvdh@users.noreply.github.com> --------- Co-authored-by: Richard van der Hoff <1389908+richvdh@users.noreply.github.com>
99 lines
4.2 KiB
TypeScript
99 lines
4.2 KiB
TypeScript
/*
|
|
Copyright 2024 New Vector Ltd.
|
|
Copyright 2023 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 { mocked, type MockedObject } from "jest-mock";
|
|
import { type MatrixClient } from "matrix-js-sdk/src/matrix";
|
|
import { type CryptoApi, type KeyBackupInfo } from "matrix-js-sdk/src/crypto-api";
|
|
import { fireEvent, render, type RenderResult, screen, waitFor } from "jest-matrix-react";
|
|
|
|
import { filterConsole, getMockClientWithEventEmitter, mockClientMethodsCrypto } from "../../../../test-utils";
|
|
import LogoutDialog from "../../../../../src/components/views/dialogs/LogoutDialog";
|
|
import dispatch from "../../../../../src/dispatcher/dispatcher";
|
|
import { Action } from "../../../../../src/dispatcher/actions";
|
|
import { UserTab } from "../../../../../src/components/views/dialogs/UserTab";
|
|
|
|
describe("LogoutDialog", () => {
|
|
let mockClient: MockedObject<MatrixClient>;
|
|
let mockCrypto: MockedObject<CryptoApi>;
|
|
|
|
beforeEach(() => {
|
|
mockClient = getMockClientWithEventEmitter({
|
|
...mockClientMethodsCrypto(),
|
|
});
|
|
|
|
mockCrypto = mocked(mockClient.getCrypto()!);
|
|
Object.assign(mockCrypto, {
|
|
getActiveSessionBackupVersion: jest.fn().mockResolvedValue(null),
|
|
});
|
|
});
|
|
|
|
function renderComponent(props: Partial<React.ComponentProps<typeof LogoutDialog>> = {}): RenderResult {
|
|
const onFinished = jest.fn();
|
|
return render(<LogoutDialog onFinished={onFinished} {...props} />);
|
|
}
|
|
|
|
it("shows a regular dialog when crypto is disabled", async () => {
|
|
mocked(mockClient.getCrypto).mockReturnValue(undefined);
|
|
const rendered = renderComponent();
|
|
await rendered.findByText("Are you sure you want to sign out?");
|
|
expect(rendered.container).toMatchSnapshot();
|
|
});
|
|
|
|
it("shows a regular dialog if backups and recovery are working", async () => {
|
|
mockCrypto.getActiveSessionBackupVersion.mockResolvedValue("1");
|
|
mockCrypto.isSecretStorageReady.mockResolvedValue(true);
|
|
const rendered = renderComponent();
|
|
await rendered.findByText("Are you sure you want to sign out?");
|
|
});
|
|
|
|
it("prompts user to set up recovery if backups are enabled but recovery isn't", async () => {
|
|
mockCrypto.getActiveSessionBackupVersion.mockResolvedValue("1");
|
|
mockCrypto.isSecretStorageReady.mockResolvedValue(false);
|
|
const rendered = renderComponent();
|
|
await rendered.findByText("You'll lose access to your encrypted messages");
|
|
});
|
|
|
|
it("Prompts user to go to settings if there is a backup on the server", async () => {
|
|
mockCrypto.getKeyBackupInfo.mockResolvedValue({} as KeyBackupInfo);
|
|
const rendered = renderComponent();
|
|
await rendered.findByText("Go to Settings");
|
|
expect(rendered.container).toMatchSnapshot();
|
|
|
|
jest.spyOn(dispatch, "dispatch");
|
|
fireEvent.click(await screen.findByRole("button", { name: "Go to Settings" }));
|
|
await waitFor(() =>
|
|
expect(dispatch.dispatch).toHaveBeenCalledWith({
|
|
action: Action.ViewUserSettings,
|
|
initialTabId: UserTab.Encryption,
|
|
}),
|
|
);
|
|
});
|
|
|
|
it("Prompts user to go to settings if there is no backup on the server", async () => {
|
|
mockCrypto.getKeyBackupInfo.mockResolvedValue(null);
|
|
const rendered = renderComponent();
|
|
await rendered.findByText("Go to Settings");
|
|
expect(rendered.container).toMatchSnapshot();
|
|
|
|
fireEvent.click(await screen.findByRole("button", { name: "Manually export keys" }));
|
|
await expect(screen.findByRole("heading", { name: "Export room keys" })).resolves.toBeInTheDocument();
|
|
});
|
|
|
|
describe("when there is an error fetching backups", () => {
|
|
filterConsole("Unable to fetch key backup status");
|
|
it("prompts user to go to settings", async () => {
|
|
mockCrypto.getKeyBackupInfo.mockImplementation(async () => {
|
|
throw new Error("beep");
|
|
});
|
|
const rendered = renderComponent();
|
|
await rendered.findByText("Go to Settings");
|
|
});
|
|
});
|
|
});
|