From c2eba7c7a67fc725e68b4380e0ac751039ef4cac Mon Sep 17 00:00:00 2001 From: Santamaura Date: Thu, 8 Jun 2023 19:25:55 +0000 Subject: [PATCH] ui: hide tenant dropdown when unneeded This change updates the tenant dropdown so that it will not display if there are fewer than 2 tenants the user has logged in to. If the singular tenant is not the system tenant the dropdown will be visible. Fixes: #104557 Release note (ui change): Hide tenant dropdown when user has logged in to fewer than 2 tenants. If the singular tenant is not the system tenant the dropdown remains visible. --- .../db-console/src/redux/cookies.ts | 1 + .../db-console/src/redux/tenants.ts | 17 ++++++++++ .../tenantDropdown/tenantDropdown.spec.tsx | 34 +++++++++++++++++-- .../tenantDropdown/tenantDropdown.tsx | 9 ++--- 4 files changed, 54 insertions(+), 7 deletions(-) create mode 100644 pkg/ui/workspaces/db-console/src/redux/tenants.ts diff --git a/pkg/ui/workspaces/db-console/src/redux/cookies.ts b/pkg/ui/workspaces/db-console/src/redux/cookies.ts index 972dbef21824..fff159bb696e 100644 --- a/pkg/ui/workspaces/db-console/src/redux/cookies.ts +++ b/pkg/ui/workspaces/db-console/src/redux/cookies.ts @@ -9,6 +9,7 @@ // licenses/APL.txt. export const MULTITENANT_SESSION_COOKIE_NAME = "session"; +export const SYSTEM_TENANT_NAME = "system"; export const getAllCookies = (): Map => { const cookieMap: Map = new Map(); diff --git a/pkg/ui/workspaces/db-console/src/redux/tenants.ts b/pkg/ui/workspaces/db-console/src/redux/tenants.ts new file mode 100644 index 000000000000..d204f95f47ec --- /dev/null +++ b/pkg/ui/workspaces/db-console/src/redux/tenants.ts @@ -0,0 +1,17 @@ +// Copyright 2023 The Cockroach Authors. +// +// Use of this software is governed by the Business Source License +// included in the file licenses/BSL.txt. +// +// As of the Change Date specified in that file, in accordance with +// the Business Source License, use of this software will be governed +// by the Apache License, Version 2.0, included in the file +// licenses/APL.txt. + +// isSystemTenant checks whether the provided tenant name is the +// system tenant. +import { SYSTEM_TENANT_NAME } from "./cookies"; + +export const isSystemTenant = (tenantName: string): boolean => { + return tenantName === SYSTEM_TENANT_NAME; +}; diff --git a/pkg/ui/workspaces/db-console/src/views/app/components/tenantDropdown/tenantDropdown.spec.tsx b/pkg/ui/workspaces/db-console/src/views/app/components/tenantDropdown/tenantDropdown.spec.tsx index 53a9ed880be7..154fb530314c 100644 --- a/pkg/ui/workspaces/db-console/src/views/app/components/tenantDropdown/tenantDropdown.spec.tsx +++ b/pkg/ui/workspaces/db-console/src/views/app/components/tenantDropdown/tenantDropdown.spec.tsx @@ -21,16 +21,32 @@ jest.mock("src/redux/cookies", () => ({ })); describe("TenantDropdown", () => { - it("returns null if there are no tenants in the session cookie", () => { + it("returns null if there's no current tenant", () => { ( selectTenantsFromMultitenantSessionCookie as jest.MockedFn< typeof selectTenantsFromMultitenantSessionCookie > ).mockReturnValueOnce([]); + ( + getCookieValue as jest.MockedFn + ).mockReturnValueOnce(null); + const wrapper = shallow(); + expect(wrapper.isEmptyRender()); + }); + // Mutli-tenant scenarios + it("returns null if there are no tenants or less than 2 tenants in the session cookie", () => { + ( + selectTenantsFromMultitenantSessionCookie as jest.MockedFn< + typeof selectTenantsFromMultitenantSessionCookie + > + ).mockReturnValueOnce(["system"]); + ( + getCookieValue as jest.MockedFn + ).mockReturnValueOnce("system"); const wrapper = shallow(); expect(wrapper.isEmptyRender()); }); - it("returns a dropdown list of tenant options if there are tenant in the session cookie", () => { + it("returns a dropdown list of tenant options if there are multiple tenant in the session cookie", () => { ( selectTenantsFromMultitenantSessionCookie as jest.MockedFn< typeof selectTenantsFromMultitenantSessionCookie @@ -40,6 +56,18 @@ describe("TenantDropdown", () => { getCookieValue as jest.MockedFn ).mockReturnValueOnce("system"); const wrapper = shallow(); - expect(wrapper.find({ children: "Tenant system" }).length).toEqual(1); + expect(wrapper.find({ children: "Tenant: system" }).length).toEqual(1); + }); + it("returns a dropdown if the there is a single tenant option but isn't system tenant", () => { + ( + selectTenantsFromMultitenantSessionCookie as jest.MockedFn< + typeof selectTenantsFromMultitenantSessionCookie + > + ).mockReturnValueOnce(["app"]); + ( + getCookieValue as jest.MockedFn + ).mockReturnValueOnce("app"); + const wrapper = shallow(); + expect(wrapper.find({ children: "Tenant: app" }).length).toEqual(1); }); }); diff --git a/pkg/ui/workspaces/db-console/src/views/app/components/tenantDropdown/tenantDropdown.tsx b/pkg/ui/workspaces/db-console/src/views/app/components/tenantDropdown/tenantDropdown.tsx index 468f276f3f87..bfe021443b4d 100644 --- a/pkg/ui/workspaces/db-console/src/views/app/components/tenantDropdown/tenantDropdown.tsx +++ b/pkg/ui/workspaces/db-console/src/views/app/components/tenantDropdown/tenantDropdown.tsx @@ -16,6 +16,7 @@ import React from "react"; import { Dropdown } from "@cockroachlabs/cluster-ui"; import ErrorBoundary from "../errorMessage/errorBoundary"; import "./tenantDropdown.styl"; +import { isSystemTenant } from "src/redux/tenants"; const tenantIDKey = "tenant"; @@ -26,7 +27,7 @@ const TenantDropdown = () => { const createDropdownItems = () => { return ( tenants?.map(tenantID => { - return { name: "Tenant " + tenantID, value: tenantID }; + return { name: "Tenant: " + tenantID, value: tenantID }; }) || [] ); }; @@ -38,7 +39,7 @@ const TenantDropdown = () => { } }; - if (tenants.length == 0) { + if (!currentTenant || (tenants.length < 2 && isSystemTenant(currentTenant))) { return null; } @@ -46,9 +47,9 @@ const TenantDropdown = () => { onTenantChange(tenantID)} + onChange={(tenantID: string) => onTenantChange(tenantID)} > -
{"Tenant " + currentTenant}
+
{"Tenant: " + currentTenant}
);