2022-06-13 08:03:16 +02:00
|
|
|
/*
|
2024-09-09 15:57:16 +02:00
|
|
|
Copyright 2024 New Vector Ltd.
|
2022-06-13 08:03:16 +02:00
|
|
|
Copyright 2022 The Matrix.org Foundation C.I.C.
|
|
|
|
|
2024-09-09 15:57:16 +02:00
|
|
|
SPDX-License-Identifier: AGPL-3.0-only OR GPL-3.0-only
|
|
|
|
Please see LICENSE files in the repository root for full details.
|
2022-06-13 08:03:16 +02:00
|
|
|
*/
|
|
|
|
|
2024-08-06 12:23:26 +02:00
|
|
|
import { ClientEvent, MatrixClient, Room, SyncState } from "matrix-js-sdk/src/matrix";
|
2024-08-06 11:54:11 +02:00
|
|
|
|
2022-06-13 08:03:16 +02:00
|
|
|
import BasePlatform from "../../src/BasePlatform";
|
2024-06-14 13:00:30 +02:00
|
|
|
import SdkConfig from "../../src/SdkConfig";
|
2022-06-13 08:03:16 +02:00
|
|
|
import { SettingLevel } from "../../src/settings/SettingLevel";
|
|
|
|
import SettingsStore from "../../src/settings/SettingsStore";
|
2024-08-06 11:54:11 +02:00
|
|
|
import { mkStubRoom, mockPlatformPeg, stubClient } from "../test-utils";
|
2022-06-13 08:03:16 +02:00
|
|
|
|
|
|
|
const TEST_DATA = [
|
|
|
|
{
|
|
|
|
name: "Electron.showTrayIcon",
|
|
|
|
level: SettingLevel.PLATFORM,
|
|
|
|
value: true,
|
|
|
|
},
|
|
|
|
];
|
|
|
|
|
2024-06-14 13:00:30 +02:00
|
|
|
/**
|
|
|
|
* An existing setting that has {@link IBaseSetting#supportedLevelsAreOrdered} set to true.
|
|
|
|
*/
|
2024-07-09 11:45:48 +02:00
|
|
|
const SETTING_NAME_WITH_CONFIG_OVERRIDE = "feature_msc3531_hide_messages_pending_moderation";
|
2024-06-14 13:00:30 +02:00
|
|
|
|
2022-06-13 08:03:16 +02:00
|
|
|
describe("SettingsStore", () => {
|
2023-02-13 12:39:16 +01:00
|
|
|
let platformSettings: Record<string, any>;
|
2022-06-13 08:03:16 +02:00
|
|
|
|
|
|
|
beforeAll(() => {
|
|
|
|
jest.clearAllMocks();
|
|
|
|
platformSettings = {};
|
|
|
|
mockPlatformPeg({
|
|
|
|
isLevelSupported: jest.fn().mockReturnValue(true),
|
|
|
|
supportsSetting: jest.fn().mockReturnValue(true),
|
|
|
|
setSettingValue: jest.fn().mockImplementation((settingName: string, value: any) => {
|
|
|
|
platformSettings[settingName] = value;
|
|
|
|
}),
|
|
|
|
getSettingValue: jest.fn().mockImplementation((settingName: string) => {
|
|
|
|
return platformSettings[settingName];
|
|
|
|
}),
|
2024-06-14 13:00:30 +02:00
|
|
|
reload: jest.fn(),
|
2022-06-13 08:03:16 +02:00
|
|
|
} as unknown as BasePlatform);
|
|
|
|
|
2022-12-12 12:24:14 +01:00
|
|
|
TEST_DATA.forEach((d) => {
|
2022-06-13 08:03:16 +02:00
|
|
|
SettingsStore.setValue(d.name, null, d.level, d.value);
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
2024-06-14 13:00:30 +02:00
|
|
|
beforeEach(() => {
|
|
|
|
SdkConfig.reset();
|
|
|
|
});
|
|
|
|
|
2022-06-13 08:03:16 +02:00
|
|
|
describe("getValueAt", () => {
|
2022-12-12 12:24:14 +01:00
|
|
|
TEST_DATA.forEach((d) => {
|
2022-06-13 08:03:16 +02:00
|
|
|
it(`should return the value "${d.level}"."${d.name}"`, () => {
|
|
|
|
expect(SettingsStore.getValueAt(d.level, d.name)).toBe(d.value);
|
|
|
|
// regression test #22545
|
|
|
|
expect(SettingsStore.getValueAt(d.level, d.name)).toBe(d.value);
|
|
|
|
});
|
|
|
|
});
|
2024-06-14 13:00:30 +02:00
|
|
|
|
|
|
|
it(`supportedLevelsAreOrdered correctly overrides setting`, async () => {
|
|
|
|
SdkConfig.put({
|
|
|
|
features: {
|
|
|
|
[SETTING_NAME_WITH_CONFIG_OVERRIDE]: false,
|
|
|
|
},
|
|
|
|
});
|
|
|
|
await SettingsStore.setValue(SETTING_NAME_WITH_CONFIG_OVERRIDE, null, SettingLevel.DEVICE, true);
|
|
|
|
expect(SettingsStore.getValue(SETTING_NAME_WITH_CONFIG_OVERRIDE)).toBe(false);
|
|
|
|
});
|
|
|
|
|
|
|
|
it(`supportedLevelsAreOrdered doesn't incorrectly override setting`, async () => {
|
|
|
|
await SettingsStore.setValue(SETTING_NAME_WITH_CONFIG_OVERRIDE, null, SettingLevel.DEVICE, true);
|
|
|
|
expect(SettingsStore.getValueAt(SettingLevel.DEVICE, SETTING_NAME_WITH_CONFIG_OVERRIDE)).toBe(true);
|
|
|
|
});
|
2022-06-13 08:03:16 +02:00
|
|
|
});
|
2024-08-06 11:54:11 +02:00
|
|
|
|
|
|
|
describe("runMigrations", () => {
|
|
|
|
let client: MatrixClient;
|
|
|
|
let room: Room;
|
|
|
|
let localStorageSetItemSpy: jest.SpyInstance;
|
|
|
|
let localStorageSetPromise: Promise<void>;
|
|
|
|
|
|
|
|
beforeEach(() => {
|
|
|
|
client = stubClient();
|
|
|
|
room = mkStubRoom("!room:example.org", "Room", client);
|
|
|
|
room.getAccountData = jest.fn().mockReturnValue({
|
|
|
|
getContent: jest.fn().mockReturnValue({
|
|
|
|
urlPreviewsEnabled_e2ee: true,
|
|
|
|
}),
|
|
|
|
});
|
|
|
|
client.getRooms = jest.fn().mockReturnValue([room]);
|
|
|
|
client.getRoom = jest.fn().mockReturnValue(room);
|
|
|
|
|
|
|
|
localStorageSetPromise = new Promise((resolve) => {
|
|
|
|
localStorageSetItemSpy = jest
|
|
|
|
.spyOn(localStorage.__proto__, "setItem")
|
|
|
|
.mockImplementation(() => resolve());
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
afterEach(() => {
|
|
|
|
jest.restoreAllMocks();
|
|
|
|
});
|
|
|
|
|
|
|
|
it("migrates URL previews setting for e2ee rooms", async () => {
|
|
|
|
SettingsStore.runMigrations(false);
|
|
|
|
client.emit(ClientEvent.Sync, SyncState.Prepared, null);
|
|
|
|
|
|
|
|
expect(room.getAccountData).toHaveBeenCalled();
|
|
|
|
|
|
|
|
await localStorageSetPromise;
|
|
|
|
|
|
|
|
expect(localStorageSetItemSpy!).toHaveBeenCalledWith(
|
|
|
|
`mx_setting_urlPreviewsEnabled_e2ee_${room.roomId}`,
|
|
|
|
JSON.stringify({ value: true }),
|
|
|
|
);
|
|
|
|
});
|
|
|
|
|
|
|
|
it("does not migrate e2ee URL previews on a fresh login", async () => {
|
|
|
|
SettingsStore.runMigrations(true);
|
|
|
|
client.emit(ClientEvent.Sync, SyncState.Prepared, null);
|
|
|
|
|
|
|
|
expect(room.getAccountData).not.toHaveBeenCalled();
|
|
|
|
});
|
|
|
|
|
|
|
|
it("does not migrate if the device is flagged as migrated", async () => {
|
|
|
|
jest.spyOn(localStorage.__proto__, "getItem").mockImplementation((key: unknown): string | undefined => {
|
|
|
|
if (key === "url_previews_e2ee_migration_done") return JSON.stringify({ value: true });
|
|
|
|
return undefined;
|
|
|
|
});
|
|
|
|
SettingsStore.runMigrations(false);
|
|
|
|
client.emit(ClientEvent.Sync, SyncState.Prepared, null);
|
|
|
|
|
|
|
|
expect(room.getAccountData).not.toHaveBeenCalled();
|
|
|
|
});
|
|
|
|
});
|
2022-06-13 08:03:16 +02:00
|
|
|
});
|