nexxtway/react-rainbow

View on GitHub
src/components/InternalDropdown/helpers/__test__/isOptionVisible.spec.js

Summary

Maintainability
A
2 hrs
Test Coverage
import isOptionVisible from '../isOptionVisible';

let container;

describe('isOptionVisible', () => {
    beforeEach(() => {
        container = { top: 203.03334045410156, bottom: 428.03334045410156 };
        container.getBoundingClientRect = jest.fn(() => ({
            top: container.top,
            bottom: container.bottom,
        }));
    });

    it('should return true when element is within container visible bounds', () => {
        const elements = [
            { top: 237.78334045410156, bottom: 282.78334045410156 },
            { top: 317.5333251953125, bottom: 362.5333251953125 },
            { top: 362.5333251953125, bottom: 407.5333251953125 },
        ].map(element => ({
            top: element.top,
            bottom: element.bottom,
            getBoundingClientRect: jest.fn(() => ({
                top: element.top,
                bottom: element.bottom,
            })),
        }));

        elements.forEach(element => {
            expect(isOptionVisible(element, container)).toBe(true);
        });
    });
    it('should return false when element is not within container visible bounds', () => {
        const elements = [
            { top: 407.5333251953125, bottom: 452.5333251953125 },
            { top: 452.5333251953125, bottom: 497.5333251953125 },
        ].map(element => ({
            top: element.top,
            bottom: element.bottom,
            getBoundingClientRect: jest.fn(() => ({
                top: element.top,
                bottom: element.bottom,
            })),
        }));

        elements.forEach(element => {
            expect(isOptionVisible(element, container)).toBe(false);
        });
    });
});