2023-03-08 15:18:03 +01:00
|
|
|
/*
|
2024-09-09 15:57:16 +02:00
|
|
|
Copyright 2024 New Vector Ltd.
|
2023-03-08 15:18:03 +01:00
|
|
|
Copyright 2023 The Matrix.org Foundation C.I.C.
|
|
|
|
|
2025-01-06 12:18:54 +01:00
|
|
|
SPDX-License-Identifier: AGPL-3.0-only OR GPL-3.0-only OR LicenseRef-Element-Commercial
|
2024-09-09 15:57:16 +02:00
|
|
|
Please see LICENSE files in the repository root for full details.
|
2023-03-08 15:18:03 +01:00
|
|
|
*/
|
|
|
|
|
|
|
|
import { mocked } from "jest-mock";
|
2023-08-10 10:01:14 +02:00
|
|
|
import { ClientEvent, MatrixClient, Room, SyncState } from "matrix-js-sdk/src/matrix";
|
2023-03-08 15:18:03 +01:00
|
|
|
|
2024-10-15 15:57:26 +02:00
|
|
|
import { createTestClient, setupAsyncStoreWithClient } from "../../test-utils";
|
2023-03-08 15:18:03 +01:00
|
|
|
import {
|
|
|
|
RoomNotificationStateStore,
|
|
|
|
UPDATE_STATUS_INDICATOR,
|
2024-10-15 15:57:26 +02:00
|
|
|
} from "../../../src/stores/notifications/RoomNotificationStateStore";
|
|
|
|
import SettingsStore from "../../../src/settings/SettingsStore";
|
|
|
|
import { MatrixDispatcher } from "../../../src/dispatcher/dispatcher";
|
2023-03-08 15:18:03 +01:00
|
|
|
|
|
|
|
describe("RoomNotificationStateStore", function () {
|
|
|
|
let store: RoomNotificationStateStore;
|
|
|
|
let client: MatrixClient;
|
|
|
|
let dis: MatrixDispatcher;
|
|
|
|
|
|
|
|
beforeEach(() => {
|
|
|
|
client = createTestClient();
|
|
|
|
dis = new MatrixDispatcher();
|
|
|
|
jest.resetAllMocks();
|
|
|
|
store = RoomNotificationStateStore.testInstance(dis);
|
|
|
|
store.emit = jest.fn();
|
|
|
|
setupAsyncStoreWithClient(store, client);
|
|
|
|
});
|
|
|
|
|
|
|
|
it("Emits no event when a room has no unreads", async () => {
|
|
|
|
// Given a room with 0 unread messages
|
|
|
|
const room = fakeRoom(0);
|
|
|
|
|
|
|
|
// When we sync and the room is visible
|
|
|
|
mocked(client.getVisibleRooms).mockReturnValue([room]);
|
|
|
|
client.emit(ClientEvent.Sync, SyncState.Syncing, SyncState.Syncing);
|
|
|
|
|
|
|
|
// Then we emit an event from the store
|
|
|
|
expect(store.emit).not.toHaveBeenCalled();
|
|
|
|
});
|
|
|
|
|
|
|
|
it("Emits an event when a room has unreads", async () => {
|
|
|
|
// Given a room with 2 unread messages
|
|
|
|
const room = fakeRoom(2);
|
|
|
|
|
|
|
|
// When we sync and the room is visible
|
|
|
|
mocked(client.getVisibleRooms).mockReturnValue([room]);
|
|
|
|
client.emit(ClientEvent.Sync, SyncState.Syncing, SyncState.Syncing);
|
|
|
|
|
|
|
|
// Then we emit an event from the store
|
|
|
|
expect(store.emit).toHaveBeenCalledWith(UPDATE_STATUS_INDICATOR, expect.anything(), "SYNCING");
|
|
|
|
});
|
|
|
|
|
|
|
|
it("Emits an event when a feature flag changes notification state", async () => {
|
|
|
|
// Given we have synced already
|
|
|
|
let room = fakeRoom(0);
|
|
|
|
mocked(store.emit).mockReset();
|
|
|
|
mocked(client.getVisibleRooms).mockReturnValue([room]);
|
|
|
|
client.emit(ClientEvent.Sync, SyncState.Syncing, SyncState.Syncing);
|
|
|
|
expect(store.emit).not.toHaveBeenCalled();
|
|
|
|
|
|
|
|
// When we update the feature flag and it makes us have a notification
|
|
|
|
room = fakeRoom(2);
|
|
|
|
mocked(client.getVisibleRooms).mockReturnValue([room]);
|
|
|
|
jest.spyOn(SettingsStore, "getValue").mockReturnValue(true);
|
|
|
|
store.emitUpdateIfStateChanged(SyncState.Syncing, false);
|
|
|
|
|
|
|
|
// Then we get notified
|
|
|
|
expect(store.emit).toHaveBeenCalledWith(UPDATE_STATUS_INDICATOR, expect.anything(), "SYNCING");
|
|
|
|
});
|
|
|
|
|
|
|
|
describe("If the feature_dynamic_room_predecessors is not enabled", () => {
|
|
|
|
beforeEach(() => {
|
|
|
|
// Turn off feature_dynamic_room_predecessors setting
|
|
|
|
jest.spyOn(SettingsStore, "getValue").mockReturnValue(false);
|
|
|
|
});
|
|
|
|
|
|
|
|
it("Passes the dynamic predecessor flag to getVisibleRooms", async () => {
|
|
|
|
// When we sync
|
|
|
|
mocked(client.getVisibleRooms).mockReturnValue([]);
|
|
|
|
client.emit(ClientEvent.Sync, SyncState.Syncing, SyncState.Syncing);
|
|
|
|
|
|
|
|
// Then we check visible rooms, using the dynamic predecessor flag
|
|
|
|
expect(client.getVisibleRooms).toHaveBeenCalledWith(false);
|
|
|
|
expect(client.getVisibleRooms).not.toHaveBeenCalledWith(true);
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
describe("If the feature_dynamic_room_predecessors is enabled", () => {
|
|
|
|
beforeEach(() => {
|
|
|
|
// Turn on feature_dynamic_room_predecessors setting
|
|
|
|
jest.spyOn(SettingsStore, "getValue").mockImplementation(
|
|
|
|
(settingName) => settingName === "feature_dynamic_room_predecessors",
|
|
|
|
);
|
|
|
|
});
|
|
|
|
|
|
|
|
it("Passes the dynamic predecessor flag to getVisibleRooms", async () => {
|
|
|
|
// When we sync
|
|
|
|
mocked(client.getVisibleRooms).mockReturnValue([]);
|
|
|
|
client.emit(ClientEvent.Sync, SyncState.Syncing, SyncState.Syncing);
|
|
|
|
|
|
|
|
// Then we check visible rooms, using the dynamic predecessor flag
|
|
|
|
expect(client.getVisibleRooms).toHaveBeenCalledWith(true);
|
|
|
|
expect(client.getVisibleRooms).not.toHaveBeenCalledWith(false);
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
let roomIdx = 0;
|
|
|
|
|
|
|
|
function fakeRoom(numUnreads: number): Room {
|
|
|
|
roomIdx++;
|
|
|
|
const ret = new Room(`room${roomIdx}`, client, "@user:example.com");
|
|
|
|
ret.getPendingEvents = jest.fn().mockReturnValue([]);
|
|
|
|
ret.isSpaceRoom = jest.fn().mockReturnValue(false);
|
|
|
|
ret.getUnreadNotificationCount = jest.fn().mockReturnValue(numUnreads);
|
2024-01-29 18:52:48 +01:00
|
|
|
ret.getRoomUnreadNotificationCount = jest.fn().mockReturnValue(numUnreads);
|
2023-03-08 15:18:03 +01:00
|
|
|
return ret;
|
|
|
|
}
|
|
|
|
});
|