144 lines
		
	
	
		
			4.5 KiB
		
	
	
	
		
			TypeScript
		
	
	
			
		
		
	
	
			144 lines
		
	
	
		
			4.5 KiB
		
	
	
	
		
			TypeScript
		
	
	
| /*
 | |
| 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 OR LicenseRef-Element-Commercial
 | |
| Please see LICENSE files in the repository root for full details.
 | |
| */
 | |
| 
 | |
| import { mocked } from "jest-mock";
 | |
| import { EventType, MatrixClient, MatrixEvent } from "matrix-js-sdk/src/matrix";
 | |
| 
 | |
| import { setDMRoom } from "../../src/Rooms";
 | |
| import { mkEvent, stubClient } from "../test-utils";
 | |
| 
 | |
| describe("setDMRoom", () => {
 | |
|     const userId1 = "@user1:example.com";
 | |
|     const userId2 = "@user2:example.com";
 | |
|     const userId3 = "@user3:example.com";
 | |
|     const roomId1 = "!room1:example.com";
 | |
|     const roomId2 = "!room2:example.com";
 | |
|     const roomId3 = "!room3:example.com";
 | |
|     const roomId4 = "!room4:example.com";
 | |
|     let client: MatrixClient;
 | |
| 
 | |
|     beforeEach(() => {
 | |
|         client = mocked(stubClient());
 | |
|         client.getAccountData = jest.fn().mockImplementation((eventType: string): MatrixEvent | undefined => {
 | |
|             if (eventType === EventType.Direct) {
 | |
|                 return mkEvent({
 | |
|                     event: true,
 | |
|                     content: {
 | |
|                         [userId1]: [roomId1, roomId2],
 | |
|                         [userId2]: [roomId3],
 | |
|                     },
 | |
|                     type: EventType.Direct,
 | |
|                     user: client.getSafeUserId(),
 | |
|                 });
 | |
|             }
 | |
| 
 | |
|             return undefined;
 | |
|         });
 | |
|     });
 | |
| 
 | |
|     describe("when logged in as a guest and marking a room as DM", () => {
 | |
|         beforeEach(() => {
 | |
|             mocked(client.isGuest).mockReturnValue(true);
 | |
|             setDMRoom(client, roomId1, userId1);
 | |
|         });
 | |
| 
 | |
|         it("should not update the account data", () => {
 | |
|             expect(client.setAccountData).not.toHaveBeenCalled();
 | |
|         });
 | |
|     });
 | |
| 
 | |
|     describe("when adding a new room to an existing DM relation", () => {
 | |
|         beforeEach(() => {
 | |
|             setDMRoom(client, roomId4, userId1);
 | |
|         });
 | |
| 
 | |
|         it("should update the account data accordingly", () => {
 | |
|             expect(client.setAccountData).toHaveBeenCalledWith(EventType.Direct, {
 | |
|                 [userId1]: [roomId1, roomId2, roomId4],
 | |
|                 [userId2]: [roomId3],
 | |
|             });
 | |
|         });
 | |
|     });
 | |
| 
 | |
|     describe("when adding a new DM room", () => {
 | |
|         beforeEach(() => {
 | |
|             setDMRoom(client, roomId4, userId3);
 | |
|         });
 | |
| 
 | |
|         it("should update the account data accordingly", () => {
 | |
|             expect(client.setAccountData).toHaveBeenCalledWith(EventType.Direct, {
 | |
|                 [userId1]: [roomId1, roomId2],
 | |
|                 [userId2]: [roomId3],
 | |
|                 [userId3]: [roomId4],
 | |
|             });
 | |
|         });
 | |
|     });
 | |
| 
 | |
|     describe("when trying to add a DM, that already exists", () => {
 | |
|         beforeEach(() => {
 | |
|             setDMRoom(client, roomId1, userId1);
 | |
|         });
 | |
| 
 | |
|         it("should not update the account data", () => {
 | |
|             expect(client.setAccountData).not.toHaveBeenCalled();
 | |
|         });
 | |
|     });
 | |
| 
 | |
|     describe("when removing an existing DM", () => {
 | |
|         beforeEach(() => {
 | |
|             setDMRoom(client, roomId1, null);
 | |
|         });
 | |
| 
 | |
|         it("should update the account data accordingly", () => {
 | |
|             expect(client.setAccountData).toHaveBeenCalledWith(EventType.Direct, {
 | |
|                 [userId1]: [roomId2],
 | |
|                 [userId2]: [roomId3],
 | |
|             });
 | |
|         });
 | |
|     });
 | |
| 
 | |
|     describe("when removing an unknown room", () => {
 | |
|         beforeEach(() => {
 | |
|             setDMRoom(client, roomId4, null);
 | |
|         });
 | |
| 
 | |
|         it("should not update the account data", () => {
 | |
|             expect(client.setAccountData).not.toHaveBeenCalled();
 | |
|         });
 | |
|     });
 | |
| 
 | |
|     describe("when the direct event is undefined", () => {
 | |
|         beforeEach(() => {
 | |
|             mocked(client.getAccountData).mockReturnValue(undefined);
 | |
|             setDMRoom(client, roomId1, userId1);
 | |
|         });
 | |
| 
 | |
|         it("should update the account data accordingly", () => {
 | |
|             expect(client.setAccountData).toHaveBeenCalledWith(EventType.Direct, {
 | |
|                 [userId1]: [roomId1],
 | |
|             });
 | |
|         });
 | |
|     });
 | |
| 
 | |
|     describe("when the current content is undefined", () => {
 | |
|         beforeEach(() => {
 | |
|             // @ts-ignore
 | |
|             mocked(client.getAccountData).mockReturnValue({
 | |
|                 getContent: jest.fn(),
 | |
|             });
 | |
|             setDMRoom(client, roomId1, userId1);
 | |
|         });
 | |
| 
 | |
|         it("should update the account data accordingly", () => {
 | |
|             expect(client.setAccountData).toHaveBeenCalledWith(EventType.Direct, {
 | |
|                 [userId1]: [roomId1],
 | |
|             });
 | |
|         });
 | |
|     });
 | |
| });
 |