2022-09-23 16:42:03 +08:00
|
|
|
/*
|
2024-09-06 22:44:31 +08:00
|
|
|
Copyright 2024 New Vector Ltd.
|
2022-09-23 16:42:03 +08:00
|
|
|
Copyright 2022 The Matrix.org Foundation C.I.C.
|
|
|
|
|
2024-09-06 22:44:31 +08: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-09-23 16:42:03 +08:00
|
|
|
*/
|
|
|
|
|
|
|
|
import "jest-canvas-mock";
|
|
|
|
|
|
|
|
import Favicon from "../../src/favicon";
|
|
|
|
|
|
|
|
jest.useFakeTimers();
|
|
|
|
|
|
|
|
describe("Favicon", () => {
|
|
|
|
beforeEach(() => {
|
|
|
|
const head = document.createElement("head");
|
|
|
|
window.document.documentElement.prepend(head);
|
|
|
|
});
|
|
|
|
|
|
|
|
it("should create a link element if one doesn't yet exist", () => {
|
|
|
|
const favicon = new Favicon();
|
|
|
|
expect(favicon).toBeTruthy();
|
2023-04-25 16:36:17 +08:00
|
|
|
const link = window.document.querySelector("link")!;
|
2022-09-23 16:42:03 +08:00
|
|
|
expect(link.rel).toContain("icon");
|
|
|
|
});
|
|
|
|
|
|
|
|
it("should draw a badge if called with a non-zero value", () => {
|
|
|
|
const favicon = new Favicon();
|
|
|
|
favicon.badge(123);
|
|
|
|
jest.runAllTimers();
|
|
|
|
expect(favicon["context"].__getDrawCalls()).toMatchSnapshot();
|
|
|
|
});
|
|
|
|
|
|
|
|
it("should clear a badge if called with a zero value", () => {
|
|
|
|
const favicon = new Favicon();
|
|
|
|
favicon.badge(123);
|
|
|
|
jest.runAllTimers();
|
|
|
|
favicon.badge(0);
|
|
|
|
expect(favicon["context"].__getDrawCalls()).toMatchSnapshot();
|
|
|
|
});
|
|
|
|
|
|
|
|
it("should recreate link element for firefox and opera", () => {
|
|
|
|
window["InstallTrigger"] = {};
|
|
|
|
window["opera"] = {};
|
|
|
|
const favicon = new Favicon();
|
|
|
|
const originalLink = window.document.querySelector("link");
|
|
|
|
favicon.badge(123);
|
|
|
|
jest.runAllTimers();
|
|
|
|
const newLink = window.document.querySelector("link");
|
|
|
|
expect(originalLink).not.toStrictEqual(newLink);
|
|
|
|
});
|
|
|
|
});
|