Skip to content

Commit

Permalink
Use ClusterTypeLabel in other views
Browse files Browse the repository at this point in the history
  • Loading branch information
arbulu89 committed Jul 10, 2024
1 parent 8490cbe commit 6e9675e
Show file tree
Hide file tree
Showing 9 changed files with 131 additions and 12 deletions.
14 changes: 9 additions & 5 deletions assets/js/common/ClusterInfoBox/ClusterInfoBox.jsx
Original file line number Diff line number Diff line change
@@ -1,12 +1,10 @@
import React from 'react';

import { getClusterTypeLabel } from '@lib/model/clusters';

import ListView from '@common/ListView';
import ProviderLabel from '@common/ProviderLabel';
import ClusterTypeLabel from '@common/ClusterTypeLabel';

// eslint-disable-next-line import/prefer-default-export
function ClusterInfoBox({ haScenario, provider }) {
function ClusterInfoBox({ haScenario, provider, architectureType }) {
return (
<div className="tn-cluster-details w-full my-6 mr-4 bg-white shadow rounded-lg px-8 py-4">
<ListView
Expand All @@ -16,7 +14,13 @@ function ClusterInfoBox({ haScenario, provider }) {
data={[
{
title: 'HA Scenario',
content: getClusterTypeLabel(haScenario),
content: haScenario,
render: (content) => (
<ClusterTypeLabel
clusterType={content}
architectureType={architectureType}
/>
),
},
{
title: 'Provider',
Expand Down
31 changes: 30 additions & 1 deletion assets/js/common/ClusterInfoBox/ClusterInfoBox.test.jsx
Original file line number Diff line number Diff line change
@@ -1,6 +1,10 @@
import React from 'react';
import { render } from '@testing-library/react';
import { screen, render } from '@testing-library/react';
import '@testing-library/jest-dom';
import userEvent from '@testing-library/user-event';

import { renderWithRouter } from '@lib/test-utils';

import ClusterInfoBox from './ClusterInfoBox';

describe('Cluster Info Box', () => {
Expand Down Expand Up @@ -62,4 +66,29 @@ describe('Cluster Info Box', () => {
expect(getByText(haScenarioText)).toBeTruthy();
});
});

it.each([
{ archType: 'classic', tooltip: 'Classic architecture' },
{ archType: 'angi', tooltip: 'Angi architecture' },
])('should display architecture type icon', async ({ archType, tooltip }) => {
const user = userEvent.setup();

renderWithRouter(
<ClusterInfoBox
haScenario="hana_scale_up"
provider="azure"
architectureType={archType}
/>
);

const icon = screen.getByTestId('eos-svg-component');

await user.hover(icon);
expect(screen.getByText(tooltip, { exact: false })).toBeInTheDocument();
});

it('should not display architecture type icon if architecture is unknown', () => {
render(<ClusterInfoBox haScenario="ascs_ers" provider="azure" />);
expect(screen.queryByTestId('eos-svg-component')).not.toBeInTheDocument();
});
});
4 changes: 4 additions & 0 deletions assets/js/lib/test-utils/factories/clusters.js
Original file line number Diff line number Diff line change
Expand Up @@ -17,6 +17,9 @@ const hanaStatus = () => faker.helpers.arrayElement(['Primary', 'Failed']);

const ascsErsRole = () => faker.helpers.arrayElement(['ascs', 'ers']);

const hanaArchitectureTypeEnum = () =>
faker.helpers.arrayElement(['classic', 'angi']);

export const sbdDevicesFactory = Factory.define(() => ({
device: faker.system.filePath(),
status: faker.helpers.arrayElement(['healthy', 'unhealthy']),
Expand Down Expand Up @@ -72,6 +75,7 @@ export const hanaClusterDetailsFactory = Factory.define(() => {
system_replication_mode: 'sync',
system_replication_operation_mode: 'logreplay',
maintenance_mode: false,
architecture_type: hanaArchitectureTypeEnum(),
};
});

Expand Down
4 changes: 3 additions & 1 deletion assets/js/pages/ClusterDetails/ClusterDetailsPage.jsx
Original file line number Diff line number Diff line change
Expand Up @@ -32,6 +32,7 @@ export function ClusterDetailsPage() {

const provider = get(cluster, 'provider');
const type = get(cluster, 'type');
const archType = get(cluster, 'details.architecture_type');

const catalog = useSelector(getCatalog());

Expand All @@ -51,13 +52,14 @@ export function ClusterDetailsPage() {
cluster_type: type,
ensa_version: ensaVersion,
filesystem_type: filesystemType,
architecture_type: archType,
});

if (provider && type) {
dispatch(updateCatalog(env));
dispatch(updateLastExecution(clusterID));
}
}, [dispatch, provider, type, ensaVersion, filesystemType]);
}, [dispatch, provider, type, ensaVersion, filesystemType, archType]);

const clusterHosts = useSelector((state) =>
getClusterHosts(state, clusterID)
Expand Down
10 changes: 8 additions & 2 deletions assets/js/pages/ClusterDetails/HanaClusterDetails.jsx
Original file line number Diff line number Diff line change
Expand Up @@ -2,14 +2,14 @@ import React from 'react';
import { get, capitalize, sortBy } from 'lodash';
import classNames from 'classnames';

import { getClusterTypeLabel } from '@lib/model/clusters';
import { RUNNING_STATES } from '@state/lastExecutions';

import BackButton from '@common/BackButton';
import Button from '@common/Button';
import ListView from '@common/ListView';
import PageHeader from '@common/PageHeader';
import ProviderLabel from '@common/ProviderLabel';
import ClusterTypeLabel from '@common/ClusterTypeLabel';
import SapSystemLink from '@common/SapSystemLink';
import Tooltip from '@common/Tooltip';
import DisabledGuard from '@common/DisabledGuard';
Expand Down Expand Up @@ -162,7 +162,13 @@ function HanaClusterDetails({
},
{
title: 'Cluster type',
content: getClusterTypeLabel(clusterType),
content: clusterType,
render: (content) => (
<ClusterTypeLabel
clusterType={content}
architectureType={details.architecture_type}
/>
),
},
{
title: 'Cluster maintenance',
Expand Down
16 changes: 15 additions & 1 deletion assets/js/pages/ClusterDetails/HanaClusterDetails.stories.jsx
Original file line number Diff line number Diff line change
Expand Up @@ -27,11 +27,15 @@ const {
provider,
cib_last_written: cibLastWritten,
details,
} = clusterFactory.build({ type: 'hana_scale_up' });
} = clusterFactory.build({
type: 'hana_scale_up',
details: { architecture_type: 'classic' },
});

const scaleOutSites = hanaClusterSiteFactory.buildList(2);

const scaleOutDetails = hanaClusterDetailsFactory.build({
architecture_type: 'classic',
sites: scaleOutSites,
nodes: [
hanaClusterDetailsNodesFactory.build({
Expand Down Expand Up @@ -213,3 +217,13 @@ export const WithNoSBDDevices = {
},
},
};

export const AngiArchitecture = {
args: {
...Hana.args,
details: {
...Hana.args.details,
architecture_type: 'angi',
},
},
};
47 changes: 47 additions & 0 deletions assets/js/pages/ClusterDetails/HanaClusterDetails.test.jsx
Original file line number Diff line number Diff line change
Expand Up @@ -466,6 +466,53 @@ describe('HanaClusterDetails component', () => {
}
);

it.each([
{ arch: 'angi', tooltip: 'Angi architecture' },
{ arch: 'classic', tooltip: 'Classic architecture' },
])(
'should show cluster type with $arch architecture',
async ({ arch, tooltip }) => {
const user = userEvent.setup();

const {
clusterID,
clusterName,
cib_last_written: cibLastWritten,
type: clusterType,
sid,
provider,
details,
} = clusterFactory.build({
type: 'hana_scale_up',
details: { architecture_type: arch },
});

const hosts = hostFactory.buildList(2, { cluster_id: clusterID });

renderWithRouter(
<HanaClusterDetails
clusterID={clusterID}
clusterName={clusterName}
selectedChecks={[]}
hasSelectedChecks={false}
hosts={hosts}
clusterType={clusterType}
cibLastWritten={cibLastWritten}
sid={sid}
provider={provider}
sapSystems={[]}
details={details}
lastExecution={null}
userAbilities={userAbilities}
/>
);

const icon = screen.getByText('HANA Scale Up').children.item(0);
await user.hover(icon);
expect(screen.getByText(tooltip, { exact: false })).toBeInTheDocument();
}
);

describe('forbidden actions', () => {
it('should disable the check execution button when the user abilities are not compatible', async () => {
const user = userEvent.setup();
Expand Down
8 changes: 7 additions & 1 deletion assets/js/pages/ClusterSettingsPage/ClusterSettingsPage.jsx
Original file line number Diff line number Diff line change
Expand Up @@ -78,6 +78,7 @@ function ClusterSettingsPage() {

const provider = get(cluster, 'provider');
const type = get(cluster, 'type');
const archType = get(cluster, 'details.architecture_type');

const refreshCatalog = () => {
const env = buildEnv({
Expand All @@ -86,6 +87,7 @@ function ClusterSettingsPage() {
cluster_type: type,
ensa_version: ensaVersion,
filesystem_type: filesystemType,
architecture_type: archType,
});

dispatch(updateCatalog(env));
Expand Down Expand Up @@ -130,7 +132,11 @@ function ClusterSettingsPage() {
onStartExecution={requestChecksExecution}
/>
{catalogBanner[provider]}
<ClusterInfoBox haScenario={type} provider={provider} />
<ClusterInfoBox
haScenario={type}
provider={provider}
architectureType={archType}
/>
<ChecksSelection
catalog={catalog}
catalogError={catalogError}
Expand Down
9 changes: 8 additions & 1 deletion assets/js/pages/ExecutionResults/TargetInfoBox.jsx
Original file line number Diff line number Diff line change
@@ -1,15 +1,22 @@
import React from 'react';
import { get } from 'lodash';

import { TARGET_CLUSTER, TARGET_HOST } from '@lib/model';

import ClusterInfoBox from '@common/ClusterInfoBox';
import HostInfoBox from '@common/HostInfoBox';

function TargetInfoBox({ targetType, target }) {
const archType = get(target, 'details.architecture_type');

switch (targetType) {
case TARGET_CLUSTER:
return (
<ClusterInfoBox haScenario={target.type} provider={target.provider} />
<ClusterInfoBox
haScenario={target.type}
provider={target.provider}
architectureType={archType}
/>
);
case TARGET_HOST:
return (
Expand Down

0 comments on commit 6e9675e

Please sign in to comment.