/* 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');
});
});