From 8cf6d51650bb19d73928a992009102d20aabfce1 Mon Sep 17 00:00:00 2001 From: Jim Ehrismann <40840436+jim-docker@users.noreply.github.com> Date: Fri, 4 Mar 2022 14:16:11 -0500 Subject: [PATCH] Release/v5.4.1 (#4969) * Fix api-manager kubeobject types (#4959) * loosen api-manager kubeobject types Signed-off-by: Jari Kolehmainen * less any Signed-off-by: Jari Kolehmainen * less any Signed-off-by: Jari Kolehmainen * fix typings Signed-off-by: Jari Kolehmainen * fix typings Signed-off-by: Jari Kolehmainen * Fix unselect. Add unit tests (#4961) * Fix unselect. Add unit tests Signed-off-by: DmitriyNoa * Cleanup Signed-off-by: DmitriyNoa * Add additional test for undefined Signed-off-by: DmitriyNoa * quick fix for logs not showing in tabs after first tab (#4964) * quick fix for logs not showing in tabs after first tab Signed-off-by: Jim Ehrismann * proper fix Signed-off-by: Jim Ehrismann * fix test file for DiContainer reference Signed-off-by: Jim Ehrismann * release v5.4.1 Signed-off-by: Jim Ehrismann Co-authored-by: Jari Kolehmainen Co-authored-by: Dmitriy Noa --- package.json | 2 +- src/common/k8s-api/api-manager.ts | 8 +- src/renderer/components/dock/logs/view.tsx | 2 +- .../components/select/select.test.tsx | 157 ++++++++++++++++++ src/renderer/components/select/select.tsx | 2 +- 5 files changed, 164 insertions(+), 7 deletions(-) create mode 100644 src/renderer/components/select/select.test.tsx diff --git a/package.json b/package.json index 59fa5e6e16..d4f9bea92b 100644 --- a/package.json +++ b/package.json @@ -3,7 +3,7 @@ "productName": "OpenLens", "description": "OpenLens - Open Source IDE for Kubernetes", "homepage": "https://github.com/lensapp/lens", - "version": "5.4.0", + "version": "5.4.1", "main": "static/build/main.js", "copyright": "© 2021 OpenLens Authors", "license": "MIT", diff --git a/src/common/k8s-api/api-manager.ts b/src/common/k8s-api/api-manager.ts index d392673364..728ac8b61d 100644 --- a/src/common/k8s-api/api-manager.ts +++ b/src/common/k8s-api/api-manager.ts @@ -32,7 +32,7 @@ export class ApiManager { return iter.find(this.apis.values(), api => api.kind === kind && api.apiVersionWithGroup === apiVersion); } - registerApi(apiBase: string, api: KubeApi) { + registerApi(apiBase: string, api: KubeApi) { if (!api.apiBase) return; if (!this.apis.has(apiBase)) { @@ -46,13 +46,13 @@ export class ApiManager { } } - protected resolveApi(api?: string | KubeApi): KubeApi | undefined { + protected resolveApi(api?: string | KubeApi): KubeApi | undefined { if (!api) { return undefined; } if (typeof api === "string") { - return this.getApi(api) as KubeApi; + return this.getApi(api) as KubeApi; } return api; @@ -69,7 +69,7 @@ export class ApiManager { } @action - registerStore(store: KubeObjectStore, apis: KubeApi[] = [store.api]) { + registerStore(store: KubeObjectStore, apis: KubeApi[] = [store.api]) { apis.filter(Boolean).forEach(api => { if (api.apiBase) this.stores.set(api.apiBase, store); }); diff --git a/src/renderer/components/dock/logs/view.tsx b/src/renderer/components/dock/logs/view.tsx index c73933b12f..0f9069dafa 100644 --- a/src/renderer/components/dock/logs/view.tsx +++ b/src/renderer/components/dock/logs/view.tsx @@ -39,7 +39,7 @@ const NonInjectedLogsDockTab = observer(({ className, tab, model, subscribeStore model.reloadLogs(); return model.stopLoadingLogs; - }, []); + }, [tab.id]); useEffect(() => subscribeStores([ podsStore, ], { diff --git a/src/renderer/components/select/select.test.tsx b/src/renderer/components/select/select.test.tsx new file mode 100644 index 0000000000..7819919d9b --- /dev/null +++ b/src/renderer/components/select/select.test.tsx @@ -0,0 +1,157 @@ +/** + * Copyright (c) OpenLens Authors. All rights reserved. + * Licensed under MIT License. See LICENSE in root directory for more information. + */ +import React from "react"; +import "@testing-library/jest-dom/extend-expect"; +import { Select } from "./select"; +import { UserStore } from "../../../common/user-store"; +import { ThemeStore } from "../../theme.store"; +import { getDiForUnitTesting } from "../../getDiForUnitTesting"; +import type { DependencyInjectionContainer } from "@ogre-tools/injectable"; +import { DiRender, renderFor } from "../test-utils/renderFor"; +import mockFs from "mock-fs"; +import directoryForUserDataInjectable + from "../../../common/app-paths/directory-for-user-data/directory-for-user-data.injectable"; +import rendererExtensionsInjectable from "../../../extensions/renderer-extensions.injectable"; +import { computed } from "mobx"; +import type { LensRendererExtension } from "../../../extensions/lens-renderer-extension"; + + +describe("); + + expect(container).toBeInstanceOf(HTMLElement); + }); + + it("should show selected option", async () => { + const options = [ + { + label: "Option one label", + value: "optionOneValue", + }, + { + label: "Option two label", + value: "optionTwoValue", + }, + ]; + + const onChange = jest.fn(); + + const { container } = render(); + const selectedValueContainer = container.querySelector(".Select__single-value"); + + expect(selectedValueContainer.textContent).toBe(options[0].label); + + rerender(); + const selectedValueContainer = container.querySelector(".Select__single-value"); + + expect(selectedValueContainer.textContent).toBe(options[0].label); + + rerender(); + const selectedValueContainer = container.querySelector(".Select__single-value"); + + expect(selectedValueContainer.textContent).toBe(options[0].label); + + rerender(