Make broker table row clickable (#2151)

* Added click functionality to the row

* Clickablerow moved to separate file

Co-authored-by: Oleg Shur <workshur@gmail.com>
This commit is contained in:
Kirill Morozov 2022-06-21 18:53:11 +03:00 committed by GitHub
parent fac348bb38
commit 3c922bc470
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
3 changed files with 40 additions and 4 deletions

View file

@ -0,0 +1,5 @@
import styled from 'styled-components';
export const ClickableRow = styled.tr`
cursor: pointer;
`;

View file

@ -1,7 +1,7 @@
import React from 'react';
import { ClusterName } from 'redux/interfaces';
import BytesFormatted from 'components/common/BytesFormatted/BytesFormatted';
import { NavLink } from 'react-router-dom';
import { NavLink, useNavigate } from 'react-router-dom';
import TableHeaderCell from 'components/common/table/TableHeaderCell/TableHeaderCell';
import { Table } from 'components/common/table/Table/Table.styled';
import PageHeading from 'components/common/PageHeading/PageHeading';
@ -10,7 +10,10 @@ import useAppParams from 'lib/hooks/useAppParams';
import useBrokers from 'lib/hooks/useBrokers';
import useClusterStats from 'lib/hooks/useClusterStats';
import { ClickableRow } from './BrokersList.style';
const BrokersList: React.FC = () => {
const navigate = useNavigate();
const { clusterName } = useAppParams<{ clusterName: ClusterName }>();
const { data: clusterStats } = useClusterStats(clusterName);
const { data: brokers } = useBrokers(clusterName);
@ -58,7 +61,6 @@ const BrokersList: React.FC = () => {
onlinePartitionCount
)}
<Metrics.LightText>
{' '}
of {(onlinePartitionCount || 0) + (offlinePartitionCount || 0)}
</Metrics.LightText>
</Metrics.Indicator>
@ -114,8 +116,12 @@ const BrokersList: React.FC = () => {
diskUsage.length !== 0 &&
diskUsage.map(({ brokerId, segmentSize, segmentCount }) => {
const brokerItem = brokers?.find(({ id }) => id === brokerId);
return (
<tr key={brokerId}>
<ClickableRow
key={brokerId}
onClick={() => navigate(`${brokerId}`)}
>
<td>
<NavLink to={`${brokerId}`} role="link">
{brokerId}
@ -127,7 +133,7 @@ const BrokersList: React.FC = () => {
<td>{segmentCount}</td>
<td>{brokerItem?.port}</td>
<td>{brokerItem?.host}</td>
</tr>
</ClickableRow>
);
})}
</tbody>

View file

@ -9,6 +9,14 @@ import {
brokersPayload,
clusterStatsPayload,
} from 'components/Brokers/__test__/fixtures';
import userEvent from '@testing-library/user-event';
const mockedUsedNavigate = jest.fn();
jest.mock('react-router-dom', () => ({
...jest.requireActual('react-router-dom'),
useNavigate: () => mockedUsedNavigate,
}));
describe('BrokersList Component', () => {
afterEach(() => fetchMock.reset());
@ -53,6 +61,22 @@ describe('BrokersList Component', () => {
expect(rows.length).toEqual(3);
});
it('opens broker when row clicked', async () => {
const fetchStatsMock = fetchMock.get(fetchStatsUrl, clusterStatsPayload);
await act(() => {
renderComponent();
});
await waitFor(() => expect(fetchStatsMock.called()).toBeTruthy());
await act(() => {
userEvent.click(screen.getByRole('cell', { name: '0' }));
});
await waitFor(() => {
expect(mockedUsedNavigate).toBeCalled();
expect(mockedUsedNavigate).toBeCalledWith('0');
});
});
it('shows warning when offlinePartitionCount > 0', async () => {
const fetchStatsMock = fetchMock.getOnce(fetchStatsUrl, {
...clusterStatsPayload,
@ -93,6 +117,7 @@ describe('BrokersList Component', () => {
expect(onlineWidgetDef).toBeInTheDocument();
expect(onlineWidget).toBeInTheDocument();
});
it('shows right count when inSyncReplicasCount: undefined outOfSyncReplicasCount: 1', async () => {
const fetchStatsMock = fetchMock.getOnce(fetchStatsUrl, {
...clusterStatsPayload,