Skip to content
This repository has been archived by the owner on Sep 11, 2024. It is now read-only.

Apply strictNullChecks to src/utils/local-room.ts #10915

Merged
merged 4 commits into from
Jun 1, 2023
Merged
Show file tree
Hide file tree
Changes from 2 commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
2 changes: 1 addition & 1 deletion src/utils/direct-messages.ts
Original file line number Diff line number Diff line change
Expand Up @@ -89,7 +89,7 @@ export async function createRoomFromLocalRoom(client: MatrixClient, localRoom: L
if (!roomId) throw new Error(`startDm for local room ${localRoom.roomId} didn't return a room Id`);

localRoom.actualRoomId = roomId;
return waitForRoomReadyAndApplyAfterCreateCallbacks(client, localRoom);
return waitForRoomReadyAndApplyAfterCreateCallbacks(client, localRoom, roomId);
},
() => {
logger.warn(`Error creating DM for local room ${localRoom.roomId}`);
Expand Down
21 changes: 16 additions & 5 deletions src/utils/local-room.ts
Original file line number Diff line number Diff line change
Expand Up @@ -22,6 +22,15 @@ import { LocalRoom, LocalRoomState } from "../models/LocalRoom";
import { isLocalRoom } from "./localRoom/isLocalRoom";
import { isRoomReady } from "./localRoom/isRoomReady";

const isActualRoomIdDefined = (actualRoomId: string | undefined): actualRoomId is string => {
if (actualRoomId === undefined) {
// should not happen
throw new Error("Local room in CREATED state without actual room Id occurred");
}

return true;
};

/**
* Does a room action:
* For non-local rooms it calls fn directly.
Expand All @@ -43,7 +52,7 @@ export async function doMaybeLocalRoomAction<T>(
if (isLocalRoom(roomId)) {
const room = client.getRoom(roomId) as LocalRoom;

if (room.isCreated) {
if (room.isCreated && isActualRoomIdDefined(room.actualRoomId)) {
return fn(room.actualRoomId);
}

Expand All @@ -69,17 +78,19 @@ export async function doMaybeLocalRoomAction<T>(
* @async
* @param {MatrixClient} client
* @param {LocalRoom} localRoom
* @param actualRoomId Id of the actual room
* @returns {Promise<string>} Resolved to the actual room id
*/
export async function waitForRoomReadyAndApplyAfterCreateCallbacks(
client: MatrixClient,
localRoom: LocalRoom,
actualRoomId: string,
): Promise<string> {
if (isRoomReady(client, localRoom)) {
return applyAfterCreateCallbacks(localRoom, localRoom.actualRoomId).then(() => {
return applyAfterCreateCallbacks(localRoom, actualRoomId).then(() => {
localRoom.state = LocalRoomState.CREATED;
client.emit(ClientEvent.Room, localRoom);
return Promise.resolve(localRoom.actualRoomId);
return Promise.resolve(actualRoomId);
});
}

Expand All @@ -88,10 +99,10 @@ export async function waitForRoomReadyAndApplyAfterCreateCallbacks(
if (checkRoomStateIntervalHandle) clearInterval(checkRoomStateIntervalHandle);
if (stopgapTimeoutHandle) clearTimeout(stopgapTimeoutHandle);

applyAfterCreateCallbacks(localRoom, localRoom.actualRoomId).then(() => {
applyAfterCreateCallbacks(localRoom, actualRoomId).then(() => {
localRoom.state = LocalRoomState.CREATED;
client.emit(ClientEvent.Room, localRoom);
resolve(localRoom.actualRoomId);
resolve(actualRoomId);
});
};

Expand Down
6 changes: 5 additions & 1 deletion test/utils/direct-messages-test.ts
Original file line number Diff line number Diff line change
Expand Up @@ -196,7 +196,11 @@ describe("direct-messages", () => {
const result = await dmModule.createRoomFromLocalRoom(mockClient, localRoom);
expect(result).toBe(room1.roomId);
expect(localRoom.state).toBe(LocalRoomState.CREATING);
expect(waitForRoomReadyAndApplyAfterCreateCallbacks).toHaveBeenCalledWith(mockClient, localRoom);
expect(waitForRoomReadyAndApplyAfterCreateCallbacks).toHaveBeenCalledWith(
mockClient,
localRoom,
room1.roomId,
);
});
});
});
Expand Down
18 changes: 15 additions & 3 deletions test/utils/local-room-test.ts
Original file line number Diff line number Diff line change
Expand Up @@ -108,7 +108,11 @@ describe("local-room", () => {
});

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);
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);
Expand All @@ -121,7 +125,11 @@ describe("local-room", () => {
});

it("should invoke the callbacks, set the room state to created and return the actual room id", async () => {
const prom = localRoomModule.waitForRoomReadyAndApplyAfterCreateCallbacks(client, localRoom);
const prom = localRoomModule.waitForRoomReadyAndApplyAfterCreateCallbacks(
client,
localRoom,
room1.roomId,
);
jest.advanceTimersByTime(5000);
const roomId = await prom;
expect(localRoom.state).toBe(LocalRoomState.CREATED);
Expand All @@ -137,7 +145,11 @@ describe("local-room", () => {
});

it("should invoke the callbacks, set the room state to created and return the actual room id", async () => {
const prom = localRoomModule.waitForRoomReadyAndApplyAfterCreateCallbacks(client, localRoom);
const prom = localRoomModule.waitForRoomReadyAndApplyAfterCreateCallbacks(
client,
localRoom,
room1.roomId,
);
mocked(isRoomReady).mockReturnValue(true);
jest.advanceTimersByTime(500);
const roomId = await prom;
Expand Down