import React from 'react'; import { shallow, mount } from 'enzyme'; import { act } from 'react-dom/test-utils'; import Avatar from '../Avatar'; import AvatarImage from '../AvatarImage'; const testDataURI = 'data:image/gif;base64,R0lGODlhAQABAIAAAAAAAP///yH5BAEAAAAALAAAAAABAAEAAAIBRAA7'; describe('components/avatar/Avatar', () => { test('should render an avatar container', () => { const wrapper = shallow(); expect(wrapper.is('.avatar.test-avatar')).toBe(true); }); test('should add small size class based on prop', () => { const wrapper = shallow(); expect(wrapper.is('.avatar.avatar--small')).toBe(true); }); test('should add large size class based on prop', () => { const wrapper = shallow(); expect(wrapper.is('.avatar.avatar--large')).toBe(true); }); test('should not allow unknown sizes', () => { // eslint-disable-next-line // @ts-ignore testing a wrong value for the size prop const wrapper = shallow(); expect(wrapper.is('.avatar.avatar--WRONG')).toBe(false); }); test('should render an AvatarImage when avatarUrl is passed in', () => { const wrapper = shallow(); const avatarImage = wrapper.find(AvatarImage); expect(avatarImage.length).toEqual(1); expect(avatarImage.prop('url')).toEqual(testDataURI); }); test('should render an AvatarInitials when name is passed in', () => { const wrapper = shallow(); const avatarInitials = wrapper.find('AvatarInitials'); expect(avatarInitials.length).toEqual(1); expect(avatarInitials.prop('name')).toEqual('hello world'); expect(avatarInitials.prop('id')).toEqual('1'); }); test('should render an UnknownUserAvatar when no params are passed', () => { const wrapper = shallow(); const avatarIcon = wrapper.find('UnknownUserAvatar'); expect(avatarIcon.length).toEqual(1); expect(avatarIcon.prop('className')).toEqual('avatar-icon'); }); test('should render an UnknownUserAvatar when empty name and url are passed', () => { const wrapper = shallow(); const avatarIcon = wrapper.find('UnknownUserAvatar'); expect(avatarIcon.length).toEqual(1); expect(avatarIcon.prop('className')).toEqual('avatar-icon'); }); test('should fall back to AvatarInitials when there is an error in AvatarImage', () => { const wrapper = shallow(); const avatarImage = wrapper.find(AvatarImage); const onError = avatarImage.prop('onError') as Function; onError(); const avatarInitials = wrapper.find('AvatarInitials'); expect(avatarInitials.length).toEqual(1); }); test('should show external user icon only when requested', () => { const externalWrapper = shallow(); const nonExternalWrapper = shallow(); expect(externalWrapper.is('.avatar.avatar--isExternal')).toBe(true); expect(nonExternalWrapper.is('.avatar.avatar--isExternal')).toBe(false); }); test('should reset error state when new avatarUrl is passed in', () => { const props = { id: '1', name: 'hello world', avatarUrl: 'http://foo.bar/baz123_invalid', }; const wrapper = mount(); expect(wrapper.find(AvatarImage).length).toEqual(1); act(() => { const avatarImage = wrapper.find(AvatarImage); const onError = avatarImage.prop('onError') as Function; onError(); }); wrapper.update(); expect(wrapper.find(AvatarImage).length).toEqual(0); expect(wrapper.find('AvatarInitials').length).toEqual(1); act(() => { wrapper.setProps({ ...props, avatarUrl: 'http://foo.bar/baz123_invalid_new', }); }); wrapper.update(); expect(wrapper.find(AvatarImage).length).toEqual(1); }); });