/* eslint-disable jest/require-top-level-describe */ import { render } from '@testing-library/react'; import React from 'react'; import { Color, SEVERITIES } from '../../../helpers/constants/design-system'; import { Icon, ICON_NAMES } from '../icon'; import { HelpText } from './help-text'; describe('HelpText', () => { it('should render with text inside the HelpText', () => { const { getByText } = render(help text); expect(getByText('help text')).toBeDefined(); expect(getByText('help text')).toHaveClass('mm-help-text'); }); it('should match snapshot', () => { const { container } = render(help text); expect(container).toMatchSnapshot(); }); it('should render with and additional className', () => { const { getByText } = render( help text, ); expect(getByText('help text')).toHaveClass('mm-help-text test-class'); }); it('should render with react nodes inside the HelpText', () => { const { getByText, getByTestId } = render( help text{' '} , ); expect(getByText('help text')).toBeDefined(); expect(getByTestId('icon')).toBeDefined(); }); it('should render with severities', () => { const { getByText } = render( <> error success warning info , ); expect(getByText('error')).toHaveClass('mm-text--color-error-default'); expect(getByText('success')).toHaveClass('mm-text--color-success-default'); expect(getByText('warning')).toHaveClass('mm-text--color-warning-default'); expect(getByText('info')).toHaveClass('mm-text--color-info-default'); }); it('should render with different colors', () => { const { getByText } = render( <> default text default text alternative text muted , ); expect(getByText('default')).toHaveClass('mm-text--color-text-default'); expect(getByText('text default')).toHaveClass( 'mm-text--color-text-default', ); expect(getByText('text alternative')).toHaveClass( 'mm-text--color-text-alternative', ); expect(getByText('text muted')).toHaveClass('mm-text--color-text-muted'); }); it('should render with a different html element if children is an object', () => { const { getByText, getByTestId } = render( <> help text as p help text as div , ); expect(getByText('help text as p')).toBeDefined(); expect(getByText('help text as p').tagName).toBe('P'); expect(getByText('help text as div')).toBeDefined(); expect(getByTestId('help-text-div').tagName).toBe('DIV'); }); });