nexxtway/react-rainbow

View on GitHub
src/components/WeekDayPicker/__test__/weekDayPicker.spec.js

Summary

Maintainability
D
1 day
Test Coverage
import React from 'react';
import { mount } from 'enzyme';
import WeekDayPicker from '..';
import { StyledHelpText } from '../styled';
import StyledTextError from '../../Input/styled/errorText';
import WeekDayItems from '../weekDayItems';
import { useUniqueIdentifier } from '../../../libs/hooks';

jest.mock('../../../libs/hooks/useUniqueIdentifier', () => jest.fn(() => 'week-day-items'));

describe('<WeekDayPicker />', () => {
    it('should pass the right props to the Label component', () => {
        const component = mount(<WeekDayPicker label="custom label" required />);
        expect(component.find('Label').props()).toEqual({
            label: 'custom label',
            required: true,
            readOnly: false,
            labelAlignment: 'center',
            hideLabel: false,
            as: 'legend',
            variant: 'default',
            size: 'medium',
        });
    });
    it('should render bottom help text when bottomHelpText prop is passed', () => {
        const component = mount(<WeekDayPicker bottomHelpText="My help text" />);
        expect(component.find(StyledHelpText).length).toBe(1);
    });
    it('should render required asterisk when required prop is true', () => {
        const component = mount(<WeekDayPicker label="My label" required />);
        expect(component.find('RequiredAsterisk').exists()).toBe(true);
    });
    it('should have input type as checkbox when multiple is true', () => {
        const component = mount(<WeekDayPicker multiple />);
        expect(
            component
                .find('input')
                .at(0)
                .prop('type'),
        ).toBe('checkbox');
    });
    it('should have input type as radio when multiple is false', () => {
        const component = mount(<WeekDayPicker />);
        expect(
            component
                .find('input')
                .at(0)
                .prop('type'),
        ).toBe('radio');
    });
    it('should render an error text when error prop is passed', () => {
        const component = mount(<WeekDayPicker error="error" />);
        expect(component.find(StyledTextError).exists()).toBe(true);
    });
    it('should have the opposite days disabled when a list of availableDates is sent', () => {
        const weekDays = [
            'sunday',
            'monday',
            'tuesday',
            'wednesday',
            'thursday',
            'friday',
            'saturday',
        ];
        const availableDates = ['wednesday', 'friday'];
        const component = mount(<WeekDayPicker availableDates={availableDates} />);
        weekDays.forEach((weekDay, index) => {
            const isDisabled = component
                .find('input')
                .at(index)
                .prop('disabled');
            const shouldDisable = !availableDates.includes(weekDay);
            if (shouldDisable) {
                expect(isDisabled).toBe(true);
            } else {
                expect(isDisabled).toBe(false);
            }
        });
    });
    it('should have readonly prop as true when readOnly param is passed', () => {
        const component = mount(<WeekDayPicker readOnly />);
        expect(
            component
                .find('input')
                .at(0)
                .prop('readOnly'),
        ).toBe(true);
    });
    it('should change checked properly status for single day selection', () => {
        const component = mount(<WeekDayPicker value="friday" />);
        component.setProps({ value: 'monday' });
        expect(
            component
                .find('input')
                .at(5)
                .prop('checked'),
        ).toBe(false);
        expect(
            component
                .find('input')
                .at(1)
                .prop('checked'),
        ).toBe(true);
    });
    it('should change checked status properly for multiple selection', () => {
        const value = ['saturday'];
        const component = mount(<WeekDayPicker value={value} multiple />);
        component.setProps({ value: ['sunday', 'monday'] });
        expect(
            component
                .find('input')
                .at(0)
                .prop('checked'),
        ).toBe(true);
        expect(
            component
                .find('input')
                .at(1)
                .prop('checked'),
        ).toBe(true);
        expect(
            component
                .find('input')
                .at(6)
                .prop('checked'),
        ).toBe(false);
    });
    it('should call useUniqueIdentifier 8 times for the ids generations', () => {
        useUniqueIdentifier.mockClear();
        mount(<WeekDayPicker />);
        expect(useUniqueIdentifier).toHaveBeenCalledTimes(8);
    });
    it('should have default name when name params is not sent', () => {
        const component = mount(<WeekDayPicker />);
        expect(
            component
                .find(WeekDayItems)
                .at(0)
                .prop('name'),
        ).toBe('week-day-items');
    });
    it('should not run onChange when checkbox change is triggered and readOnly is true', () => {
        const onChangeFn = jest.fn();
        const component = mount(<WeekDayPicker onChange={onChangeFn} readOnly />);
        component
            .find('input')
            .at(0)
            .simulate('change', { target: { checked: true, value: 'sunday' } });
        expect(onChangeFn).not.toHaveBeenCalled();
    });
    it('should not run onChange when input change is triggered and disabled is true', () => {
        const onChangeFn = jest.fn();
        const component = mount(<WeekDayPicker onChange={onChangeFn} disabled />);
        component
            .find('input')
            .at(0)
            .simulate('change', { target: { checked: true, value: 'sunday' } });
        expect(onChangeFn).not.toHaveBeenCalled();
    });
    it('should run onChange with the right value when multiple is not set', () => {
        const onChangeFn = jest.fn();
        const component = mount(<WeekDayPicker value="monday" onChange={onChangeFn} />);
        component
            .find('input')
            .at(0)
            .simulate('change', { target: { checked: true, value: 'sunday' } });
        expect(onChangeFn).toHaveBeenCalledWith('sunday');
    });
    it('should run onChange with the right sorted values when multiple is true', () => {
        const onChangeFn = jest.fn();
        const value = ['friday', 'monday'];
        const component = mount(<WeekDayPicker value={value} multiple onChange={onChangeFn} />);
        component
            .find('input')
            .at(0)
            .simulate('change', { target: { checked: true, value: 'sunday' } });
        expect(onChangeFn).toHaveBeenCalledWith(['sunday', 'monday', 'friday']);
    });
});