wix-style-react
Version:
wix-style-react
121 lines (107 loc) • 3.79 kB
JavaScript
import React from 'react';
import FieldWithSelectionComposite from './FieldWithSelectionComposite';
import Label from '../../Label';
import Input from '../../Input';
import InputArea from '../../InputArea';
import Checkbox from '../../Checkbox';
import FieldWithSelectionCompositeDriverFactory from './FieldWithSelectionComposite.driver';
import { createDriverFactory } from 'wix-ui-test-utils/driver-factory';
import Tooltip from '../../Tooltip/Tooltip';
describe('FieldWithSelectionComposite', () => {
const createCompositeDriverFactory = createDriverFactory(
FieldWithSelectionCompositeDriverFactory,
);
it('should remove label wrapping when label not given', () => {
const driver = createCompositeDriverFactory(
<FieldWithSelectionComposite>
<Input />
<Checkbox />
</FieldWithSelectionComposite>,
);
expect(driver.hasLabel()).toBe(false);
expect(driver.getNumberOfChildren()).toBe(1);
expect(driver.hasInput()).toBe(true);
expect(driver.hasSelectionInput()).toBe(true);
});
it('should render Label with Input', () => {
const driver = createCompositeDriverFactory(
<FieldWithSelectionComposite>
<Label>myLabel</Label>
<Input />
<Checkbox />
</FieldWithSelectionComposite>,
);
expect(driver.hasLabel()).toBe(true);
expect(driver.getLabel()).toBe('myLabel');
expect(driver.hasInput()).toBe(true);
expect(driver.hasSelectionInput()).toBe(true);
});
it('should render Label with InputArea', () => {
const driver = createCompositeDriverFactory(
<FieldWithSelectionComposite>
<Label />
<InputArea />
<Checkbox />
</FieldWithSelectionComposite>,
);
expect(driver.hasLabel()).toBe(true);
expect(driver.hasInput()).toBe(true);
expect(driver.hasSelectionInput()).toBe(true);
});
describe('input properties', () => {
it('should verify that onBlur callback was called', () => {
const onBlur = jest.fn();
const driver = createCompositeDriverFactory(
<FieldWithSelectionComposite>
<Label />
<Input onBlur={onBlur} />
<Checkbox />
</FieldWithSelectionComposite>,
);
driver.triggerInputBlur();
expect(onBlur).toHaveBeenCalled();
});
});
describe('label attributes', () => {
it('should FieldLabelAttributes not exists if all attributes empty or false', () => {
const driver = createCompositeDriverFactory(
<FieldWithSelectionComposite>
<Label />
<InputArea />
<Checkbox />
</FieldWithSelectionComposite>,
);
expect(driver.hasFieldLabelAttributes()).toBe(false);
});
it('should FieldLabelAttributes exists if required', () => {
const driver = createCompositeDriverFactory(
<FieldWithSelectionComposite required>
<Label />
<InputArea />
<Checkbox />
</FieldWithSelectionComposite>,
);
expect(driver.hasFieldLabelAttributes()).toBe(true);
});
it('should FieldLabelAttributes exists if info', () => {
const driver = createCompositeDriverFactory(
<FieldWithSelectionComposite info="info">
<Label />
<InputArea />
<Checkbox />
</FieldWithSelectionComposite>,
);
expect(driver.hasFieldLabelAttributes()).toBe(true);
});
it('should FieldLabelAttributes exists if tooltip', () => {
const driver = createCompositeDriverFactory(
<FieldWithSelectionComposite tooltip={<Tooltip content="content" />}>
<Label />
<InputArea />
<Checkbox />
</FieldWithSelectionComposite>,
);
expect(driver.hasFieldLabelAttributes()).toBe(true);
});
});
});