groupDetailsLayout.spec.tsx 3.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100
  1. import {EventFixture} from 'sentry-fixture/event';
  2. import {EventsStatsFixture} from 'sentry-fixture/events';
  3. import {GroupFixture} from 'sentry-fixture/group';
  4. import {OrganizationFixture} from 'sentry-fixture/organization';
  5. import {ProjectFixture} from 'sentry-fixture/project';
  6. import {TagsFixture} from 'sentry-fixture/tags';
  7. import {render, screen, userEvent} from 'sentry-test/reactTestingLibrary';
  8. import ProjectsStore from 'sentry/stores/projectsStore';
  9. import {ReprocessingStatus} from 'sentry/views/issueDetails/utils';
  10. import {GroupDetailsLayout} from './groupDetailsLayout';
  11. describe('GroupDetailsLayout', () => {
  12. const organization = OrganizationFixture();
  13. const group = GroupFixture();
  14. const event = EventFixture();
  15. const project = ProjectFixture();
  16. beforeEach(() => {
  17. ProjectsStore.init();
  18. ProjectsStore.loadInitialData([project]);
  19. MockApiClient.addMockResponse({
  20. url: '/organizations/org-slug/replay-count/',
  21. body: {},
  22. });
  23. MockApiClient.addMockResponse({
  24. url: `/organizations/org-slug/repos/`,
  25. body: {},
  26. });
  27. MockApiClient.addMockResponse({
  28. url: `/organizations/${organization.slug}/releases/stats/`,
  29. body: [],
  30. });
  31. MockApiClient.addMockResponse({
  32. url: `/organizations/${organization.slug}/issues/${group.id}/attachments/`,
  33. body: [],
  34. });
  35. MockApiClient.addMockResponse({
  36. url: `/organizations/${organization.slug}/users/`,
  37. body: [],
  38. });
  39. MockApiClient.addMockResponse({
  40. url: `/organizations/${organization.slug}/issues/${group.id}/first-last-release/`,
  41. });
  42. MockApiClient.addMockResponse({
  43. url: `/organizations/${organization.slug}/issues/${group.id}/external-issues/`,
  44. body: [],
  45. });
  46. MockApiClient.addMockResponse({
  47. url: `/organizations/${organization.slug}/issues/${group.id}/integrations/`,
  48. body: [],
  49. });
  50. MockApiClient.addMockResponse({
  51. url: `/organizations/${organization.slug}/events-stats/`,
  52. body: {'count()': EventsStatsFixture(), 'count_unique(user)': EventsStatsFixture()},
  53. });
  54. MockApiClient.addMockResponse({
  55. url: `/organizations/${organization.slug}/events/`,
  56. body: {data: [{'count_unique(user)': 21}]},
  57. });
  58. MockApiClient.addMockResponse({
  59. url: `/projects/${organization.slug}/${project.slug}/events/${event.id}/owners/`,
  60. body: {owners: [], rules: []},
  61. });
  62. MockApiClient.addMockResponse({
  63. url: `/organizations/${organization.slug}/issues/${group.id}/tags/`,
  64. body: TagsFixture(),
  65. });
  66. MockApiClient.addMockResponse({
  67. url: '/projects/org-slug/project-slug/events/1/committers/',
  68. body: {committers: []},
  69. });
  70. });
  71. it('renders children, can collapse sidebar', async () => {
  72. render(
  73. <GroupDetailsLayout
  74. group={group}
  75. event={event}
  76. project={project}
  77. groupReprocessingStatus={ReprocessingStatus.NO_STATUS}
  78. >
  79. <div data-test-id="children" />
  80. </GroupDetailsLayout>
  81. );
  82. expect(await screen.findByTestId('children')).toBeInTheDocument();
  83. expect(
  84. await screen.findByText('Track this issue in Jira, GitHub, etc.')
  85. ).toBeInTheDocument();
  86. await userEvent.click(screen.getByRole('button', {name: 'Close Sidebar'}));
  87. expect(await screen.findByTestId('children')).toBeInTheDocument();
  88. expect(
  89. screen.queryByText('Track this issue in Jira, GitHub, etc.')
  90. ).not.toBeInTheDocument();
  91. });
  92. });