2022-12-06 06:18:03 +00:00
|
|
|
/*
|
2024-09-09 13:57:16 +00:00
|
|
|
Copyright 2024 New Vector Ltd.
|
2022-12-06 06:18:03 +00:00
|
|
|
Copyright 2022 The Matrix.org Foundation C.I.C.
|
|
|
|
|
2024-09-09 13:57:16 +00:00
|
|
|
SPDX-License-Identifier: AGPL-3.0-only OR GPL-3.0-only
|
|
|
|
Please see LICENSE files in the repository root for full details.
|
2022-12-06 06:18:03 +00:00
|
|
|
*/
|
|
|
|
|
|
|
|
import { logger } from "matrix-js-sdk/src/logger";
|
|
|
|
|
|
|
|
import {
|
|
|
|
isBulkUnverifiedDeviceReminderSnoozed,
|
|
|
|
snoozeBulkUnverifiedDeviceReminder,
|
2024-10-15 13:57:26 +00:00
|
|
|
} from "../../../../src/utils/device/snoozeBulkUnverifiedDeviceReminder";
|
2022-12-06 06:18:03 +00:00
|
|
|
|
|
|
|
const SNOOZE_KEY = "mx_snooze_bulk_unverified_device_nag";
|
|
|
|
|
|
|
|
describe("snooze bulk unverified device nag", () => {
|
|
|
|
const localStorageSetSpy = jest.spyOn(localStorage.__proto__, "setItem");
|
|
|
|
const localStorageGetSpy = jest.spyOn(localStorage.__proto__, "getItem");
|
|
|
|
const localStorageRemoveSpy = jest.spyOn(localStorage.__proto__, "removeItem");
|
|
|
|
|
|
|
|
// 14.03.2022 16:15
|
|
|
|
const now = 1647270879403;
|
|
|
|
|
|
|
|
beforeEach(() => {
|
|
|
|
localStorageSetSpy.mockClear().mockImplementation(() => {});
|
|
|
|
localStorageGetSpy.mockClear().mockReturnValue(null);
|
|
|
|
localStorageRemoveSpy.mockClear().mockImplementation(() => {});
|
|
|
|
|
|
|
|
jest.spyOn(Date, "now").mockReturnValue(now);
|
|
|
|
});
|
|
|
|
|
|
|
|
afterAll(() => {
|
|
|
|
jest.restoreAllMocks();
|
|
|
|
});
|
|
|
|
|
|
|
|
describe("snoozeBulkUnverifiedDeviceReminder()", () => {
|
|
|
|
it("sets the current time in local storage", () => {
|
|
|
|
snoozeBulkUnverifiedDeviceReminder();
|
|
|
|
|
|
|
|
expect(localStorageSetSpy).toHaveBeenCalledWith(SNOOZE_KEY, now.toString());
|
|
|
|
});
|
|
|
|
|
|
|
|
it("catches an error from localstorage", () => {
|
|
|
|
const loggerErrorSpy = jest.spyOn(logger, "error");
|
|
|
|
localStorageSetSpy.mockImplementation(() => {
|
|
|
|
throw new Error("oups");
|
|
|
|
});
|
|
|
|
snoozeBulkUnverifiedDeviceReminder();
|
|
|
|
expect(loggerErrorSpy).toHaveBeenCalled();
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
describe("isBulkUnverifiedDeviceReminderSnoozed()", () => {
|
|
|
|
it("returns false when there is no snooze in storage", () => {
|
|
|
|
const result = isBulkUnverifiedDeviceReminderSnoozed();
|
|
|
|
expect(localStorageGetSpy).toHaveBeenCalledWith(SNOOZE_KEY);
|
|
|
|
expect(result).toBe(false);
|
|
|
|
});
|
|
|
|
|
|
|
|
it("catches an error from localstorage and returns false", () => {
|
|
|
|
const loggerErrorSpy = jest.spyOn(logger, "error");
|
|
|
|
localStorageGetSpy.mockImplementation(() => {
|
|
|
|
throw new Error("oups");
|
|
|
|
});
|
|
|
|
const result = isBulkUnverifiedDeviceReminderSnoozed();
|
|
|
|
expect(result).toBe(false);
|
|
|
|
expect(loggerErrorSpy).toHaveBeenCalled();
|
|
|
|
});
|
|
|
|
|
|
|
|
it("returns false when snooze timestamp in storage is not a number", () => {
|
|
|
|
localStorageGetSpy.mockReturnValue("test");
|
|
|
|
const result = isBulkUnverifiedDeviceReminderSnoozed();
|
|
|
|
expect(result).toBe(false);
|
|
|
|
});
|
|
|
|
|
|
|
|
it("returns false when snooze timestamp in storage is over a week ago", () => {
|
|
|
|
const msDay = 1000 * 60 * 60 * 24;
|
|
|
|
// snoozed 8 days ago
|
|
|
|
localStorageGetSpy.mockReturnValue(now - msDay * 8);
|
|
|
|
const result = isBulkUnverifiedDeviceReminderSnoozed();
|
|
|
|
expect(result).toBe(false);
|
|
|
|
});
|
|
|
|
|
|
|
|
it("returns true when snooze timestamp in storage is less than a week ago", () => {
|
|
|
|
const msDay = 1000 * 60 * 60 * 24;
|
|
|
|
// snoozed 8 days ago
|
|
|
|
localStorageGetSpy.mockReturnValue(now - msDay * 6);
|
|
|
|
const result = isBulkUnverifiedDeviceReminderSnoozed();
|
|
|
|
expect(result).toBe(true);
|
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|