mirror of
https://github.com/lensapp/lens.git
synced 2025-05-20 05:10:56 +00:00
* Convert runMany and runManySync to use injectManyWithMeta Signed-off-by: Sebastian Malton <sebastian@malton.name> * Fixup type errors due to new Runnable requirements Signed-off-by: Sebastian Malton <sebastian@malton.name> * Add documentation for verifyRunnablesAreDAG Signed-off-by: Sebastian Malton <sebastian@malton.name> * Simplify convertToWithIdWith Signed-off-by: Sebastian Malton <sebastian@malton.name> * Move all utility functions to separate package Signed-off-by: Sebastian Malton <sebastian@malton.name> * Move testing utilities to separate package Signed-off-by: Sebastian Malton <sebastian@malton.name> * Move run-many and run-many-sync to separate package Signed-off-by: Sebastian Malton <sebastian@malton.name> * Replace all internal uses of utilities with new packages Signed-off-by: Sebastian Malton <sebastian@malton.name> * Use new @k8slens/run-many package in core Signed-off-by: Sebastian Malton <sebastian@malton.name> * Add dep to open-lens Signed-off-by: Sebastian Malton <sebastian@malton.name> * Fixup type errors Signed-off-by: Sebastian Malton <sebastian@malton.name> * Fixup uses of @k8slens/test-utils Signed-off-by: Sebastian Malton <sebastian@malton.name> * Fixup getGlobalOverride Signed-off-by: Sebastian Malton <sebastian@malton.name> * Move tests to new package too Signed-off-by: Sebastian Malton <sebastian@malton.name> * Fix type errors Signed-off-by: Sebastian Malton <sebastian@malton.name> * Fixup uses of AsyncResult and autoBind Signed-off-by: Sebastian Malton <sebastian@malton.name> * Fixup remaining import issues Signed-off-by: Sebastian Malton <sebastian@malton.name> * Finial fixups to fix build Signed-off-by: Sebastian Malton <sebastian@malton.name> * Fix lint Signed-off-by: Sebastian Malton <sebastian@malton.name> * Revert moving "testUsingFakeTime" to separate package - This fixes tests Signed-off-by: Sebastian Malton <sebastian@malton.name> * Fix integration tests Signed-off-by: Sebastian Malton <sebastian@malton.name> * Fix unit test failing due to spelling fix Signed-off-by: Sebastian Malton <sebastian@malton.name> --------- Signed-off-by: Sebastian Malton <sebastian@malton.name>
148 lines
5.5 KiB
TypeScript
148 lines
5.5 KiB
TypeScript
/**
|
|
* Copyright (c) OpenLens Authors. All rights reserved.
|
|
* Licensed under MIT License. See LICENSE in root directory for more information.
|
|
*/
|
|
|
|
import type { FSWatcher } from "chokidar";
|
|
import { getDiForUnitTesting } from "../../main/getDiForUnitTesting";
|
|
import extensionDiscoveryInjectable from "../extension-discovery/extension-discovery.injectable";
|
|
import type { ExtensionDiscovery } from "../extension-discovery/extension-discovery";
|
|
import installExtensionInjectable from "../install-extension/install-extension.injectable";
|
|
import directoryForUserDataInjectable from "../../common/app-paths/directory-for-user-data/directory-for-user-data.injectable";
|
|
import { delay } from "@k8slens/utilities";
|
|
import { observable, runInAction, when } from "mobx";
|
|
import readJsonFileInjectable from "../../common/fs/read-json-file.injectable";
|
|
import pathExistsInjectable from "../../common/fs/path-exists.injectable";
|
|
import watchInjectable from "../../common/fs/watch/watch.injectable";
|
|
import extensionApiVersionInjectable from "../../common/vars/extension-api-version.injectable";
|
|
import removePathInjectable from "../../common/fs/remove.injectable";
|
|
import type { JoinPaths } from "../../common/path/join-paths.injectable";
|
|
import joinPathsInjectable from "../../common/path/join-paths.injectable";
|
|
import homeDirectoryPathInjectable from "../../common/os/home-directory-path.injectable";
|
|
import pathExistsSyncInjectable from "../../common/fs/path-exists-sync.injectable";
|
|
import readJsonSyncInjectable from "../../common/fs/read-json-sync.injectable";
|
|
import writeJsonSyncInjectable from "../../common/fs/write-json-sync.injectable";
|
|
|
|
describe("ExtensionDiscovery", () => {
|
|
let extensionDiscovery: ExtensionDiscovery;
|
|
let readJsonFileMock: jest.Mock;
|
|
let pathExistsMock: jest.Mock;
|
|
let watchMock: jest.Mock;
|
|
let joinPaths: JoinPaths;
|
|
let homeDirectoryPath: string;
|
|
|
|
beforeEach(() => {
|
|
const di = getDiForUnitTesting();
|
|
|
|
di.override(directoryForUserDataInjectable, () => "/some-directory-for-user-data");
|
|
di.override(installExtensionInjectable, () => () => Promise.resolve());
|
|
di.override(extensionApiVersionInjectable, () => "5.0.0");
|
|
di.override(pathExistsSyncInjectable, () => () => { throw new Error("tried call pathExistsSync without override"); });
|
|
di.override(readJsonSyncInjectable, () => () => { throw new Error("tried call readJsonSync without override"); });
|
|
di.override(writeJsonSyncInjectable, () => () => { throw new Error("tried call writeJsonSync without override"); });
|
|
|
|
joinPaths = di.inject(joinPathsInjectable);
|
|
homeDirectoryPath = di.inject(homeDirectoryPathInjectable);
|
|
|
|
readJsonFileMock = jest.fn();
|
|
di.override(readJsonFileInjectable, () => readJsonFileMock);
|
|
|
|
pathExistsMock = jest.fn(() => Promise.resolve(true));
|
|
di.override(pathExistsInjectable, () => pathExistsMock);
|
|
|
|
watchMock = jest.fn();
|
|
di.override(watchInjectable, () => watchMock);
|
|
|
|
di.override(removePathInjectable, () => async () => {}); // allow deleting files for now
|
|
|
|
extensionDiscovery = di.inject(extensionDiscoveryInjectable);
|
|
});
|
|
|
|
it("emits add for added extension", async () => {
|
|
const letTestFinish = observable.box(false);
|
|
let addHandler!: (filePath: string) => void;
|
|
|
|
readJsonFileMock.mockImplementation((p) => {
|
|
expect(p).toBe(joinPaths(homeDirectoryPath, ".k8slens/extensions/my-extension/package.json"));
|
|
|
|
return {
|
|
name: "my-extension",
|
|
version: "1.0.0",
|
|
engines: {
|
|
lens: "5.0.0",
|
|
},
|
|
};
|
|
});
|
|
|
|
const mockWatchInstance = {
|
|
on: jest.fn((event: string, handler: typeof addHandler) => {
|
|
if (event === "add") {
|
|
addHandler = handler;
|
|
}
|
|
|
|
return mockWatchInstance;
|
|
}),
|
|
} as unknown as FSWatcher;
|
|
|
|
watchMock.mockImplementationOnce(() => mockWatchInstance);
|
|
|
|
// Need to force isLoaded to be true so that the file watching is started
|
|
extensionDiscovery.isLoaded = true;
|
|
|
|
await extensionDiscovery.watchExtensions();
|
|
|
|
extensionDiscovery.events.on("add", extension => {
|
|
expect(extension).toEqual({
|
|
absolutePath: expect.any(String),
|
|
id: "/some-directory-for-user-data/node_modules/my-extension/package.json",
|
|
isBundled: false,
|
|
isEnabled: false,
|
|
isCompatible: true,
|
|
manifest: {
|
|
name: "my-extension",
|
|
version: "1.0.0",
|
|
engines: {
|
|
lens: "5.0.0",
|
|
},
|
|
},
|
|
manifestPath: "/some-directory-for-user-data/node_modules/my-extension/package.json",
|
|
});
|
|
runInAction(() => letTestFinish.set(true));
|
|
});
|
|
|
|
addHandler(joinPaths(extensionDiscovery.localFolderPath, "/my-extension/package.json"));
|
|
await when(() => letTestFinish.get());
|
|
});
|
|
|
|
it("doesn't emit add for added file under extension", async () => {
|
|
let addHandler!: (filePath: string) => void;
|
|
|
|
const mockWatchInstance = {
|
|
on: jest.fn((event: string, handler: typeof addHandler) => {
|
|
if (event === "add") {
|
|
addHandler = handler;
|
|
}
|
|
|
|
return mockWatchInstance;
|
|
}),
|
|
} as unknown as FSWatcher;
|
|
|
|
watchMock.mockImplementationOnce(() => mockWatchInstance);
|
|
|
|
// Need to force isLoaded to be true so that the file watching is started
|
|
extensionDiscovery.isLoaded = true;
|
|
|
|
await extensionDiscovery.watchExtensions();
|
|
|
|
const onAdd = jest.fn();
|
|
|
|
extensionDiscovery.events.on("add", onAdd);
|
|
|
|
addHandler(joinPaths(extensionDiscovery.localFolderPath, "/my-extension/node_modules/dep/package.json"));
|
|
|
|
await delay(10);
|
|
|
|
expect(onAdd).not.toHaveBeenCalled();
|
|
});
|
|
});
|