nexxtway/react-rainbow

View on GitHub
src/components/VerticalNavigation/__test__/verticalNavigation.spec.js

Summary

Maintainability
B
4 hrs
Test Coverage
import React from 'react';
import { mount } from 'enzyme';
import VerticalNavigation from '..';
import VerticalSection from '../../VerticalSection';
import VerticalSectionOverflow from '../../VerticalSectionOverflow';
import VerticalItem from '../../VerticalItem';

describe('<VerticalNavigation/>', () => {
    it('should set the ariaLabel passed as aria-label in the nav element', () => {
        const component = mount(<VerticalNavigation ariaLabel="my aria label" />);
        expect(component.find('nav').prop('aria-label')).toBe('my aria label');
    });
    it('should render the children passed', () => {
        const component = mount(
            <VerticalNavigation>
                <span>item children</span>
            </VerticalNavigation>,
        );
        expect(component.find('span').text()).toBe('item children');
    });
    it('should call onSelect event with the right data when an item is clicked', () => {
        const onSelectMockFn = jest.fn();
        const component = mount(
            <VerticalNavigation onSelect={onSelectMockFn}>
                <VerticalSection label="header section">
                    <VerticalItem name="item 1" label="item 1" />
                    <VerticalItem name="item 2" label="item 2" />
                    <VerticalItem name="item 3" label="item 3" />
                </VerticalSection>
            </VerticalNavigation>,
        );
        const item2 = component
            .find('VerticalItem[name="item 2"]')
            .find('button[data-id="vertical-item-clickable-element"]');
        item2.simulate('click');
        expect(onSelectMockFn).toHaveBeenCalledWith(expect.any(Object), 'item 2');
    });
    it('should set tabIndex 0 in the clickable element element when use VerticalSection', () => {
        const component = mount(
            <VerticalNavigation>
                <VerticalSection label="header section">
                    <VerticalItem name="item 1" label="item 1" />
                </VerticalSection>
            </VerticalNavigation>,
        );
        expect(
            component.find('button[data-id="vertical-item-clickable-element"]').prop('tabIndex'),
        ).toBe(0);
    });
    it('should set tabIndex 0 in the clickable element element when use VerticalSectionOverflow and expanded is true', () => {
        const component = mount(
            <VerticalNavigation>
                <VerticalSectionOverflow expanded>
                    <VerticalItem name="item 1" label="item 1" />
                </VerticalSectionOverflow>
            </VerticalNavigation>,
        );
        expect(
            component.find('button[data-id="vertical-item-clickable-element"]').prop('tabIndex'),
        ).toBe(0);
    });
    it('should set tabIndex -1 in the clickable element element when use VerticalSectionOverflow and expanded is false', () => {
        const component = mount(
            <VerticalNavigation>
                <VerticalSectionOverflow expanded={false}>
                    <VerticalItem name="item 1" label="item 1" />
                </VerticalSectionOverflow>
            </VerticalNavigation>,
        );
        expect(
            component.find('button[data-id="vertical-item-clickable-element"]').prop('tabIndex'),
        ).toBe(-1);
    });
});