From ca8450e0bb8ecf8cfd6a23bceb4aee546593f31a Mon Sep 17 00:00:00 2001 From: Aaron Chong Date: Thu, 5 Dec 2024 10:36:55 +0800 Subject: [PATCH] robot-summary Signed-off-by: Aaron Chong --- .../robots/robot-summary.stories.tsx | 31 ++++++++ .../components/robots/robot-summary.test.tsx | 73 +++++++++++++++++++ 2 files changed, 104 insertions(+) create mode 100644 packages/rmf-dashboard-framework/src/components/robots/robot-summary.stories.tsx create mode 100644 packages/rmf-dashboard-framework/src/components/robots/robot-summary.test.tsx diff --git a/packages/rmf-dashboard-framework/src/components/robots/robot-summary.stories.tsx b/packages/rmf-dashboard-framework/src/components/robots/robot-summary.stories.tsx new file mode 100644 index 000000000..adda3214e --- /dev/null +++ b/packages/rmf-dashboard-framework/src/components/robots/robot-summary.stories.tsx @@ -0,0 +1,31 @@ +import { Meta, StoryObj } from '@storybook/react'; +import { ApiServerModelsRmfApiRobotStateStatus as Status } from 'api-client'; + +import { RobotSummary } from './robot-summary'; + +export default { + title: 'Robots/RobotSummary', + component: RobotSummary, +} satisfies Meta; + +type Story = StoryObj; + +export const Default: Story = { + args: { + onClose: () => {}, + robot: { + fleet: 'test_fleet', + name: 'test_robot', + status: Status.Idle, + battery: 60, + estFinishTime: 1000000, + lastUpdateTime: 900000, + level: 'L1', + commission: { + dispatch_tasks: true, + direct_tasks: true, + idle_behavior: true, + }, + }, + }, +}; diff --git a/packages/rmf-dashboard-framework/src/components/robots/robot-summary.test.tsx b/packages/rmf-dashboard-framework/src/components/robots/robot-summary.test.tsx new file mode 100644 index 000000000..b456a85a6 --- /dev/null +++ b/packages/rmf-dashboard-framework/src/components/robots/robot-summary.test.tsx @@ -0,0 +1,73 @@ +import { waitFor } from '@testing-library/react'; +import userEvent from '@testing-library/user-event'; +import { ApiServerModelsRmfApiRobotStateStatus as Status, FleetState } from 'api-client'; +import { act } from 'react'; +import { describe, expect, it, vi } from 'vitest'; + +import { RmfApiProvider } from '../../hooks'; +import { MockRmfApi, render, TestProviders } from '../../utils/test-utils.test'; +import { makeTaskState } from './../tasks/make-tasks.test'; +import { RobotSummary } from './robot-summary'; +import { RobotTableData } from './robot-table-datagrid'; +import { makeRobot } from './test-utils.test'; + +describe('Robot summary', () => { + const rmfApi = new MockRmfApi(); + const Base = (props: React.PropsWithChildren<{}>) => { + return ( + + {props.children} + + ); + }; + + it('Renders robot summary', async () => { + const onCloseMock = vi.fn(); + const robotTableData: RobotTableData = { + fleet: 'test_fleet', + name: 'test_robot', + status: Status.Idle, + battery: 0.6, + estFinishTime: 1000000, + lastUpdateTime: 900000, + level: 'L1', + commission: { + dispatch_tasks: true, + direct_tasks: true, + idle_behavior: true, + }, + }; + + const root = render( + + + , + ); + + // Create the subject for the fleet + rmfApi.getFleetStateObs('test_fleet'); + const mockFleetState: FleetState = { + name: 'test_fleet', + robots: { + ['test_robot']: makeRobot({ name: 'test_robot', task_id: 'test_task_id' }), + }, + }; + act(() => { + rmfApi.fleetStateObsStore['test_fleet'].next(mockFleetState); + }); + + // Create the subject for the task + rmfApi.getTaskStateObs('test_task_id'); + const mockTaskState = makeTaskState('test_task_id'); + act(() => { + rmfApi.taskStateObsStore['test_task_id'].next(mockTaskState); + }); + + expect(root.getByText(/Robot summary/i)).toBeTruthy(); + expect(root.getByText(/test_robot/i)).toBeTruthy(); + expect(root.getByText(/Assigned tasks/i)).toBeTruthy(); + expect(root.getByText(/test_task_id/i)).toBeTruthy(); + userEvent.keyboard('{Escape}'); + await waitFor(() => expect(onCloseMock).toHaveBeenCalledTimes(1)); + }); +});