Skip to main content
Glama
ProblemList.test.tsx6.87 kB
// SPDX-FileCopyrightText: Copyright Orangebot, Inc. and Medplum contributors // SPDX-License-Identifier: Apache-2.0 import { createReference } from '@medplum/core'; import type { Condition } from '@medplum/fhirtypes'; import { HomerSimpson, MockClient } from '@medplum/mock'; import { MedplumProvider } from '@medplum/react-hooks'; import type { ReactNode } from 'react'; import { MemoryRouter } from 'react-router'; import { act, fireEvent, render, screen } from '../test-utils/render'; import { ProblemList } from './ProblemList'; const medplum = new MockClient(); describe('PatientSummary - ProblemList', () => { async function setup(children: ReactNode): Promise<void> { await act(async () => { render( <MemoryRouter> <MedplumProvider medplum={medplum}>{children}</MedplumProvider> </MemoryRouter> ); }); } beforeEach(() => { jest.useFakeTimers(); }); afterEach(async () => { await act(async () => { jest.runOnlyPendingTimers(); }); jest.useRealTimers(); }); test('Renders empty', async () => { await setup(<ProblemList patient={HomerSimpson} problems={[]} />); expect(screen.getByText('Problems')).toBeInTheDocument(); }); test('Renders existing', async () => { await setup( <ProblemList patient={HomerSimpson} problems={[ { resourceType: 'Condition', id: 'peanut', subject: { reference: 'Patient/123' }, code: { text: 'Peanut' }, }, ]} /> ); expect(screen.getByText('Problems')).toBeInTheDocument(); expect(screen.getByText('Peanut')).toBeInTheDocument(); }); test('Add problem', async () => { await setup(<ProblemList patient={HomerSimpson} problems={[]} />); await act(async () => { fireEvent.click(screen.getByLabelText('Add item')); }); // Enter problem "Dizziness" const input = (await screen.findAllByRole('searchbox'))[0] as HTMLInputElement; await act(async () => { fireEvent.change(input, { target: { value: 'Dizziness' } }); }); // Wait for the drop down await act(async () => { jest.advanceTimersByTime(1000); }); // Press the down arrow await act(async () => { fireEvent.keyDown(input, { key: 'ArrowDown', code: 'ArrowDown' }); }); // Press "Enter" await act(async () => { fireEvent.keyDown(input, { key: 'Enter', code: 'Enter' }); }); // Enter Dx Date await act(async () => { fireEvent.change(screen.getByLabelText('Dx Date *'), { target: { value: '2021-01-01' } }); }); // Click "Save" button await act(async () => { fireEvent.click(screen.getByText('Save')); }); }); test('Edit problem', async () => { const condition: Condition = { resourceType: 'Condition', id: 'dizziness', subject: createReference(HomerSimpson), code: { text: 'Dizziness' }, }; await setup(<ProblemList patient={HomerSimpson} problems={[condition]} />); await act(async () => { fireEvent.click(screen.getByText('Dizziness')); }); // Enter problem "Dizziness" const input = (await screen.findAllByRole('searchbox'))[0] as HTMLInputElement; await act(async () => { fireEvent.change(input, { target: { value: 'Dizziness' } }); }); // Wait for the drop down await act(async () => { jest.advanceTimersByTime(1000); }); // Press the down arrow await act(async () => { fireEvent.keyDown(input, { key: 'ArrowDown', code: 'ArrowDown' }); }); // Press "Enter" await act(async () => { fireEvent.keyDown(input, { key: 'Enter', code: 'Enter' }); }); // Enter Dx Date await act(async () => { fireEvent.change(screen.getByLabelText('Dx Date *'), { target: { value: '2021-01-01' } }); }); // Click "Save" button await act(async () => { fireEvent.click(screen.getByText('Save')); }); }); test('Problem status colors', async () => { await setup( <ProblemList patient={HomerSimpson} problems={[ { resourceType: 'Condition', id: 'active', subject: createReference(HomerSimpson), code: { text: 'Active Problem' }, clinicalStatus: { coding: [ { code: 'active', system: 'http://terminology.hl7.org/CodeSystem/condition-clinical', display: 'Active', }, ], }, }, { resourceType: 'Condition', id: 'inactive', subject: createReference(HomerSimpson), code: { text: 'Inactive Problem' }, clinicalStatus: { coding: [ { code: 'inactive', system: 'http://terminology.hl7.org/CodeSystem/condition-clinical', display: 'Inactive', }, ], }, }, { resourceType: 'Condition', id: 'remission', subject: createReference(HomerSimpson), code: { text: 'Remission Problem' }, clinicalStatus: { coding: [ { code: 'remission', system: 'http://terminology.hl7.org/CodeSystem/condition-clinical', display: 'Remission', }, ], }, }, { resourceType: 'Condition', id: 'resolved', subject: createReference(HomerSimpson), code: { text: 'Resolved Problem' }, clinicalStatus: { coding: [ { code: 'resolved', system: 'http://terminology.hl7.org/CodeSystem/condition-clinical', display: 'Resolved', }, ], }, }, ]} /> ); const activeBadge = screen.getByText('active').closest('[class*="mantine-Badge-root"]'); expect(activeBadge).toHaveStyle({ '--badge-color': 'var(--mantine-color-green-light-color)' }); const inactiveBadge = screen.getByText('inactive').closest('[class*="mantine-Badge-root"]'); expect(inactiveBadge).toHaveStyle({ '--badge-color': 'var(--mantine-color-orange-light-color)' }); const remissionBadge = screen.getByText('remission').closest('[class*="mantine-Badge-root"]'); expect(remissionBadge).toHaveStyle({ '--badge-color': 'var(--mantine-color-blue-light-color)' }); const resolvedBadge = screen.getByText('resolved').closest('[class*="mantine-Badge-root"]'); expect(resolvedBadge).toHaveStyle({ '--badge-color': 'var(--mantine-color-teal-light-color)' }); }); });

Latest Blog Posts

MCP directory API

We provide all the information about MCP servers via our MCP API.

curl -X GET 'https://glama.ai/api/mcp/v1/servers/medplum/medplum'

If you have feedback or need assistance with the MCP directory API, please join our Discord server