From 15d1ce3ae0eb77de3a5aeedcae94be76de15bbdd Mon Sep 17 00:00:00 2001
From: Hinson Chan <68029599+flatypus@users.noreply.github.com>
Date: Mon, 2 Oct 2023 09:12:14 -0700
Subject: [PATCH] fix: allow index usageCount to be 0 and display 'data
unavailable' message if user cannot view stats COMPASS-7290 (#4930)
---
.../regular-indexes-table/usage-field.spec.tsx | 14 +++++++++++---
.../regular-indexes-table/usage-field.tsx | 14 ++++++++++----
packages/data-service/src/index-detail-helper.ts | 3 +--
3 files changed, 22 insertions(+), 9 deletions(-)
diff --git a/packages/compass-indexes/src/components/regular-indexes-table/usage-field.spec.tsx b/packages/compass-indexes/src/components/regular-indexes-table/usage-field.spec.tsx
index 375b950391f..2a6fd0ffa8d 100644
--- a/packages/compass-indexes/src/components/regular-indexes-table/usage-field.spec.tsx
+++ b/packages/compass-indexes/src/components/regular-indexes-table/usage-field.spec.tsx
@@ -17,10 +17,15 @@ describe('UsageField', function () {
expect(screen.getByText(renderedText)).to.exist;
});
- it('renders zero when usage is not defined', function () {
- render();
+ it('renders usage unavailable when usage is not defined', function () {
+ render();
+ const renderedText = 'Usage data unavailable';
+ expect(screen.getByText(renderedText)).to.exist;
+ });
- const renderedText = `0`;
+ it('renders zero when usage is zero', function () {
+ render();
+ const renderedText = '0';
expect(screen.getByText(renderedText)).to.exist;
});
@@ -37,6 +42,9 @@ describe('UsageField', function () {
'Either the server does not support the $indexStats command' +
' or the user is not authorized to execute it.'
);
+ expect(getUsageTooltip(0)).to.equal(
+ '0 index hits since index creation or last server restart'
+ );
expect(getUsageTooltip(30)).to.equal(
'30 index hits since index creation or last server restart'
);
diff --git a/packages/compass-indexes/src/components/regular-indexes-table/usage-field.tsx b/packages/compass-indexes/src/components/regular-indexes-table/usage-field.tsx
index 9145e122dea..f6e9706d36b 100644
--- a/packages/compass-indexes/src/components/regular-indexes-table/usage-field.tsx
+++ b/packages/compass-indexes/src/components/regular-indexes-table/usage-field.tsx
@@ -6,7 +6,7 @@ const NO_USAGE_STATS =
' or the user is not authorized to execute it.';
export const getUsageTooltip = (usage?: number): string => {
- return !usage
+ return usage === null || usage === undefined
? NO_USAGE_STATS
: `${usage} index hits since index creation or last server restart`;
};
@@ -27,9 +27,15 @@ const UsageField: React.FunctionComponent = ({
{children}
- {usage || 0}
- {nbsp}
- <>{since ? `(since ${since.toDateString()})` : ''}>
+ {usage === null || usage === undefined ? (
+ 'Usage data unavailable'
+ ) : (
+ <>
+ {usage}
+ {nbsp}
+ {since ? `(since ${since.toDateString()})` : ''}
+ >
+ )}
)}
diff --git a/packages/data-service/src/index-detail-helper.ts b/packages/data-service/src/index-detail-helper.ts
index f77080d76b1..6674319c03d 100644
--- a/packages/data-service/src/index-detail-helper.ts
+++ b/packages/data-service/src/index-detail-helper.ts
@@ -9,7 +9,7 @@ export type IndexInfo = {
export type IndexStats = {
name: string;
- usageCount: number;
+ usageCount?: number;
usageHost?: string;
usageSince?: Date;
};
@@ -124,7 +124,6 @@ export function createIndexDefinition(
): IndexDefinition {
indexStats ??= {
name,
- usageCount: 0,
usageHost: '',
usageSince: new Date(0),
};