UsersActionBar.test.tsx 1.1 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152
  1. import React from 'react';
  2. import { shallow } from 'enzyme';
  3. import { UsersActionBar, Props } from './UsersActionBar';
  4. const setup = (propOverrides?: object) => {
  5. const props: Props = {
  6. searchQuery: '',
  7. setUsersSearchQuery: jest.fn(),
  8. onShowInvites: jest.fn(),
  9. pendingInvitesCount: 0,
  10. canInvite: false,
  11. externalUserMngLinkUrl: '',
  12. externalUserMngLinkName: '',
  13. showInvites: false,
  14. };
  15. Object.assign(props, propOverrides);
  16. return shallow(<UsersActionBar {...props} />);
  17. };
  18. describe('Render', () => {
  19. it('should render component', () => {
  20. const wrapper = setup();
  21. expect(wrapper).toMatchSnapshot();
  22. });
  23. it('should render pending invites button', () => {
  24. const wrapper = setup({
  25. pendingInvitesCount: 5,
  26. });
  27. expect(wrapper).toMatchSnapshot();
  28. });
  29. it('should show invite button', () => {
  30. const wrapper = setup({
  31. canInvite: true,
  32. });
  33. expect(wrapper).toMatchSnapshot();
  34. });
  35. it('should show external user management button', () => {
  36. const wrapper = setup({
  37. externalUserMngLinkUrl: 'some/url',
  38. });
  39. expect(wrapper).toMatchSnapshot();
  40. });
  41. });