Skip to main content
Glama
NewTopicDialog.test.tsx3.02 kB
// SPDX-FileCopyrightText: Copyright Orangebot, Inc. and Medplum contributors // SPDX-License-Identifier: Apache-2.0 import { MantineProvider } from '@mantine/core'; import { Notifications } from '@mantine/notifications'; import type { Patient } from '@medplum/fhirtypes'; import { HomerSimpson, MockClient } from '@medplum/mock'; import { MedplumProvider } from '@medplum/react'; import { render, screen, waitFor } from '@testing-library/react'; import userEvent from '@testing-library/user-event'; import { MemoryRouter } from 'react-router'; import { describe, expect, test, vi, beforeEach } from 'vitest'; import { NewTopicDialog } from './NewTopicDialog'; const mockOnSubmit = vi.fn(); const mockOnClose = vi.fn(); describe('NewTopicDialog', () => { let medplum: MockClient; beforeEach(async () => { medplum = new MockClient(); vi.clearAllMocks(); await medplum.createResource(HomerSimpson); }); const setup = (opened = true, subject?: Patient): void => { render( <MemoryRouter> <MedplumProvider medplum={medplum}> <MantineProvider> <Notifications /> <NewTopicDialog opened={opened} onClose={mockOnClose} onSubmit={mockOnSubmit} subject={subject} /> </MantineProvider> </MedplumProvider> </MemoryRouter> ); }; test('renders modal when opened', () => { setup(true); expect(screen.getByText('New Message')).toBeInTheDocument(); }); test('does not render modal when closed', () => { setup(false); expect(screen.queryByText('New Message')).not.toBeInTheDocument(); }); test('displays patient input field', () => { setup(true); expect(screen.getByText('Patient')).toBeInTheDocument(); expect(screen.getByText('Select a patient')).toBeInTheDocument(); }); test('displays practitioner input field', () => { setup(true); expect(screen.getByText('Practitioner (optional)')).toBeInTheDocument(); }); test('displays topic input field', () => { setup(true); expect(screen.getByText('Topic (optional)')).toBeInTheDocument(); expect(screen.getByPlaceholderText('Enter your topic')).toBeInTheDocument(); }); test('displays submit button', () => { setup(true); expect(screen.getByRole('button', { name: 'Next' })).toBeInTheDocument(); }); test('shows error when submitting without patient', async () => { const user = userEvent.setup(); setup(true); const submitButton = screen.getByRole('button', { name: 'Next' }); await user.click(submitButton); await waitFor(() => { expect(screen.getByText(/Please select a patient/i)).toBeInTheDocument(); }); }); test('calls onClose when modal is closed', async () => { const user = userEvent.setup(); setup(true); const closeButton = document.querySelector('.mantine-Modal-close'); expect(closeButton).toBeInTheDocument(); if (closeButton) { await user.click(closeButton); expect(mockOnClose).toHaveBeenCalled(); } }); });

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