nexxtway/react-rainbow

View on GitHub
src/components/Avatar/__test__/avatarContent.spec.js

Summary

Maintainability
A
3 hrs
Test Coverage
import React from 'react';
import { mount } from 'enzyme';
import AvatarContent from '../avatarContent';
import StyledImage from '../styled/image';

describe('<AvatarContent/>', () => {
    it('should render an img when src is passed', () => {
        const component = mount(<AvatarContent src="images/user/user1.jpg" />);
        expect(component.find('img').exists()).toBe(true);
    });
    it('should pass right props to the img element when a valid src is passed', () => {
        const component = mount(<AvatarContent src="images/user/user1.jpg" title="Title" />);
        expect(component.find(StyledImage).props()).toEqual({
            src: 'images/user/user1.jpg',
            onError: expect.any(Function),
            title: 'Title',
        });
    });
    it('should render an abbr when src is not passed and initials props is passed', () => {
        const component = mount(<AvatarContent initials="JD" />);
        expect(component.find('abbr').exists()).toBe(true);
    });
    it('should pass right props to the abbr element when src is not passed and initials props is passed', () => {
        const component = mount(
            <AvatarContent initialsVariant="default" initials="JD" title="Title" />,
        );
        expect(component.find('abbr').props()).toEqual({
            children: 'JD',
            className: expect.any(String),
            title: 'Title',
        });
    });
    it('should return the icon passed when src and initials are not passed', () => {
        const component = mount(<AvatarContent icon={<svg />} />);
        expect(component.find('svg').exists()).toBe(true);
    });
});