2023-01-18 22:49:34 +08:00
|
|
|
/*
|
2024-09-09 21:57:16 +08:00
|
|
|
Copyright 2024 New Vector Ltd.
|
2023-01-18 22:49:34 +08:00
|
|
|
Copyright 2023 The Matrix.org Foundation C.I.C.
|
|
|
|
|
2024-09-09 21:57:16 +08:00
|
|
|
SPDX-License-Identifier: AGPL-3.0-only OR GPL-3.0-only
|
|
|
|
Please see LICENSE files in the repository root for full details.
|
2023-01-18 22:49:34 +08:00
|
|
|
*/
|
|
|
|
|
|
|
|
import { mocked } from "jest-mock";
|
2023-08-10 16:01:14 +08:00
|
|
|
import {
|
|
|
|
ClientEvent,
|
|
|
|
EventType,
|
|
|
|
MatrixClient,
|
|
|
|
MatrixEvent,
|
|
|
|
MatrixEventEvent,
|
|
|
|
SyncState,
|
|
|
|
} from "matrix-js-sdk/src/matrix";
|
2023-01-18 22:49:34 +08:00
|
|
|
|
2024-10-15 21:57:26 +08:00
|
|
|
import SettingsStore from "../../../src/settings/SettingsStore";
|
|
|
|
import AutoRageshakeStore from "../../../src/stores/AutoRageshakeStore";
|
|
|
|
import { mkEvent, stubClient } from "../../test-utils";
|
2023-01-18 22:49:34 +08:00
|
|
|
|
2024-10-15 21:57:26 +08:00
|
|
|
jest.mock("../../../src/rageshake/submit-rageshake");
|
|
|
|
jest.mock("../../../src/stores/WidgetStore");
|
|
|
|
jest.mock("../../../src/stores/widgets/WidgetLayoutStore");
|
2023-01-18 22:49:34 +08:00
|
|
|
|
2024-03-05 00:24:08 +08:00
|
|
|
const TEST_SENDER = "@sender@example.com";
|
|
|
|
|
2023-01-18 22:49:34 +08:00
|
|
|
describe("AutoRageshakeStore", () => {
|
|
|
|
const roomId = "!room:example.com";
|
|
|
|
let client: MatrixClient;
|
|
|
|
let utdEvent: MatrixEvent;
|
|
|
|
let autoRageshakeStore: AutoRageshakeStore;
|
|
|
|
|
|
|
|
beforeAll(() => {
|
|
|
|
jest.useFakeTimers();
|
|
|
|
});
|
|
|
|
|
|
|
|
afterAll(() => {
|
|
|
|
jest.useRealTimers();
|
|
|
|
});
|
|
|
|
|
|
|
|
beforeEach(() => {
|
|
|
|
jest.spyOn(SettingsStore, "getValue").mockReturnValue(true);
|
|
|
|
|
|
|
|
client = stubClient();
|
|
|
|
|
|
|
|
// @ts-ignore bypass private ctor for tests
|
|
|
|
autoRageshakeStore = new AutoRageshakeStore();
|
2024-10-10 22:08:43 +08:00
|
|
|
autoRageshakeStore.start();
|
2023-01-18 22:49:34 +08:00
|
|
|
|
|
|
|
utdEvent = mkEvent({
|
|
|
|
event: true,
|
|
|
|
content: {},
|
|
|
|
room: roomId,
|
2024-03-05 00:24:08 +08:00
|
|
|
user: TEST_SENDER,
|
2023-01-18 22:49:34 +08:00
|
|
|
type: EventType.RoomMessage,
|
|
|
|
});
|
|
|
|
jest.spyOn(utdEvent, "isDecryptionFailure").mockReturnValue(true);
|
|
|
|
});
|
|
|
|
|
|
|
|
afterEach(() => {
|
|
|
|
jest.restoreAllMocks();
|
|
|
|
});
|
|
|
|
|
|
|
|
describe("when the initial sync completed", () => {
|
|
|
|
beforeEach(() => {
|
|
|
|
client.emit(ClientEvent.Sync, SyncState.Syncing, SyncState.Stopped, { nextSyncToken: "abc123" });
|
|
|
|
});
|
|
|
|
|
|
|
|
describe("and an undecryptable event occurs", () => {
|
|
|
|
beforeEach(() => {
|
|
|
|
client.emit(MatrixEventEvent.Decrypted, utdEvent);
|
|
|
|
// simulate event grace period
|
|
|
|
jest.advanceTimersByTime(5500);
|
|
|
|
});
|
|
|
|
|
2024-03-05 00:24:08 +08:00
|
|
|
it("should send a to-device message", () => {
|
|
|
|
expect(mocked(client).sendToDevice.mock.calls).toEqual([
|
2023-01-18 22:49:34 +08:00
|
|
|
[
|
|
|
|
"im.vector.auto_rs_request",
|
2024-03-05 00:24:08 +08:00
|
|
|
new Map([
|
|
|
|
[
|
|
|
|
TEST_SENDER,
|
|
|
|
new Map([
|
|
|
|
[
|
|
|
|
undefined,
|
|
|
|
{
|
|
|
|
"device_id": undefined,
|
|
|
|
"event_id": utdEvent.getId(),
|
|
|
|
"org.matrix.msgid": expect.any(String),
|
|
|
|
"recipient_rageshake": undefined,
|
|
|
|
"room_id": "!room:example.com",
|
|
|
|
"sender_key": undefined,
|
|
|
|
"session_id": undefined,
|
|
|
|
"user_id": TEST_SENDER,
|
|
|
|
},
|
|
|
|
],
|
|
|
|
]),
|
|
|
|
],
|
|
|
|
]),
|
|
|
|
],
|
|
|
|
]);
|
2023-01-18 22:49:34 +08:00
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|