Skip to content

Commit

Permalink
refactoring (support ODF in any Namespace)
Browse files Browse the repository at this point in the history
  • Loading branch information
SanjalKatiyar committed Nov 17, 2023
1 parent e71d640 commit 712f0be
Show file tree
Hide file tree
Showing 129 changed files with 1,937 additions and 1,413 deletions.
1 change: 1 addition & 0 deletions package.json
Original file line number Diff line number Diff line change
Expand Up @@ -108,6 +108,7 @@
"ts-loader": "^9.4.1",
"ts-node": "5.0.1",
"tsm": "^2.3.0",
"typesafe-actions": "^4.2.1",
"typescript": "^4.8",
"victory-core": "^35.4.4",
"webpack": "5.74.0",
Expand Down
Original file line number Diff line number Diff line change
@@ -1,4 +1,5 @@
import * as React from 'react';
import { useOprInstallNamespaceSelector } from '@odf/core/redux';
import { PVC_PROVISIONER_ANNOTATION } from '@odf/ocs/constants';
import {
eventsResource,
Expand Down Expand Up @@ -48,6 +49,8 @@ const getClientOperatorSubscription = (
) as SubscriptionKind;

const RecentEvent: React.FC = () => {
const { oprInstallNs } = useOprInstallNamespaceSelector();

const [pvcs, pvcLoaded, pvcLoadError] =
useK8sWatchResource<PersistentVolumeClaimKind[]>(pvcResource);
const [events, eventsLoaded, eventsLoadError] =
Expand All @@ -61,8 +64,8 @@ const RecentEvent: React.FC = () => {
const memoizedPVCNames = useDeepCompareMemoize(validPVC, true);

const clientEventsFilter = React.useCallback(
() => isPersistentStorageEvent(memoizedPVCNames),
[memoizedPVCNames]
() => isPersistentStorageEvent(memoizedPVCNames, oprInstallNs),
[memoizedPVCNames, oprInstallNs]
);

const eventObject = {
Expand Down
2 changes: 1 addition & 1 deletion packages/ibm/system-connection-details.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -166,9 +166,9 @@ export const createFlashSystemPayload: CreatePayload<FlashSystemState> = ({
systemName,
state,
model,
namespace,
storageClassName,
}) => {
const namespace = 'openshift-storage';
const defaultFilesystem = 'ext4';
const defaultVolumeMode = 'thick';
const defaultVolumePrefix = 'odf';
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -167,6 +167,7 @@ export const CreateDRPolicy: React.FC<ReRouteResourceProps> = ({
clusterName: cluster?.name,
storageClusterRef: {
name: cluster.storageClusterName,
// ToDo (epic 4422): Need to update this as per ConfigMap/ClusterClaim (whichever us decided) JSON output
namespace: CEPH_STORAGE_NAMESPACE,
},
})),
Expand Down
2 changes: 2 additions & 0 deletions packages/mco/components/mco-dashboard/queries.ts
Original file line number Diff line number Diff line change
Expand Up @@ -26,6 +26,7 @@ export const LAST_SYNC_TIME_QUERY = 'ramen_sync_duration_seconds';
export const getLastSyncPerClusterQuery = () =>
`${LAST_SYNC_TIME_QUERY}{${DRPC_OBJECT_TYPE}, ${RAMEN_HUB_OPERATOR_METRICS_SERVICE}}`;

// ToDo (epic 4422): Need to update as per updates in the metrics
export const CAPACITY_QUERIES = {
[StorageDashboard.TOTAL_CAPACITY_FILE_BLOCK]: `(label_replace(odf_system_map{target_namespace="openshift-storage"} , "managedBy", "$1", "target_name", "(.*)")) * on (namespace, managedBy, cluster) group_right(storage_system, target_kind) ${TOTAL_CAPACITY_FILE_BLOCK_METRIC}`,
[StorageDashboard.USED_CAPACITY_FILE_BLOCK]: `(label_replace(odf_system_map{target_namespace="openshift-storage"} , "managedBy", "$1", "target_name", "(.*)")) * on (namespace, managedBy, cluster) group_right(storage_system, target_kind) ${USED_CAPACITY_FILE_BLOCK_METRIC}`,
Expand All @@ -43,6 +44,7 @@ export const getRBDSnapshotUtilizationQuery = (
return queries[queryName];
};

// ToDo (epic 4422): Need to update as per updates in the metrics
export const STATUS_QUERIES = {
[StorageDashboard.SYSTEM_HEALTH]: `(label_replace(odf_system_map{target_namespace="openshift-storage"} , "managedBy", "$1", "target_name", "(.*)")) * on (namespace, managedBy, cluster) group_right(storage_system, target_kind) ${SYSTEM_HEALTH_METRIC}`,
[StorageDashboard.HEALTH]: SYSTEM_HEALTH_METRIC,
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -273,6 +273,7 @@ const appResources2: ArgoApplicationSetResourceKind = {
};

const onClose = jest.fn();

jest.mock('@odf/mco/hooks/disaster-recovery', () => ({
__esModule: true,
useDisasterRecoveryResourceWatch: jest.fn(() => {
Expand All @@ -283,6 +284,7 @@ jest.mock('@odf/mco/hooks/disaster-recovery', () => ({
}
}),
}));

jest.mock('@odf/mco/hooks/argo-application-set', () => ({
__esModule: true,
useArgoApplicationSetResourceWatch: jest.fn(() => {
Expand All @@ -293,6 +295,7 @@ jest.mock('@odf/mco/hooks/argo-application-set', () => ({
}
}),
}));

jest.mock('../utils/k8s-utils', () => ({
unAssignPromises: jest.fn(() => [Promise.resolve({ data: {} })]),
}));
Expand Down
31 changes: 17 additions & 14 deletions packages/ocs/block-pool/BlockPoolDetailsPage.tsx
Original file line number Diff line number Diff line change
@@ -1,14 +1,13 @@
import * as React from 'react';
import { useSafeK8sWatchResource } from '@odf/core/hooks';
import { useOprInstallNamespaceSelector } from '@odf/core/redux';
import DetailsPage from '@odf/shared/details-page/DetailsPage';
import { LoadingBox } from '@odf/shared/generic/status-box';
import { Kebab } from '@odf/shared/kebab/kebab';
import { ModalKeys } from '@odf/shared/modals/types';
import { useCustomTranslation } from '@odf/shared/useCustomTranslationHook';
import { referenceForModel } from '@odf/shared/utils';
import { EventStreamWrapped, YAMLEditorWrapped } from '@odf/shared/utils/Tabs';
import { useK8sWatchResource } from '@openshift-console/dynamic-plugin-sdk';
import { RouteComponentProps, useLocation } from 'react-router-dom';
import { CEPH_NS } from '../constants';
import { BlockPoolDashboard } from '../dashboards/block-pool/block-pool-dashboard';
import { CephBlockPoolModel, CephClusterModel } from '../models';
import { StoragePoolKind } from '../types';
Expand All @@ -33,12 +32,16 @@ export const BlockPoolDetailsPage: React.FC<BlockPoolDetailsPageProps> = ({
const location = useLocation();
const kind = referenceForModel(CephBlockPoolModel);

const [resource, loaded] = useK8sWatchResource<StoragePoolKind>({
kind,
name: poolName,
namespace: CEPH_NS,
isList: false,
});
const { oprInstallNs, isOprNsLoaded, oprNsLoadError } =
useOprInstallNamespaceSelector();

const [resource, loaded, loadError] =
useSafeK8sWatchResource<StoragePoolKind>((ns: string) => ({
kind,
name: poolName,
namespace: ns,
isList: false,
}));

const breadcrumbs = [
{
Expand All @@ -62,7 +65,7 @@ export const BlockPoolDetailsPage: React.FC<BlockPoolDetailsPageProps> = ({
extraProps={{
resource,
resourceModel: CephBlockPoolModel,
namespace: CEPH_NS,
namespace: oprInstallNs,
}}
customKebabItems={[
{
Expand All @@ -82,12 +85,12 @@ export const BlockPoolDetailsPage: React.FC<BlockPoolDetailsPageProps> = ({
]}
/>
);
}, [resource, t]);
}, [resource, oprInstallNs, t]);

return !loaded ? (
<LoadingBox />
) : (
return (
<DetailsPage
loaded={loaded && isOprNsLoaded}
loadError={loadError || oprNsLoadError}
breadcrumbs={breadcrumbs}
actions={actions}
resourceModel={CephBlockPoolModel}
Expand Down
76 changes: 48 additions & 28 deletions packages/ocs/block-pool/BlockPoolListPage.tsx
Original file line number Diff line number Diff line change
@@ -1,4 +1,6 @@
import * as React from 'react';
import { useSafeK8sWatchResources } from '@odf/core/hooks';
import { useOprInstallNamespaceSelector } from '@odf/core/redux';
import { healthStateMapping } from '@odf/shared/dashboards/status-card/states';
import {
useCustomPrometheusPoll,
Expand All @@ -15,7 +17,11 @@ import {
CephClusterKind,
} from '@odf/shared/types';
import { useCustomTranslation } from '@odf/shared/useCustomTranslationHook';
import { humanizeBinaryBytes, referenceForModel } from '@odf/shared/utils';
import {
humanizeBinaryBytes,
referenceForModel,
getValidPrometheusPollObj,
} from '@odf/shared/utils';
import {
ListPageBody,
ListPageCreateLink,
Expand All @@ -26,7 +32,7 @@ import {
TableColumn,
TableData,
useActiveColumns,
useK8sWatchResources,
WatchK8sResults,
useListPageFilter,
VirtualizedTable,
} from '@openshift-console/dynamic-plugin-sdk';
Expand All @@ -35,7 +41,6 @@ import classNames from 'classnames';
import { Link, useLocation } from 'react-router-dom';
import { Tooltip } from '@patternfly/react-core';
import { sortable, wrappable } from '@patternfly/react-table';
import { CEPH_NS } from '../constants';
import { CephBlockPoolModel, CephClusterModel } from '../models';
import { getPoolQuery, StorageDashboardQuery } from '../queries';
import { StoragePoolKind } from '../types';
Expand Down Expand Up @@ -370,11 +375,11 @@ type BlockPoolListPageProps = {
hideColumnManagement?: boolean;
};

const resources = {
const resources = (ns: string) => ({
ceph: {
kind: referenceForModel(CephClusterModel),
namespaced: true,
namespace: CEPH_NS,
namespace: ns,
isList: true,
},
sc: {
Expand All @@ -386,7 +391,7 @@ const resources = {
kind: referenceForModel(CephBlockPoolModel),
isList: true,
},
};
});

type WatchType = {
sc: StorageClassResourceKind[];
Expand All @@ -397,10 +402,15 @@ type WatchType = {
export const BlockPoolListPage: React.FC<BlockPoolListPageProps> = ({}) => {
const { t } = useCustomTranslation();

const { oprInstallNs, isOprNsLoaded, oprNsLoadError, isNsSafe } =
useOprInstallNamespaceSelector();

const location = useLocation();
const listPagePath: string = location.pathname;

const response = useK8sWatchResources<WatchType>(resources);
const response = useSafeK8sWatchResources(
resources
) as WatchK8sResults<WatchType>;

const cephClusters = response.ceph.data;
const cephLoaded = response.ceph.loaded;
Expand All @@ -423,27 +433,37 @@ export const BlockPoolListPage: React.FC<BlockPoolListPageProps> = ({}) => {

// Metrics
const [poolRawCapacityMetrics, rawCapLoadError, rawCapLoading] =
useCustomPrometheusPoll({
endpoint: 'api/v1/query' as any,
query: getPoolQuery(
memoizedPoolNames,
StorageDashboardQuery.POOL_RAW_CAPACITY_USED
),
namespace: CEPH_NS,
basePath: usePrometheusBasePath(),
});
useCustomPrometheusPoll(
getValidPrometheusPollObj(
{
endpoint: 'api/v1/query' as any,
query: getPoolQuery(
memoizedPoolNames,
StorageDashboardQuery.POOL_RAW_CAPACITY_USED
),
namespace: oprInstallNs,
basePath: usePrometheusBasePath(),
},
isNsSafe
)
);

// compression queries
const [compressionSavings, compressionLoadError, compressionLoading] =
useCustomPrometheusPoll({
endpoint: 'api/v1/query' as any,
query: getPoolQuery(
poolNames,
StorageDashboardQuery.POOL_COMPRESSION_SAVINGS
),
namespace: CEPH_NS,
basePath: usePrometheusBasePath(),
});
useCustomPrometheusPoll(
getValidPrometheusPollObj(
{
endpoint: 'api/v1/query' as any,
query: getPoolQuery(
poolNames,
StorageDashboardQuery.POOL_COMPRESSION_SAVINGS
),
namespace: oprInstallNs,
basePath: usePrometheusBasePath(),
},
isNsSafe
)
);

const customData = React.useMemo(() => {
const poolRawCapacity: PoolMetrics = getPerPoolMetrics(
Expand Down Expand Up @@ -498,15 +518,15 @@ export const BlockPoolListPage: React.FC<BlockPoolListPageProps> = ({}) => {
<ListPageBody>
<ListPageFilter
data={data}
loaded={loaded}
loaded={loaded && isOprNsLoaded}
onFilterChange={onFilterChange}
hideColumnManagement={true}
/>
<BlockPoolList
data={filteredData}
unfilteredData={data}
loaded={loaded}
loadError={error}
loaded={loaded && isOprNsLoaded}
loadError={error || oprNsLoadError}
rowData={{ ...customData }}
/>
</ListPageBody>
Expand Down
Loading

0 comments on commit 712f0be

Please sign in to comment.