You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

Avatar-test.tsx 1.9KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657
  1. /*
  2. * SonarQube
  3. * Copyright (C) 2009-2022 SonarSource SA
  4. * mailto:info AT sonarsource DOT com
  5. *
  6. * This program is free software; you can redistribute it and/or
  7. * modify it under the terms of the GNU Lesser General Public
  8. * License as published by the Free Software Foundation; either
  9. * version 3 of the License, or (at your option) any later version.
  10. *
  11. * This program is distributed in the hope that it will be useful,
  12. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  13. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
  14. * Lesser General Public License for more details.
  15. *
  16. * You should have received a copy of the GNU Lesser General Public License
  17. * along with this program; if not, write to the Free Software Foundation,
  18. * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
  19. */
  20. import { shallow } from 'enzyme';
  21. import * as React from 'react';
  22. import { mockAppState } from '../../../helpers/testMocks';
  23. import { GlobalSettingKeys } from '../../../types/settings';
  24. import { Avatar } from '../Avatar';
  25. const gravatarServerUrl = 'http://example.com/{EMAIL_MD5}.jpg?s={SIZE}';
  26. it('should be able to render with hash only', () => {
  27. const avatar = shallow(
  28. <Avatar
  29. appState={mockAppState({
  30. settings: {
  31. [GlobalSettingKeys.EnableGravatar]: 'true',
  32. [GlobalSettingKeys.GravatarServerUrl]: gravatarServerUrl
  33. }
  34. })}
  35. hash="7daf6c79d4802916d83f6266e24850af"
  36. name="Foo"
  37. size={30}
  38. />
  39. );
  40. expect(avatar).toMatchSnapshot();
  41. });
  42. it('falls back to dummy avatar', () => {
  43. const avatar = shallow(
  44. <Avatar appState={mockAppState({ settings: {} })} name="Foo Bar" size={30} />
  45. );
  46. expect(avatar).toMatchSnapshot();
  47. });
  48. it('do not fail when name is missing', () => {
  49. const avatar = shallow(
  50. <Avatar appState={mockAppState({ settings: {} })} name={undefined} size={30} />
  51. );
  52. expect(avatar.getElement()).toBeNull();
  53. });