d8800ef987
* 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>
145 lines
6.2 KiB
TypeScript
145 lines
6.2 KiB
TypeScript
/*
|
|
Copyright 2024 New Vector Ltd.
|
|
Copyright 2023 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 { waitFor, renderHook } from "jest-matrix-react";
|
|
import { IPushRules, MatrixClient, PushRuleKind, RuleId } from "matrix-js-sdk/src/matrix";
|
|
|
|
import { useNotificationSettings } from "../../../src/hooks/useNotificationSettings";
|
|
import { MatrixClientPeg } from "../../../src/MatrixClientPeg";
|
|
import {
|
|
DefaultNotificationSettings,
|
|
NotificationSettings,
|
|
} from "../../../src/models/notificationsettings/NotificationSettings";
|
|
import { StandardActions } from "../../../src/notifications/StandardActions";
|
|
import { RoomNotifState } from "../../../src/RoomNotifs";
|
|
import { stubClient } from "../../test-utils";
|
|
|
|
const expectedModel: NotificationSettings = {
|
|
globalMute: false,
|
|
defaultLevels: {
|
|
dm: RoomNotifState.AllMessages,
|
|
room: RoomNotifState.MentionsOnly,
|
|
},
|
|
sound: {
|
|
calls: "ring",
|
|
mentions: "default",
|
|
people: undefined,
|
|
},
|
|
activity: {
|
|
bot_notices: false,
|
|
invite: true,
|
|
status_event: false,
|
|
},
|
|
mentions: {
|
|
user: true,
|
|
room: true,
|
|
keywords: true,
|
|
},
|
|
keywords: ["justjann3", "justj4nn3", "justj4nne", "Janne", "J4nne", "Jann3", "jann3", "j4nne", "janne"],
|
|
};
|
|
|
|
describe("useNotificationSettings", () => {
|
|
let cli: MatrixClient;
|
|
let pushRules: IPushRules;
|
|
|
|
beforeAll(async () => {
|
|
pushRules = (await import("../models/notificationsettings/pushrules_sample.json")) as IPushRules;
|
|
});
|
|
|
|
beforeEach(() => {
|
|
stubClient();
|
|
cli = MatrixClientPeg.safeGet();
|
|
cli.getPushRules = jest.fn(cli.getPushRules).mockResolvedValue(pushRules);
|
|
cli.supportsIntentionalMentions = jest.fn(cli.supportsIntentionalMentions).mockReturnValue(false);
|
|
});
|
|
|
|
it("correctly parses model", async () => {
|
|
const { result } = renderHook(() => useNotificationSettings(cli));
|
|
expect(result.current.model).toEqual(null);
|
|
await waitFor(() => expect(result.current.model).toEqual(expectedModel));
|
|
expect(result.current.hasPendingChanges).toBeFalsy();
|
|
});
|
|
|
|
it("correctly generates change calls", async () => {
|
|
const addPushRule = jest.fn(cli.addPushRule);
|
|
cli.addPushRule = addPushRule;
|
|
const deletePushRule = jest.fn(cli.deletePushRule);
|
|
cli.deletePushRule = deletePushRule;
|
|
const setPushRuleEnabled = jest.fn(cli.setPushRuleEnabled);
|
|
cli.setPushRuleEnabled = setPushRuleEnabled;
|
|
const setPushRuleActions = jest.fn(cli.setPushRuleActions);
|
|
cli.setPushRuleActions = setPushRuleActions;
|
|
|
|
const { result } = renderHook(() => useNotificationSettings(cli));
|
|
expect(result.current.model).toEqual(null);
|
|
await waitFor(() => expect(result.current.model).toEqual(expectedModel));
|
|
expect(result.current.hasPendingChanges).toBeFalsy();
|
|
await result.current.reconcile(DefaultNotificationSettings);
|
|
await waitFor(() => expect(result.current.hasPendingChanges).toBeFalsy());
|
|
expect(addPushRule).toHaveBeenCalledTimes(0);
|
|
expect(deletePushRule).toHaveBeenCalledTimes(9);
|
|
expect(deletePushRule).toHaveBeenCalledWith("global", PushRuleKind.ContentSpecific, "justjann3");
|
|
expect(deletePushRule).toHaveBeenCalledWith("global", PushRuleKind.ContentSpecific, "justj4nn3");
|
|
expect(deletePushRule).toHaveBeenCalledWith("global", PushRuleKind.ContentSpecific, "justj4nne");
|
|
expect(deletePushRule).toHaveBeenCalledWith("global", PushRuleKind.ContentSpecific, "Janne");
|
|
expect(deletePushRule).toHaveBeenCalledWith("global", PushRuleKind.ContentSpecific, "J4nne");
|
|
expect(deletePushRule).toHaveBeenCalledWith("global", PushRuleKind.ContentSpecific, "Jann3");
|
|
expect(deletePushRule).toHaveBeenCalledWith("global", PushRuleKind.ContentSpecific, "jann3");
|
|
expect(deletePushRule).toHaveBeenCalledWith("global", PushRuleKind.ContentSpecific, "j4nne");
|
|
expect(deletePushRule).toHaveBeenCalledWith("global", PushRuleKind.ContentSpecific, "janne");
|
|
expect(setPushRuleEnabled).toHaveBeenCalledTimes(6);
|
|
expect(setPushRuleEnabled).toHaveBeenCalledWith(
|
|
"global",
|
|
PushRuleKind.Underride,
|
|
RuleId.EncryptedMessage,
|
|
true,
|
|
);
|
|
expect(setPushRuleEnabled).toHaveBeenCalledWith("global", PushRuleKind.Underride, RuleId.Message, true);
|
|
expect(setPushRuleEnabled).toHaveBeenCalledWith("global", PushRuleKind.Underride, RuleId.EncryptedDM, true);
|
|
expect(setPushRuleEnabled).toHaveBeenCalledWith("global", PushRuleKind.Underride, RuleId.DM, true);
|
|
expect(setPushRuleEnabled).toHaveBeenCalledWith("global", PushRuleKind.Override, RuleId.SuppressNotices, false);
|
|
expect(setPushRuleEnabled).toHaveBeenCalledWith("global", PushRuleKind.Override, RuleId.InviteToSelf, true);
|
|
expect(setPushRuleActions).toHaveBeenCalledTimes(6);
|
|
expect(setPushRuleActions).toHaveBeenCalledWith(
|
|
"global",
|
|
PushRuleKind.Underride,
|
|
RuleId.EncryptedMessage,
|
|
StandardActions.ACTION_NOTIFY,
|
|
);
|
|
expect(setPushRuleActions).toHaveBeenCalledWith(
|
|
"global",
|
|
PushRuleKind.Underride,
|
|
RuleId.Message,
|
|
StandardActions.ACTION_NOTIFY,
|
|
);
|
|
expect(setPushRuleActions).toHaveBeenCalledWith(
|
|
"global",
|
|
PushRuleKind.Underride,
|
|
RuleId.EncryptedDM,
|
|
StandardActions.ACTION_NOTIFY_DEFAULT_SOUND,
|
|
);
|
|
expect(setPushRuleActions).toHaveBeenCalledWith(
|
|
"global",
|
|
PushRuleKind.Underride,
|
|
RuleId.DM,
|
|
StandardActions.ACTION_NOTIFY_DEFAULT_SOUND,
|
|
);
|
|
expect(setPushRuleActions).toHaveBeenCalledWith(
|
|
"global",
|
|
PushRuleKind.Override,
|
|
RuleId.SuppressNotices,
|
|
StandardActions.ACTION_DONT_NOTIFY,
|
|
);
|
|
expect(setPushRuleActions).toHaveBeenCalledWith(
|
|
"global",
|
|
PushRuleKind.Override,
|
|
RuleId.InviteToSelf,
|
|
StandardActions.ACTION_NOTIFY_DEFAULT_SOUND,
|
|
);
|
|
});
|
|
});
|