nexxtway/react-rainbow

View on GitHub
src/components/Tabset/__test__/tabset.spec.js

Summary

Maintainability
F
6 days
Test Coverage
import React from 'react';
import { mount } from 'enzyme';
import Tabset from '../index';
import Tab from '../../Tab';
import {
    getLeftButtonDisabledState,
    getRightButtonDisabledState,
    isNotSameChildren,
    getChildrenTotalWidth,
    getChildrenTotalWidthUpToClickedTab,
    getTabIndexFromName,
} from '../utils';
import StyledButton from '../../Tab/styled/button';

jest.mock('./../utils.js', () => ({
    getLeftButtonDisabledState: jest.fn(() => false),
    getRightButtonDisabledState: jest.fn(() => false),
    getChildTabNodes: jest.fn(() => []),
    insertChildOrderly: jest.fn(() => []),
    getActiveTabIndex: jest.fn(() => 0),
    getChildrenTotalWidth: jest.fn(() => 0),
    getChildrenTotalWidthUpToClickedTab: jest.fn(() => 0),
    isNotSameChildren: jest.fn(() => false),
    getUpdatedTabsetChildren: jest.fn(() => []),
    getTabIndexFromName: jest.fn(() => 0),
}));

const registerTabMockFn = jest.fn();

describe('<Tabset />', () => {
    it('should render the children passed', () => {
        const component = mount(
            <Tabset>
                <p>testing tabset</p>
            </Tabset>,
        );
        expect(component.find('p').text()).toBe('testing tabset');
    });
    it('should render children with only one tab', () => {
        const component = mount(
            <Tabset activeTabName="tab-1">
                <Tab label="Tab-1" name="tab-1" registerTab={registerTabMockFn} />
            </Tabset>,
        );
        const item1 = component.find('Tab[name="tab-1"]').find(StyledButton);
        expect(item1.prop('isActive')).toBe(true);
    });
    it('should set isActive to true only on the third Tab when activeTabName is tab-3', () => {
        const component = mount(
            <Tabset activeTabName="tab-3">
                <Tab label="Tab-1" name="tab-1" registerTab={registerTabMockFn} />
                <Tab label="Tab-2" name="tab-2" registerTab={registerTabMockFn} />
                <Tab label="Tab-3" name="tab-3" registerTab={registerTabMockFn} />
            </Tabset>,
        );
        const item1 = component.find('Tab[name="tab-1"]').find(StyledButton);
        const item2 = component.find('Tab[name="tab-2"]').find(StyledButton);
        const item3 = component.find('Tab[name="tab-3"]').find(StyledButton);
        expect(item1.prop('isActive')).toBe(false);
        expect(item2.prop('isActive')).toBe(false);
        expect(item3.prop('isActive')).toBe(true);
    });
    it('should call onSelect event with the right data when an item is clicked', () => {
        const onSelectMockFn = jest.fn();
        const component = mount(
            <Tabset onSelect={onSelectMockFn}>
                <Tab label="Tab-1" name="tab-1" registerTab={registerTabMockFn} />
                <Tab label="Tab-2" name="tab-2" registerTab={registerTabMockFn} />
                <Tab label="Tab-3" name="tab-3" registerTab={registerTabMockFn} />
            </Tabset>,
        );
        component.instance().tabsetRef.current.scrollTo = jest.fn();
        const item2 = component.find('Tab[name="tab-2"]').find('button');
        item2.simulate('click');
        expect(onSelectMockFn).toHaveBeenCalledWith(expect.any(Object), 'tab-2');
    });
    it('should call scrollToSelectedTab function with the right data when an item is clicked', () => {
        const onSelectMockFn = jest.fn();
        const component = mount(
            <Tabset onSelect={onSelectMockFn}>
                <Tab label="Tab-1" name="tab-1" registerTab={registerTabMockFn} />
                <Tab label="Tab-2" name="tab-2" registerTab={registerTabMockFn} />
                <Tab label="Tab-3" name="tab-3" registerTab={registerTabMockFn} />
            </Tabset>,
        );
        component.instance().scrollToSelectedTab = jest.fn();
        const item1 = component.find('Tab[name="tab-1"]').find('button');
        item1.simulate('click');
        expect(component.instance().scrollToSelectedTab).toHaveBeenCalledWith('tab-1');
    });
    it('should not call updateButtonsVisibility function if any child is changed', () => {
        isNotSameChildren.mockReset();
        isNotSameChildren.mockReturnValue(false);
        const component = mount(
            <Tabset>
                <Tab label="Tab-1" name="tab-1" registerTab={registerTabMockFn} />
                <Tab label="Tab-2" name="tab-2" registerTab={registerTabMockFn} />
                <Tab label="Tab-3" name="tab-3" registerTab={registerTabMockFn} />
            </Tabset>,
        );
        component.instance().updateButtonsVisibility = jest.fn();
        component.setProps();
        expect(component.instance().updateButtonsVisibility).toHaveBeenCalledTimes(0);
    });
    it('should call updateButtonsVisibility function and set isFirstTime to false when all children are registered and is first time', () => {
        isNotSameChildren.mockReset();
        isNotSameChildren.mockReturnValue(false);
        const component = mount(
            <Tabset activeTabName="tab-1">
                <Tab label="Tab-1" name="tab-1" registerTab={registerTabMockFn} />
                <Tab label="Tab-2" name="tab-2" registerTab={registerTabMockFn} />
                <Tab label="Tab-3" name="tab-3" registerTab={registerTabMockFn} />
            </Tabset>,
        );
        component.instance().updateButtonsVisibility = jest.fn();
        expect(component.instance().isFirstTime).toBe(true);
        component.instance().tabsetChildren = [
            <Tab label="Tab-1" name="tab-1" registerTab={registerTabMockFn} />,
            <Tab label="Tab-2" name="tab-2" registerTab={registerTabMockFn} />,
            <Tab label="Tab-3" name="tab-3" registerTab={registerTabMockFn} />,
        ];
        component.setState({
            key: Date.now(),
        });
        expect(component.instance().updateButtonsVisibility).toHaveBeenCalledTimes(1);
        expect(component.instance().isFirstTime).toBe(false);
    });
    it('should set the left button disabled to true', () => {
        getLeftButtonDisabledState.mockReset();
        getLeftButtonDisabledState.mockReturnValue(true);
        const component = mount(
            <Tabset activeTabName="tab-1">
                <Tab label="Tab-1" name="tab-1" registerTab={registerTabMockFn} />
                <Tab label="Tab-2" name="tab-2" registerTab={registerTabMockFn} />
                <Tab label="Tab-3" name="tab-3" registerTab={registerTabMockFn} />
            </Tabset>,
        );
        component.setState({ areButtonsVisible: true });
        const leftButton = component.find('button[data-id="button-icon-element"]').at(0);
        expect(leftButton.prop('disabled')).toBe(true);
    });
    it('should set the right button disabled to true', () => {
        getRightButtonDisabledState.mockReset();
        getRightButtonDisabledState.mockReturnValue(true);
        const component = mount(
            <Tabset activeTabName="tab-1">
                <Tab label="Tab-1" name="tab-1" registerTab={registerTabMockFn} />
                <Tab label="Tab-2" name="tab-2" registerTab={registerTabMockFn} />
                <Tab label="Tab-3" name="tab-3" registerTab={registerTabMockFn} />
            </Tabset>,
        );
        component.setState({ areButtonsVisible: true });
        const leftButton = component.find('button[data-id="button-icon-element"]').at(1);
        expect(leftButton.prop('disabled')).toBe(true);
    });
    it('should set the areButtonsVisible to true when children total width is more than tabset width', () => {
        isNotSameChildren.mockReset();
        getChildrenTotalWidth.mockReturnValue(600);
        const component = mount(
            <Tabset activeTabName="tab-1">
                <Tab label="Tab-1" name="tab-1" registerTab={registerTabMockFn} />
                <Tab label="Tab-2" name="tab-2" registerTab={registerTabMockFn} />
                <Tab label="Tab-3" name="tab-3" registerTab={registerTabMockFn} />
            </Tabset>,
        );
        component.instance().tabsetRef.current = { offsetWidth: 500 };
        component.instance().tabsetChildren = [
            <Tab label="Tab-1" name="tab-1" registerTab={registerTabMockFn} />,
            <Tab label="Tab-2" name="tab-2" registerTab={registerTabMockFn} />,
            <Tab label="Tab-3" name="tab-3" registerTab={registerTabMockFn} />,
        ];
        component.setState({
            key: Date.now(),
        });
        expect(component.state().areButtonsVisible).toBe(true);
    });
    it('should set the areButtonsVisible to false when children total width is less than tabset width', () => {
        isNotSameChildren.mockReset();
        getChildrenTotalWidth.mockReturnValue(500);
        const component = mount(
            <Tabset activeTabName="tab-1">
                <Tab label="Tab-1" name="tab-1" registerTab={registerTabMockFn} />
                <Tab label="Tab-2" name="tab-2" registerTab={registerTabMockFn} />
                <Tab label="Tab-3" name="tab-3" registerTab={registerTabMockFn} />
            </Tabset>,
        );
        component.instance().tabsetRef.current = { offsetWidth: 600 };
        component.setState({
            tabsetChildren: [
                <Tab label="Tab-1" name="tab-1" registerTab={registerTabMockFn} />,
                <Tab label="Tab-2" name="tab-2" registerTab={registerTabMockFn} />,
                <Tab label="Tab-3" name="tab-3" registerTab={registerTabMockFn} />,
            ],
        });
        component.setProps();
        expect(component.state().areButtonsVisible).toBe(false);
    });
    it('should set the right scroll motion when click on the first tab', () => {
        getTabIndexFromName.mockReset();
        getTabIndexFromName.mockReturnValue(0);
        const onSelectMockFn = jest.fn();
        const component = mount(
            <Tabset onSelect={onSelectMockFn} activeTabName="tab-1">
                <Tab label="Tab-1" name="tab-1" registerTab={registerTabMockFn} />
                <Tab label="Tab-2" name="tab-2" registerTab={registerTabMockFn} />
                <Tab label="Tab-3" name="tab-3" registerTab={registerTabMockFn} />
            </Tabset>,
        );
        component.instance().tabsetRef.current.scrollTo = jest.fn();
        const item1 = component.find('Tab[name="tab-1"]').find('button');
        item1.simulate('click');
        expect(component.instance().tabsetRef.current.scrollTo).toHaveBeenCalledWith(0, 0);
    });
    it('should set the right scroll motion when click on a tab that is out of view on the left side', () => {
        getChildrenTotalWidthUpToClickedTab.mockReset();
        getChildrenTotalWidthUpToClickedTab.mockReturnValue(400);
        getTabIndexFromName.mockReset();
        getTabIndexFromName.mockReturnValue(2);
        const onSelectMockFn = jest.fn();
        const component = mount(
            <Tabset onSelect={onSelectMockFn}>
                <Tab label="Tab-1" name="tab-1" registerTab={registerTabMockFn} />
                <Tab label="Tab-2" name="tab-2" registerTab={registerTabMockFn} />
                <Tab label="Tab-3" name="tab-3" registerTab={registerTabMockFn} />
            </Tabset>,
        );
        component.instance().tabsetRef.current = {
            scrollLeft: 600,
            offsetWidth: 600,
        };
        component.instance().tabsetRef.current.scrollTo = jest.fn();
        const item2 = component.find('Tab[name="tab-2"]').find('button');
        item2.simulate('click');
        expect(component.instance().tabsetRef.current.scrollTo).toHaveBeenCalledWith(400, 0);
    });
    it('should set the right scroll motion when click on a tab that is out of view on the right side', () => {
        getChildrenTotalWidthUpToClickedTab.mockReset();
        getChildrenTotalWidthUpToClickedTab.mockReturnValue(500);
        getTabIndexFromName.mockReset();
        getTabIndexFromName.mockReturnValue(2);
        const onSelectMockFn = jest.fn();
        const component = mount(
            <Tabset onSelect={onSelectMockFn}>
                <Tab label="Tab-1" name="tab-1" registerTab={registerTabMockFn} />
                <Tab label="Tab-2" name="tab-2" registerTab={registerTabMockFn} />
                <Tab label="Tab-3" name="tab-3" registerTab={registerTabMockFn} />
            </Tabset>,
        );
        component.instance().tabsetRef.current = {
            scrollLeft: 200,
            offsetWidth: 300,
        };
        component.instance().tabsetRef.current.scrollTo = jest.fn();
        const item3 = component.find('Tab[name="tab-3"]').find('button');
        item3.simulate('click');
        expect(component.instance().tabsetRef.current.scrollTo).toHaveBeenCalledWith(220, 0);
    });
});