Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Migrated wrapField tests to @testing-library/react #1318

Merged
merged 28 commits into from
Jun 3, 2024
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
28 commits
Select commit Hold shift + click to select a range
86ca983
Moved SelectField tests to suites
zaxovaiko Nov 9, 2023
93c60e6
Added few more test suites
zaxovaiko Feb 9, 2024
baaba56
Added few more tests
zaxovaiko Feb 23, 2024
abbdf52
Added few more tests
zaxovaiko Feb 24, 2024
8fbba3f
Added more tests
zaxovaiko Feb 29, 2024
dc39e50
Removed theme tests
zaxovaiko Feb 29, 2024
f3fa234
wip, three tests need attention
zaxovaiko Feb 29, 2024
f232d6b
Added few more tests for array
zaxovaiko Feb 29, 2024
afb8bc0
changed props
zaxovaiko Feb 29, 2024
c737546
Added few more tests for partial hit
zaxovaiko Feb 29, 2024
6f62067
Added few more tests for partial hit
zaxovaiko Mar 1, 2024
85268e5
Added few more tests for partial hit
zaxovaiko Mar 1, 2024
c7a9c37
Enable AntD SelectField tests suite
kestarumper Mar 23, 2024
ce1e1fe
Merge branch 'master' into select-field-tests
zaxovaiko Mar 31, 2024
9dec81c
Added (multiple) label to test names
zaxovaiko Mar 31, 2024
2e5dfa1
Merge branch 'master' into select-field-tests-antd
zaxovaiko Apr 5, 2024
e2aa01a
Added labels multiple to tests
zaxovaiko Apr 5, 2024
6e3910b
Rewritten a few tests for wrapField
zaxovaiko Apr 19, 2024
38476ab
Merged with main
zaxovaiko Apr 19, 2024
f955d8f
Added missing test for bootstrap3
zaxovaiko Apr 19, 2024
e16db3c
rewritten few more tests
zaxovaiko Apr 19, 2024
ab85d95
Refactored code
zaxovaiko Apr 19, 2024
783649b
Merge branch 'master' into wrap-field-tests
zaxovaiko Apr 22, 2024
6e05d14
Moved a few tests into AntD and MUI packages
zaxovaiko May 24, 2024
8fdb7d9
Added a few options specific for some props and moved test to AntD
zaxovaiko May 24, 2024
a1238de
Completed tests
zaxovaiko May 24, 2024
b36fc61
Removed unused props
zaxovaiko May 24, 2024
0b739ca
Used container from zod
zaxovaiko May 24, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
6 changes: 6 additions & 0 deletions packages/uniforms-antd/__tests__/index.ts
Original file line number Diff line number Diff line change
Expand Up @@ -65,4 +65,10 @@ describe('@RTL', () => {
suites.testTextField(theme.TextField);
suites.testValidatedForm(theme.ValidatedForm);
suites.testValidatedQuickForm(theme.ValidatedQuickForm);
suites.testWrapField(theme.wrapField, {
helpPropsName: 'help',
withoutWrapClassName: true,
withoutHelpClassName: true,
withoutLabelClassName: true,
});
});
121 changes: 49 additions & 72 deletions packages/uniforms-antd/__tests__/wrapField.tsx
Original file line number Diff line number Diff line change
@@ -1,75 +1,52 @@
import Form from 'antd/lib/form';
import Tooltip from 'antd/lib/tooltip';
import { screen } from '@testing-library/react';
import React from 'react';
import { wrapField } from 'uniforms-antd';

import mount from './_mount';

test('<wrapField> - renders wrapper with label', () => {
const element = wrapField({ label: 'Label' }, <div />);
const wrapper = mount(element);

// @ts-expect-error Correct label type.
expect(wrapper.find(Form.Item).prop('label').props.children[0]).toBe('Label');
});

test('<wrapField> - renders wrapper with label and info', () => {
const element = wrapField({ label: 'Label', info: 'Info' }, <div />);
const wrapper = mount(element);

expect(wrapper.find(Tooltip).prop('title')).toBe('Info');
});

test('<wrapField> - renders wrapper with an error message', () => {
const error = new Error();
const element = wrapField(
{ error, showInlineError: true, errorMessage: 'Error' },
<div />,
);
const wrapper = mount(element);

expect(wrapper.find(Form.Item).prop('help')).toBe('Error');
});

test('<wrapField> - renders wrapper with an error status', () => {
const element = wrapField({}, <div />);
const wrapper = mount(element);

expect(wrapper.find(Form.Item).prop('validateStatus')).toBe(undefined);
});

test('<wrapField> - renders wrapper with an error status (error)', () => {
const error = new Error();
const element = wrapField({ error }, <div />);
const wrapper = mount(element);

expect(wrapper.find(Form.Item).prop('validateStatus')).toBe('error');
});

test('<wrapField> - renders wrapper with help text', () => {
const element = wrapField({ help: 'Help' }, <div />);
const wrapper = mount(element);

expect(wrapper.find(Form.Item).prop('help')).toBe('Help');
});

test('<wrapField> - renders wrapper with extra text', () => {
const element = wrapField({ extra: 'Extra' }, <div />);
const wrapper = mount(element);

expect(wrapper.find(Form.Item).prop('extra')).toBe('Extra');
});

test('<wrapField> - renders wrapper with extra style', () => {
const element = wrapField({ wrapperStyle: {} }, <div />);
const wrapper = mount(element);

expect(wrapper.find(Form.Item).prop('style')).toEqual({});
});

