Prepare for repo merge
Signed-off-by: Michael Telatynski <7t3chguy@gmail.com>
This commit is contained in:
parent
0f670b8dc0
commit
b084ff2313
807 changed files with 0 additions and 0 deletions
156
test/unit-tests/utils/local-room-test.ts
Normal file
156
test/unit-tests/utils/local-room-test.ts
Normal file
|
@ -0,0 +1,156 @@
|
|||
/*
|
||||
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 { mocked } from "jest-mock";
|
||||
import { MatrixClient, Room } from "matrix-js-sdk/src/matrix";
|
||||
import { KnownMembership } from "matrix-js-sdk/src/types";
|
||||
|
||||
import { LocalRoom, LocalRoomState, LOCAL_ROOM_ID_PREFIX } from "../../src/models/LocalRoom";
|
||||
import * as localRoomModule from "../../src/utils/local-room";
|
||||
import defaultDispatcher from "../../src/dispatcher/dispatcher";
|
||||
import { createTestClient } from "../test-utils";
|
||||
import { isRoomReady } from "../../src/utils/localRoom/isRoomReady";
|
||||
|
||||
jest.mock("../../src/utils/localRoom/isRoomReady", () => ({
|
||||
isRoomReady: jest.fn(),
|
||||
}));
|
||||
|
||||
describe("local-room", () => {
|
||||
const userId1 = "@user1:example.com";
|
||||
let room1: Room;
|
||||
let localRoom: LocalRoom;
|
||||
let client: MatrixClient;
|
||||
|
||||
beforeEach(() => {
|
||||
client = createTestClient();
|
||||
room1 = new Room("!room1:example.com", client, userId1);
|
||||
room1.getMyMembership = () => KnownMembership.Join;
|
||||
localRoom = new LocalRoom(LOCAL_ROOM_ID_PREFIX + "test", client, "@test:example.com");
|
||||
mocked(client.getRoom).mockImplementation((roomId: string) => {
|
||||
if (roomId === localRoom.roomId) {
|
||||
return localRoom;
|
||||
}
|
||||
return null;
|
||||
});
|
||||
});
|
||||
|
||||
describe("doMaybeLocalRoomAction", () => {
|
||||
let callback: jest.Mock;
|
||||
|
||||
beforeEach(() => {
|
||||
callback = jest.fn();
|
||||
callback.mockReturnValue(Promise.resolve());
|
||||
localRoom.actualRoomId = "@new:example.com";
|
||||
});
|
||||
|
||||
it("should invoke the callback for a non-local room", () => {
|
||||
localRoomModule.doMaybeLocalRoomAction("!room:example.com", callback, client);
|
||||
expect(callback).toHaveBeenCalled();
|
||||
});
|
||||
|
||||
it("should invoke the callback with the new room ID for a created room", () => {
|
||||
localRoom.state = LocalRoomState.CREATED;
|
||||
localRoomModule.doMaybeLocalRoomAction(localRoom.roomId, callback, client);
|
||||
expect(callback).toHaveBeenCalledWith(localRoom.actualRoomId);
|
||||
});
|
||||
|
||||
describe("for a local room", () => {
|
||||
let prom: Promise<unknown>;
|
||||
|
||||
beforeEach(() => {
|
||||
jest.spyOn(defaultDispatcher, "dispatch");
|
||||
prom = localRoomModule.doMaybeLocalRoomAction(localRoom.roomId, callback, client);
|
||||
});
|
||||
|
||||
it("dispatch a local_room_event", () => {
|
||||
expect(defaultDispatcher.dispatch).toHaveBeenCalledWith({
|
||||
action: "local_room_event",
|
||||
roomId: localRoom.roomId,
|
||||
});
|
||||
});
|
||||
|
||||
it("should resolve the promise after invoking the callback", async () => {
|
||||
localRoom.afterCreateCallbacks.forEach((callback) => {
|
||||
callback(localRoom.actualRoomId);
|
||||
});
|
||||
await prom;
|
||||
});
|
||||
});
|
||||
});
|
||||
|
||||
describe("waitForRoomReadyAndApplyAfterCreateCallbacks", () => {
|
||||
let localRoomCallbackRoomId: string;
|
||||
|
||||
beforeEach(() => {
|
||||
localRoom.actualRoomId = room1.roomId;
|
||||
localRoom.afterCreateCallbacks.push((roomId: string) => {
|
||||
localRoomCallbackRoomId = roomId;
|
||||
return Promise.resolve();
|
||||
});
|
||||
jest.useFakeTimers();
|
||||
});
|
||||
|
||||
describe("for an immediate ready room", () => {
|
||||
beforeEach(() => {
|
||||
mocked(isRoomReady).mockReturnValue(true);
|
||||
});
|
||||
|
||||
it("should invoke the callbacks, set the room state to created and return the actual room id", async () => {
|
||||
const result = await localRoomModule.waitForRoomReadyAndApplyAfterCreateCallbacks(
|
||||
client,
|
||||
localRoom,
|
||||
room1.roomId,
|
||||
);
|
||||
expect(localRoom.state).toBe(LocalRoomState.CREATED);
|
||||
expect(localRoomCallbackRoomId).toBe(room1.roomId);
|
||||
expect(result).toBe(room1.roomId);
|
||||
});
|
||||
});
|
||||
|
||||
describe("for a room running into the create timeout", () => {
|
||||
beforeEach(() => {
|
||||
mocked(isRoomReady).mockReturnValue(false);
|
||||
});
|
||||
|
||||
it("should invoke the callbacks, set the room state to created and return the actual room id", async () => {
|
||||
const prom = localRoomModule.waitForRoomReadyAndApplyAfterCreateCallbacks(
|
||||
client,
|
||||
localRoom,
|
||||
room1.roomId,
|
||||
);
|
||||
jest.advanceTimersByTime(5000);
|
||||
const roomId = await prom;
|
||||
expect(localRoom.state).toBe(LocalRoomState.CREATED);
|
||||
expect(localRoomCallbackRoomId).toBe(room1.roomId);
|
||||
expect(roomId).toBe(room1.roomId);
|
||||
expect(jest.getTimerCount()).toBe(0);
|
||||
});
|
||||
});
|
||||
|
||||
describe("for a room that is ready after a while", () => {
|
||||
beforeEach(() => {
|
||||
mocked(isRoomReady).mockReturnValue(false);
|
||||
});
|
||||
|
||||
it("should invoke the callbacks, set the room state to created and return the actual room id", async () => {
|
||||
const prom = localRoomModule.waitForRoomReadyAndApplyAfterCreateCallbacks(
|
||||
client,
|
||||
localRoom,
|
||||
room1.roomId,
|
||||
);
|
||||
mocked(isRoomReady).mockReturnValue(true);
|
||||
jest.advanceTimersByTime(500);
|
||||
const roomId = await prom;
|
||||
expect(localRoom.state).toBe(LocalRoomState.CREATED);
|
||||
expect(localRoomCallbackRoomId).toBe(room1.roomId);
|
||||
expect(roomId).toBe(room1.roomId);
|
||||
expect(jest.getTimerCount()).toBe(0);
|
||||
});
|
||||
});
|
||||
});
|
||||
});
|
Loading…
Add table
Add a link
Reference in a new issue