/** * Copyright (c) OpenLens Authors. All rights reserved. * Licensed under MIT License. See LICENSE in root directory for more information. */ import type { ApplicationBuilder } from "../../renderer/components/test-utils/get-application-builder"; import { getApplicationBuilder } from "../../renderer/components/test-utils/get-application-builder"; import electronUpdaterIsActiveInjectable from "../../main/electron-app/features/electron-updater-is-active.injectable"; import publishIsConfiguredInjectable from "../../main/application-update/publish-is-configured.injectable"; import type { AsyncFnMock } from "@async-fn/jest"; import asyncFn from "@async-fn/jest"; import type { CheckForPlatformUpdates } from "../../main/application-update/check-for-platform-updates/check-for-platform-updates.injectable"; import checkForPlatformUpdatesInjectable from "../../main/application-update/check-for-platform-updates/check-for-platform-updates.injectable"; import appEventBusInjectable from "../../common/app-event-bus/app-event-bus.injectable"; import type { DiContainer } from "@ogre-tools/injectable"; import processCheckingForUpdatesInjectable from "../../main/application-update/check-for-updates/process-checking-for-updates.injectable"; import type { DownloadPlatformUpdate } from "../../main/application-update/download-platform-update/download-platform-update.injectable"; import downloadPlatformUpdateInjectable from "../../main/application-update/download-platform-update/download-platform-update.injectable"; import quitAndInstallUpdateInjectable from "../../main/application-update/quit-and-install-update.injectable"; import appVersionInjectable from "../../common/get-configuration-file-model/app-version/app-version.injectable"; import periodicalCheckForUpdatesInjectable from "../../main/application-update/periodical-check-for-updates/periodical-check-for-updates.injectable"; import { advanceFakeTime, useFakeTime } from "../../common/test-utils/use-fake-time"; describe("analytics for installing update", () => { let applicationBuilder: ApplicationBuilder; let checkForPlatformUpdatesMock: AsyncFnMock; let downloadPlatformUpdateMock: AsyncFnMock; let analyticsListenerMock: jest.Mock; let mainDi: DiContainer; beforeEach(async () => { useFakeTime("2015-10-21T07:28:00Z"); applicationBuilder = getApplicationBuilder(); analyticsListenerMock = jest.fn(); applicationBuilder.beforeApplicationStart(({ mainDi }) => { mainDi.override(appVersionInjectable, () => "42.0.0"); checkForPlatformUpdatesMock = asyncFn(); mainDi.override( checkForPlatformUpdatesInjectable, () => checkForPlatformUpdatesMock, ); downloadPlatformUpdateMock = asyncFn(); mainDi.override(downloadPlatformUpdateInjectable, () => downloadPlatformUpdateMock); mainDi.override(electronUpdaterIsActiveInjectable, () => true); mainDi.override(publishIsConfiguredInjectable, () => true); const eventBus = mainDi.inject(appEventBusInjectable); eventBus.addListener(analyticsListenerMock); }); mainDi = applicationBuilder.dis.mainDi; }); describe("given application is started and checking updates periodically", () => { beforeEach(async () => { mainDi.unoverride(periodicalCheckForUpdatesInjectable); mainDi.permitSideEffects(periodicalCheckForUpdatesInjectable); await applicationBuilder.render(); }); it("sends event to analytics for being checked periodically", () => { expect(analyticsListenerMock).toHaveBeenCalledWith({ name: "app", action: "checking-for-updates", params: { currentDateTime: "2015-10-21T07:28:00Z", source: "periodic", }, }); }); it("when enough time passes to check for updates again, sends event to analytics for being checked periodically", () => { analyticsListenerMock.mockClear(); advanceFakeTime(1000 * 60 * 60 * 2); expect(analyticsListenerMock).toHaveBeenCalledWith({ name: "app", action: "checking-for-updates", params: { currentDateTime: "2015-10-21T09:28:00Z", source: "periodic", }, }); }); }); describe("when application is started", () => { beforeEach(async () => { analyticsListenerMock.mockClear(); await applicationBuilder.render(); }); it("sends event to analytics about the current version", () => { expect(analyticsListenerMock).toHaveBeenCalledWith({ name: "app", action: "current-version", params: { version: "42.0.0", currentDateTime: "2015-10-21T07:28:00Z", }, }); }); it("when checking for updates using tray, sends event to analytics for being checked from tray", async () => { analyticsListenerMock.mockClear(); applicationBuilder.tray.click("check-for-updates"); expect(analyticsListenerMock.mock.calls).toEqual([ [ { name: "app", action: "checking-for-updates", params: { currentDateTime: "2015-10-21T07:28:00Z", source: "tray", }, }, ], ]); }); it("when checking for updates using application menu, sends event to analytics for being checked from application menu", async () => { analyticsListenerMock.mockClear(); applicationBuilder.applicationMenu.click("root.check-for-updates"); expect(analyticsListenerMock.mock.calls).toEqual([ [ { name: "app", action: "checking-for-updates", params: { currentDateTime: "2015-10-21T07:28:00Z", source: "application-menu", }, }, ], ]); }); describe("given checking for updates, when check for updates resolves with new update being available", () => { beforeEach(async () => { const processCheckingForUpdates = mainDi.inject(processCheckingForUpdatesInjectable); processCheckingForUpdates("irrelevant"); analyticsListenerMock.mockClear(); await checkForPlatformUpdatesMock.resolve({ updateWasDiscovered: true, version: "43.0.0", }); }); it("sends event to analytics about new update being available", () => { expect(analyticsListenerMock.mock.calls).toEqual([ [ { name: "app", action: "update-was-discovered", params: { version: "43.0.0", currentDateTime: "2015-10-21T07:28:00Z", }, }, ], ]); }); describe("given update is downloaded", () => { beforeEach(async () => { analyticsListenerMock.mockClear(); await downloadPlatformUpdateMock.resolve({ downloadWasSuccessful: true }); }); it("does not send event to analytics about update downloaded being successful", () => { expect(analyticsListenerMock).not.toHaveBeenCalled(); }); it("when installing the update, sends event to analytics about installing the update", () => { const quitAndInstallUpdate = mainDi.inject(quitAndInstallUpdateInjectable); quitAndInstallUpdate(); expect(analyticsListenerMock.mock.calls).toEqual([ [ { name: "app", action: "start-installing-update", params: { version: "43.0.0", currentDateTime: "2015-10-21T07:28:00Z", updateChannel: "latest", }, }, ], ]); }); }); }); }); });