test('<wrapField> - renders wrapper with a custom validateStatus', () => {
const element = wrapField({ validateStatus: 'success' }, <div />);
const wrapper = mount(element);

expect(wrapper.find(Form.Item).prop('validateStatus')).toBe('success');
import { renderWithZod } from 'uniforms/__suites__';
import { z } from 'zod';

describe('wrapField tests', () => {
test('<wrapField> - renders wrapper with extra style', () => {
const { container } = renderWithZod({
element: wrapField(
{ wrapperStyle: { backgroundColor: 'red' } },
<div data-testid="x" />,
),
schema: z.object({}),
});
const element = container.getElementsByClassName('ant-form-item')[0];
expect(element?.getAttribute('style')).toBe('background-color: red;');
});

test('<wrapField> - renders wrapper with label and info', () => {
renderWithZod({
element: wrapField({ label: 'Label', info: 'Info' }, <div />),
schema: z.object({}),
});
expect(screen.getByRole('img').getAttribute('aria-label')).toBe(
'question-circle',
);
});

test('<wrapField> - renders wrapper with extra text', () => {
renderWithZod({
element: wrapField({ extra: 'Extra' }, <div data-testid="x" />),
schema: z.object({}),
});
expect(screen.getByText('Extra')).toBeInTheDocument();
});

test('<wrapField> - renders wrapper with a custom validateStatus', () => {
renderWithZod({
element: wrapField(
{ validateStatus: 'success' },
<div data-testid="x" />,
),
schema: z.object({}),
});
expect(
screen
.getByTestId('x')
.closest('.ant-form-item-has-feedback.ant-form-item-has-success'),
).toBeInTheDocument();
});
});
84 changes: 0 additions & 84 deletions packages/uniforms-bootstrap3/__tests__/wrapField.tsx

This file was deleted.

1 change: 1 addition & 0 deletions packages/uniforms-bootstrap4/__tests__/index.ts
Original file line number Diff line number Diff line change
Expand Up @@ -63,4 +63,5 @@ describe('@RTL', () => {
suites.testTextField(theme.TextField, { testWrapClassName: true });
suites.testValidatedForm(theme.ValidatedForm);
suites.testValidatedQuickForm(theme.ValidatedQuickForm);
suites.testWrapField(theme.wrapField);
});
90 changes: 17 additions & 73 deletions packages/uniforms-bootstrap4/__tests__/wrapField.tsx
Original file line number Diff line number Diff line change
@@ -1,76 +1,20 @@
import { screen } from '@testing-library/react';
import React from 'react';
import { wrapField } from 'uniforms-bootstrap4';

import mount from './_mount';

test('<wrapField> - renders wrapper with correct class', () => {
const element = wrapField({ wrapClassName: 'container' }, <div />);
const wrapper = mount(element);

expect(wrapper.find('.container')).toHaveLength(1);
});

test('<wrapField> - renders help block', () => {
const element = wrapField({ help: 'Hint' }, <div />);
const wrapper = mount(element);

expect(wrapper.find('.form-text').text()).toBe('Hint');
});

test('<wrapField> - renders help block with specified class', () => {
const element = wrapField(
{ help: 'Hint', helpClassName: 'text-hint' },
<div />,
);
const wrapper = mount(element);

expect(wrapper.find('.form-text.text-hint')).toHaveLength(1);
});

test('<wrapField> - renders error block', () => {
const error = new Error();
const element = wrapField(
{ error, showInlineError: true, errorMessage: 'Error' },
<div />,
);
const wrapper = mount(element);

expect(wrapper.find('.text-danger').text()).toBe('Error');
});

test('<wrapField> - renders error block (showInlineError=false)', () => {
const error = new Error();
const element = wrapField(
{ error, showInlineError: false, errorMessage: 'Error' },
<div />,
);
const wrapper = mount(element);

expect(wrapper.find('.text-danger')).toHaveLength(0);
});

test('<wrapField> - label has custom class (String)', () => {
const element = wrapField(
{
label: 'A field label',
labelClassName: 'custom-label-class',
},
<div />,
);
const wrapper = mount(element);

expect(wrapper.find('label.custom-label-class')).toHaveLength(1);
});

test('<wrapField> - label has custom class (Array[String])', () => {
const element = wrapField(
{
label: 'A field label',
labelClassName: ['custom-1', 'custom-2'],
},
<div />,
);
const wrapper = mount(element);

expect(wrapper.find('label.custom-1.custom-2')).toHaveLength(1);
import { renderWithZod } from 'uniforms/__suites__';
import { z } from 'zod';

describe('wrapField tests', () => {
test('<wrapField> - renders wrapper with correct class', () => {
renderWithZod({
element: wrapField(
{ wrapClassName: 'container' },
<div data-testid="x" />,
),
schema: z.object({}),
});
expect(
screen.getByTestId('x').parentElement?.classList.contains('container'),
).toBe(true);
});
});
1 change: 1 addition & 0 deletions packages/uniforms-bootstrap5/__tests__/index.ts
Original file line number Diff line number Diff line change
Expand Up @@ -68,4 +68,5 @@ describe('@RTL', () => {
});
suites.testValidatedForm(theme.ValidatedForm);
suites.testValidatedQuickForm(theme.ValidatedQuickForm);
suites.testWrapField(theme.wrapField);
});
Loading
Loading