mirror of
https://github.com/lensapp/lens.git
synced 2025-05-20 05:10:56 +00:00
127 lines
3.8 KiB
TypeScript
127 lines
3.8 KiB
TypeScript
/**
|
|
* Copyright (c) OpenLens Authors. All rights reserved.
|
|
* Licensed under MIT License. See LICENSE in root directory for more information.
|
|
*/
|
|
import type { RenderResult } from "@testing-library/react";
|
|
import type { ApplicationBuilder } from "../../../../renderer/components/test-utils/get-application-builder";
|
|
import { getApplicationBuilder } from "../../../../renderer/components/test-utils/get-application-builder";
|
|
import { getExtensionFakeFor } from "../../../../renderer/components/test-utils/get-extension-fake";
|
|
import { getInjectable } from "@ogre-tools/injectable";
|
|
import { frontEndRouteInjectionToken } from "../../../../common/front-end-routing/front-end-route-injection-token";
|
|
import type { IObservableValue } from "mobx";
|
|
import { observable, runInAction, computed } from "mobx";
|
|
import React from "react";
|
|
import { navigateToRouteInjectionToken } from "../../../../common/front-end-routing/navigate-to-route-injection-token";
|
|
import { routeSpecificComponentInjectionToken } from "../../../../renderer/routes/route-specific-component-injection-token";
|
|
import { KubeObject } from "../../../../common/k8s-api/kube-object";
|
|
import { KubeObjectMenu } from "../../../../renderer/components/kube-object-menu";
|
|
|
|
describe("reactively hide kube object menu item", () => {
|
|
let builder: ApplicationBuilder;
|
|
let rendered: RenderResult;
|
|
let someObservable: IObservableValue<boolean>;
|
|
|
|
beforeEach(async () => {
|
|
builder = getApplicationBuilder();
|
|
|
|
const rendererDi = builder.dis.rendererDi;
|
|
|
|
rendererDi.register(testRouteInjectable, testRouteComponentInjectable);
|
|
|
|
builder.setEnvironmentToClusterFrame();
|
|
|
|
const getExtensionFake = getExtensionFakeFor(builder);
|
|
|
|
someObservable = observable.box(false);
|
|
|
|
const testExtension = getExtensionFake({
|
|
id: "test-extension-id",
|
|
name: "test-extension",
|
|
|
|
rendererOptions: {
|
|
kubeObjectMenuItems: [
|
|
{
|
|
kind: "some-kind",
|
|
apiVersions: ["some-api-version"],
|
|
components: {
|
|
MenuItem: () => (
|
|
<div data-testid="some-kube-object-menu-item">Some menu item</div>
|
|
),
|
|
},
|
|
|
|
visible: computed(() => someObservable.get()),
|
|
},
|
|
],
|
|
},
|
|
});
|
|
|
|
rendered = await builder.render();
|
|
|
|
const navigateToRoute = rendererDi.inject(navigateToRouteInjectionToken);
|
|
const testRoute = rendererDi.inject(testRouteInjectable);
|
|
|
|
navigateToRoute(testRoute);
|
|
|
|
builder.extensions.enable(testExtension);
|
|
});
|
|
|
|
it("does not show the kube object menu item", () => {
|
|
const actual = rendered.queryByTestId("some-kube-object-menu-item");
|
|
|
|
expect(actual).not.toBeInTheDocument();
|
|
});
|
|
|
|
it("given item should be shown, shows the kube object menu item", () => {
|
|
runInAction(() => {
|
|
someObservable.set(true);
|
|
});
|
|
|
|
const actual = rendered.queryByTestId("some-kube-object-menu-item");
|
|
|
|
expect(actual).toBeInTheDocument();
|
|
});
|
|
});
|
|
|
|
const testRouteInjectable = getInjectable({
|
|
id: "test-route",
|
|
|
|
instantiate: () => ({
|
|
path: "/test-route",
|
|
clusterFrame: true,
|
|
isEnabled: computed(() => true),
|
|
}),
|
|
|
|
injectionToken: frontEndRouteInjectionToken,
|
|
});
|
|
|
|
const testRouteComponentInjectable = getInjectable({
|
|
id: "test-route-component",
|
|
|
|
instantiate: (di) => ({
|
|
route: di.inject(testRouteInjectable),
|
|
|
|
Component: () => (
|
|
<KubeObjectMenu
|
|
toolbar={true}
|
|
object={getKubeObjectStub("some-kind", "some-api-version")}
|
|
/>
|
|
),
|
|
}),
|
|
|
|
injectionToken: routeSpecificComponentInjectionToken,
|
|
});
|
|
|
|
const getKubeObjectStub = (kind: string, apiVersion: string) =>
|
|
KubeObject.create({
|
|
apiVersion,
|
|
kind,
|
|
metadata: {
|
|
uid: "some-uid",
|
|
name: "some-name",
|
|
resourceVersion: "some-resource-version",
|
|
namespace: "some-namespace",
|
|
selfLink: "",
|
|
},
|
|
});
|
|
|