mirror of
https://github.com/lensapp/lens.git
synced 2025-05-20 05:10:56 +00:00
* Introduce helper for advancing fake time Signed-off-by: Janne Savolainen <janne.savolainen@live.fi> * Introduce reactive now to kludge around global shared state in library Signed-off-by: Janne Savolainen <janne.savolainen@live.fi> * Replace all usages of "now" from mobx-utils with our own kludge to get rid of shared global state between unit tests Signed-off-by: Janne Savolainen <janne.savolainen@live.fi> * Consolidate all usages of advanceTimersByTime to make sure things happening based on timers are run correctly Signed-off-by: Janne Savolainen <janne.savolainen@live.fi> * Fix incorrect expect in test Signed-off-by: Janne Savolainen <janne.savolainen@live.fi> * Enable skipped unit test since prerequisites are done Signed-off-by: Janne Savolainen <janne.savolainen@live.fi>
225 lines
7.7 KiB
TypeScript
225 lines
7.7 KiB
TypeScript
/**
|
|
* 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<CheckForPlatformUpdates>;
|
|
let downloadPlatformUpdateMock: AsyncFnMock<DownloadPlatformUpdate>;
|
|
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",
|
|
},
|
|
},
|
|
],
|
|
]);
|
|
});
|
|
});
|
|
});
|
|
});
|
|
});
|