element-web/test/unit-tests/hooks/useUserDirectory-test.tsx

84 lines
2.4 KiB
TypeScript
Raw Normal View History

2022-05-19 11:03:29 +03:00
/*
Copyright 2024 New Vector Ltd.
2022-05-19 11:03:29 +03:00
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.
2022-05-19 11:03:29 +03:00
*/
Update to React 18 (#24763) * Upgrade target to es2021 Signed-off-by: Michael Telatynski <7t3chguy@gmail.com> * Upgrade target to es2021 Signed-off-by: Michael Telatynski <7t3chguy@gmail.com> * Upgrade to es2022 Signed-off-by: Michael Telatynski <7t3chguy@gmail.com> * Upgrade to es2022 Signed-off-by: Michael Telatynski <7t3chguy@gmail.com> * Fix babel config Signed-off-by: Michael Telatynski <7t3chguy@gmail.com> * Fix babel config Signed-off-by: Michael Telatynski <7t3chguy@gmail.com> * Fix React contexts Signed-off-by: Michael Telatynski <7t3chguy@gmail.com> * Fix types Signed-off-by: Michael Telatynski <7t3chguy@gmail.com> * Fix React state Signed-off-by: Michael Telatynski <7t3chguy@gmail.com> * Iterate Signed-off-by: Michael Telatynski <7t3chguy@gmail.com> * Update to React 18 Signed-off-by: Michael Telatynski <7t3chguy@gmail.com> * Update to React 18 Signed-off-by: Michael Telatynski <7t3chguy@gmail.com> * Iterate Signed-off-by: Michael Telatynski <7t3chguy@gmail.com> * Iterate Signed-off-by: Michael Telatynski <7t3chguy@gmail.com> * Iterate Signed-off-by: Michael Telatynski <7t3chguy@gmail.com> * Iterate Signed-off-by: Michael Telatynski <7t3chguy@gmail.com> * Iterate Signed-off-by: Michael Telatynski <7t3chguy@gmail.com> * Iterate Signed-off-by: Michael Telatynski <7t3chguy@gmail.com> * Install @testing-library/dom Signed-off-by: Michael Telatynski <7t3chguy@gmail.com> * Iterate Signed-off-by: Michael Telatynski <7t3chguy@gmail.com> * Iterate Signed-off-by: Michael Telatynski <7t3chguy@gmail.com> * Iterate Signed-off-by: Michael Telatynski <7t3chguy@gmail.com> * Iterate Signed-off-by: Michael Telatynski <7t3chguy@gmail.com> * Iterate Signed-off-by: Michael Telatynski <7t3chguy@gmail.com> * Update lockfile Signed-off-by: Michael Telatynski <7t3chguy@gmail.com> * Iterate Signed-off-by: Michael Telatynski <7t3chguy@gmail.com> * Iterate Signed-off-by: Michael Telatynski <7t3chguy@gmail.com> * Iterate Signed-off-by: Michael Telatynski <7t3chguy@gmail.com> * Iterate Signed-off-by: Michael Telatynski <7t3chguy@gmail.com> * Iterate Signed-off-by: Michael Telatynski <7t3chguy@gmail.com> * Iterate Signed-off-by: Michael Telatynski <7t3chguy@gmail.com> * Iterate Signed-off-by: Michael Telatynski <7t3chguy@gmail.com> * Iterate Signed-off-by: Michael Telatynski <7t3chguy@gmail.com> * Iterate Signed-off-by: Michael Telatynski <7t3chguy@gmail.com> * Iterate Signed-off-by: Michael Telatynski <7t3chguy@gmail.com> * Iterate Signed-off-by: Michael Telatynski <7t3chguy@gmail.com> * Iterate Signed-off-by: Michael Telatynski <7t3chguy@gmail.com> * Yarn lock update * Iterate Signed-off-by: Michael Telatynski <7t3chguy@gmail.com> * Iterate Signed-off-by: Michael Telatynski <7t3chguy@gmail.com> * Iterate Signed-off-by: Michael Telatynski <7t3chguy@gmail.com> * Iterate Signed-off-by: Michael Telatynski <7t3chguy@gmail.com> --------- Signed-off-by: Michael Telatynski <7t3chguy@gmail.com>
2024-10-21 16:50:06 +03:00
import { waitFor, renderHook, act } from "jest-matrix-react";
import { MatrixClient } from "matrix-js-sdk/src/matrix";
2022-05-19 11:03:29 +03:00
import { useUserDirectory } from "../../../src/hooks/useUserDirectory";
import { MatrixClientPeg } from "../../../src/MatrixClientPeg";
import { stubClient } from "../../test-utils";
2022-05-19 11:03:29 +03:00
function render() {
return renderHook(() => useUserDirectory());
2022-05-19 11:03:29 +03:00
}
describe("useUserDirectory", () => {
let cli: MatrixClient;
2022-05-19 11:03:29 +03:00
beforeEach(() => {
stubClient();
cli = MatrixClientPeg.safeGet();
2022-05-19 11:03:29 +03:00
cli.getDomain = () => "matrix.org";
2022-05-19 11:03:29 +03:00
cli.getThirdpartyProtocols = () => Promise.resolve({});
2022-12-12 14:24:14 +03:00
cli.searchUserDirectory = ({ term: query }) =>
Promise.resolve({
results: [
{
user_id: "@bob:matrix.org",
display_name: query,
},
],
limited: false,
2022-12-12 14:24:14 +03:00
});
2022-05-19 11:03:29 +03:00
});
it("search for users in the identity server", async () => {
const query = "Bob";
const { result } = render();
2022-05-19 11:03:29 +03:00
act(() => {
result.current.search({ limit: 1, query });
2022-05-19 11:03:29 +03:00
});
await waitFor(() => expect(result.current.ready).toBe(true));
2022-05-19 11:03:29 +03:00
expect(result.current.loading).toBe(false);
expect(result.current.users[0].name).toBe(query);
2022-05-19 11:03:29 +03:00
});
it("should work with empty queries", async () => {
const query = "";
const { result } = render();
2022-05-19 11:03:29 +03:00
act(() => {
result.current.search({ limit: 1, query });
2022-05-19 11:03:29 +03:00
});
await waitFor(() => expect(result.current.ready).toBe(true));
expect(result.current.loading).toBe(false);
expect(result.current.users).toEqual([]);
2022-05-19 11:03:29 +03:00
});
it("should recover from a server exception", async () => {
2022-12-12 14:24:14 +03:00
cli.searchUserDirectory = () => {
throw new Error("Oops");
};
2022-05-19 11:03:29 +03:00
const query = "Bob";
const { result } = render();
act(() => {
result.current.search({ limit: 1, query });
2022-05-19 11:03:29 +03:00
});
await waitFor(() => expect(result.current.ready).toBe(true));
expect(result.current.loading).toBe(false);
expect(result.current.users).toEqual([]);
2022-05-19 11:03:29 +03:00
});
});