899cdb0e1d
* Skip unwritten tests Signed-off-by: Michael Telatynski <7t3chguy@gmail.com> * Tidy jest fake timers Signed-off-by: Michael Telatynski <7t3chguy@gmail.com> * Remove unnecessary sessionStorage mock Signed-off-by: Michael Telatynski <7t3chguy@gmail.com> * Improve types Signed-off-by: Michael Telatynski <7t3chguy@gmail.com> * Improve async assertions Signed-off-by: Michael Telatynski <7t3chguy@gmail.com> * Improve error assertions Signed-off-by: Michael Telatynski <7t3chguy@gmail.com> * Improve object assertions Signed-off-by: Michael Telatynski <7t3chguy@gmail.com> * Remove assertion testing unclear mock This test failed when ran individually, same as after the clearAllMocks call Signed-off-by: Michael Telatynski <7t3chguy@gmail.com> * Avoid awaiting non-thenables Signed-off-by: Michael Telatynski <7t3chguy@gmail.com> * Pass nop function when stubbing out console, vitest won't accept it any other way Signed-off-by: Michael Telatynski <7t3chguy@gmail.com> * Remove unnecessary mock which causes tests to fail after updating fetch-mock & fix typo Signed-off-by: Michael Telatynski <7t3chguy@gmail.com> * Fix mistaken assertions not testing all values in array Signed-off-by: Michael Telatynski <7t3chguy@gmail.com> * Fix hidden non-running tests in room.spec.ts Signed-off-by: Michael Telatynski <7t3chguy@gmail.com> * Update fetch-mock-jest to @fetch-mock/jest Signed-off-by: Michael Telatynski <7t3chguy@gmail.com> * Delint Signed-off-by: Michael Telatynski <7t3chguy@gmail.com> * Make knip happier Signed-off-by: Michael Telatynski <7t3chguy@gmail.com> * Make knip happier 2.0 Signed-off-by: Michael Telatynski <7t3chguy@gmail.com> * Delint Signed-off-by: Michael Telatynski <7t3chguy@gmail.com> * Switch from Jest to Vitest Signed-off-by: Michael Telatynski <7t3chguy@gmail.com> * Iterate Signed-off-by: Michael Telatynski <7t3chguy@gmail.com> * Delint Signed-off-by: Michael Telatynski <7t3chguy@gmail.com> * Fix CI Signed-off-by: Michael Telatynski <7t3chguy@gmail.com> * Remove unnecessary fake timers Signed-off-by: Michael Telatynski <7t3chguy@gmail.com> * Update vite Signed-off-by: Michael Telatynski <7t3chguy@gmail.com> * Revert irrelevant changes Signed-off-by: Michael Telatynski <7t3chguy@gmail.com> * Fix coverage spec paths Signed-off-by: Michael Telatynski <7t3chguy@gmail.com> * Fix slow test reporter Signed-off-by: Michael Telatynski <7t3chguy@gmail.com> * Fix bad merge conflict resolution Signed-off-by: Michael Telatynski <7t3chguy@gmail.com> * Fix babel config Signed-off-by: Michael Telatynski <7t3chguy@gmail.com> --------- Signed-off-by: Michael Telatynski <7t3chguy@gmail.com>
100 lines
3.4 KiB
TypeScript
100 lines
3.4 KiB
TypeScript
/*
|
|
Copyright 2022 The Matrix.org Foundation C.I.C.
|
|
|
|
Licensed under the Apache License, Version 2.0 (the "License");
|
|
you may not use this file except in compliance with the License.
|
|
You may obtain a copy of the License at
|
|
|
|
http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
Unless required by applicable law or agreed to in writing, software
|
|
distributed under the License is distributed on an "AS IS" BASIS,
|
|
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
See the License for the specific language governing permissions and
|
|
limitations under the License.
|
|
*/
|
|
|
|
import { type MockedObject } from "vitest";
|
|
|
|
import { type ClientEventHandlerMap, type EmittedEvents, type MatrixClient } from "../../src/client";
|
|
import { TypedEventEmitter } from "../../src/models/typed-event-emitter";
|
|
import { User } from "../../src/models/user";
|
|
|
|
// Cribbed from https://github.com/jestjs/jest/blob/94830794dc5dfca1b49bc435b7b031b27838a798/packages/jest-mock/src/index.ts
|
|
type FunctionLike = (...args: any) => any;
|
|
type MethodLikeKeys<T> = keyof {
|
|
[K in keyof T as Required<T>[K] extends FunctionLike ? K : never]: T[K];
|
|
};
|
|
|
|
/**
|
|
* Mock client with real event emitter
|
|
* useful for testing code that listens
|
|
* to MatrixClient events
|
|
*/
|
|
export class MockClientWithEventEmitter extends TypedEventEmitter<EmittedEvents, ClientEventHandlerMap> {
|
|
constructor(mockProperties: Partial<Record<MethodLikeKeys<MatrixClient>, unknown>> = {}) {
|
|
super();
|
|
Object.assign(this, mockProperties);
|
|
}
|
|
}
|
|
|
|
/**
|
|
* - make a mock client
|
|
* - cast the type to vi.mocked(MatrixClient)
|
|
* - spy on MatrixClientPeg.get to return the mock
|
|
* eg
|
|
* ```
|
|
* const mockClient = getMockClientWithEventEmitter({
|
|
getUserId: vi.fn().mockReturnValue(aliceId),
|
|
});
|
|
* ```
|
|
*/
|
|
export const getMockClientWithEventEmitter = (
|
|
mockProperties: Partial<Record<MethodLikeKeys<MatrixClient>, unknown>>,
|
|
): MockedObject<MatrixClient> => {
|
|
const mock = vi.mocked(new MockClientWithEventEmitter(mockProperties) as unknown as MatrixClient);
|
|
return mock;
|
|
};
|
|
|
|
/**
|
|
* Returns basic mocked client methods related to the current user
|
|
* ```
|
|
* const mockClient = getMockClientWithEventEmitter({
|
|
...mockClientMethodsUser('@mytestuser:domain'),
|
|
});
|
|
* ```
|
|
*/
|
|
export const mockClientMethodsUser = (userId = "@alice:domain") => ({
|
|
getUserId: vi.fn().mockReturnValue(userId),
|
|
getSafeUserId: vi.fn().mockReturnValue(userId),
|
|
getUser: vi.fn().mockReturnValue(new User(userId)),
|
|
isGuest: vi.fn().mockReturnValue(false),
|
|
mxcUrlToHttp: vi.fn().mockReturnValue("mock-mxcUrlToHttp"),
|
|
credentials: { userId },
|
|
getThreePids: vi.fn().mockResolvedValue({ threepids: [] }),
|
|
getAccessToken: vi.fn(),
|
|
});
|
|
|
|
/**
|
|
* Returns basic mocked client methods related to rendering events
|
|
* ```
|
|
* const mockClient = getMockClientWithEventEmitter({
|
|
...mockClientMethodsUser('@mytestuser:domain'),
|
|
});
|
|
* ```
|
|
*/
|
|
export const mockClientMethodsEvents = () => ({
|
|
decryptEventIfNeeded: vi.fn(),
|
|
getPushActionsForEvent: vi.fn(),
|
|
});
|
|
|
|
/**
|
|
* Returns basic mocked client methods related to server support
|
|
*/
|
|
export const mockClientMethodsServer = (): Partial<Record<MethodLikeKeys<MatrixClient>, unknown>> => ({
|
|
getIdentityServerUrl: vi.fn(),
|
|
getHomeserverUrl: vi.fn(),
|
|
getCachedCapabilities: vi.fn().mockReturnValue({}),
|
|
doesServerSupportUnstableFeature: vi.fn().mockResolvedValue(false),
|
|
});
|