From 6290e2d7b7573cb528a671ccb75f6fb427d2a992 Mon Sep 17 00:00:00 2001 From: Christopher Hellen Date: Mon, 10 Jun 2024 09:34:30 -0500 Subject: [PATCH] UICAL-220/228 (#527) * UICAL-220: Created test for MCLRowFormatter * UICAL -228: Test for TImeField * added newlines to end of files --- .../fields/MCLRowFormatter.test.tsx | 48 +++++++++++++++ src/components/fields/TimeField.test.tsx | 59 +++++++++++++++++++ 2 files changed, 107 insertions(+) create mode 100644 src/components/fields/MCLRowFormatter.test.tsx create mode 100644 src/components/fields/TimeField.test.tsx diff --git a/src/components/fields/MCLRowFormatter.test.tsx b/src/components/fields/MCLRowFormatter.test.tsx new file mode 100644 index 0000000..3a37356 --- /dev/null +++ b/src/components/fields/MCLRowFormatter.test.tsx @@ -0,0 +1,48 @@ +import { render, screen } from '@testing-library/react' +import React from 'react' +import MCLRowFormatter from './MCLRowFormatter' +import { MCLContentsType } from './ExceptionFieldTypes'; +import RowType from './RowType'; + +describe('MCLRowFormatter', () => { + it('Renders the formatter correctly', async () => { + render( + + rowClass='test-classname' + rowWidth={1} + rowIndex={1} + labelStrings={['foo']} + cells={[

test

]} + rowData={ + { rowState: + { i: 1, + name: 'foo', + type: RowType.Open, + lastRowI: 1, + rows: [{ + i: 1, + startDate: undefined, + startTime: undefined, + endDate: undefined, + endTime: undefined + }] + }, + name: undefined, + status: undefined, + startDate: undefined, + startTime: undefined, + endDate: undefined, + endTime: undefined, + actions: undefined, + isConflicted: false + } + } + rowProps={{} as any} + /> + ); + + expect(await screen.findByRole('heading')).toBeInTheDocument(); + expect((await screen.findByRole('heading')).textContent).toBe('test'); + expect((await screen.findByRole('heading')).parentElement?.className).toBe('test-classname'); + }); +}); diff --git a/src/components/fields/TimeField.test.tsx b/src/components/fields/TimeField.test.tsx new file mode 100644 index 0000000..2089b60 --- /dev/null +++ b/src/components/fields/TimeField.test.tsx @@ -0,0 +1,59 @@ +import { fireEvent, render, screen } from "@testing-library/react"; +import React from 'react' +import { IntlProvider } from "react-intl"; +import TimeField from "./TimeField"; +import userEvent from "@testing-library/user-event"; + +describe('TimeField', () => { + it('Renders the TimeField correctly', async () => { + render( + + {}} + error={undefined} + onBlur={() => {}} + onChange={() => {}} + /> + + ); + + expect(await screen.findByRole('textbox')).toBeInTheDocument(); + expect(await screen.findByRole('textbox')).toHaveValue(''); + }); + + it('Renders nothing when display is false', async () => { + render( + + {}} + error={undefined} + onBlur={() => {}} + onChange={() => {}} + /> + + ); + + expect(await screen.queryByRole('textbox')).toBeNull(); + }); + + it('Formatse time correctly', async () => { + render( + + {}} + error={undefined} + onBlur={() => {}} + onChange={() => {}} + /> + + ); + + expect(await screen.findByRole('textbox')).toHaveValue('12:30 PM'); + }); +});