eventTitle.spec.tsx 4.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135
  1. import {EventFixture} from 'sentry-fixture/event';
  2. import {GroupFixture} from 'sentry-fixture/group';
  3. import {render, screen, userEvent} from 'sentry-test/reactTestingLibrary';
  4. import {SectionKey, useIssueDetails} from 'sentry/views/issueDetails/streamline/context';
  5. import {EventTitle} from './eventTitle';
  6. jest.mock('sentry/views/issueDetails/streamline/context');
  7. describe('EventNavigation', () => {
  8. const testEvent = EventFixture({
  9. id: 'event-id',
  10. size: 7,
  11. dateCreated: '2019-03-20T00:00:00.000Z',
  12. errors: [],
  13. entries: [],
  14. tags: [
  15. {key: 'environment', value: 'dev'},
  16. {key: 'replayId', value: 'replay-id'},
  17. ],
  18. previousEventID: 'prev-event-id',
  19. nextEventID: 'next-event-id',
  20. });
  21. const defaultProps: React.ComponentProps<typeof EventTitle> = {
  22. event: testEvent,
  23. group: GroupFixture({id: 'group-id'}),
  24. };
  25. beforeEach(() => {
  26. jest.resetAllMocks();
  27. jest.mocked(useIssueDetails).mockReturnValue({
  28. sectionData: {
  29. highlights: {key: SectionKey.HIGHLIGHTS},
  30. tags: {key: SectionKey.TAGS},
  31. replay: {key: SectionKey.REPLAY},
  32. },
  33. eventCount: 0,
  34. isSidebarOpen: true,
  35. navScrollMargin: 0,
  36. dispatch: jest.fn(),
  37. });
  38. Object.assign(navigator, {
  39. clipboard: {writeText: jest.fn().mockResolvedValue('')},
  40. });
  41. window.open = jest.fn();
  42. MockApiClient.addMockResponse({
  43. url: `/projects/org-slug/project-slug/events/event-id/actionable-items/`,
  44. body: {
  45. errors: [],
  46. },
  47. method: 'GET',
  48. });
  49. });
  50. it('does not show jump to sections by default', () => {
  51. jest.mocked(useIssueDetails).mockReturnValue({
  52. sectionData: {},
  53. eventCount: 0,
  54. isSidebarOpen: true,
  55. navScrollMargin: 0,
  56. dispatch: jest.fn(),
  57. });
  58. render(<EventTitle {...defaultProps} />);
  59. expect(screen.queryByText('Jump To:')).not.toBeInTheDocument();
  60. expect(screen.queryByText('Replay')).not.toBeInTheDocument();
  61. expect(screen.queryByText('Tags')).not.toBeInTheDocument();
  62. expect(screen.queryByText('Highlights')).not.toBeInTheDocument();
  63. });
  64. it('does show jump to sections when the sections render', () => {
  65. render(<EventTitle {...defaultProps} />);
  66. expect(screen.getByText('Jump to:')).toBeInTheDocument();
  67. expect(screen.getByText('Highlights')).toBeInTheDocument();
  68. expect(screen.getByText('Replay')).toBeInTheDocument();
  69. expect(screen.getByText('Tags')).toBeInTheDocument();
  70. });
  71. it('can copy event ID', async () => {
  72. render(<EventTitle {...defaultProps} />);
  73. await userEvent.click(screen.getByRole('button', {name: 'Event actions'}));
  74. await userEvent.click(screen.getByRole('menuitemradio', {name: 'Copy Event ID'}));
  75. expect(navigator.clipboard.writeText).toHaveBeenCalledWith(testEvent.id);
  76. });
  77. it('shows event actions dropdown', async () => {
  78. render(<EventTitle {...defaultProps} />);
  79. await userEvent.click(screen.getByRole('button', {name: 'Event actions'}));
  80. await userEvent.click(screen.getByRole('menuitemradio', {name: 'Copy Event ID'}));
  81. expect(navigator.clipboard.writeText).toHaveBeenCalledWith(testEvent.id);
  82. await userEvent.click(screen.getByRole('button', {name: 'Event actions'}));
  83. await userEvent.click(screen.getByRole('menuitemradio', {name: 'Copy Event Link'}));
  84. expect(navigator.clipboard.writeText).toHaveBeenCalledWith(
  85. `http://localhost/organizations/org-slug/issues/group-id/events/event-id/`
  86. );
  87. await userEvent.click(screen.getByRole('button', {name: 'Event actions'}));
  88. await userEvent.click(screen.getByRole('menuitemradio', {name: 'View JSON'}));
  89. expect(window.open).toHaveBeenCalledWith(
  90. `https://us.sentry.io/api/0/projects/org-slug/project-slug/events/event-id/json/`
  91. );
  92. });
  93. it('shows processing issue button if there is an event error', async () => {
  94. MockApiClient.addMockResponse({
  95. url: `/projects/org-slug/project-slug/events/event-id/actionable-items/`,
  96. body: {
  97. errors: [
  98. {
  99. type: 'invalid_data',
  100. data: {
  101. name: 'logentry',
  102. },
  103. message: 'no message present',
  104. },
  105. ],
  106. },
  107. method: 'GET',
  108. });
  109. render(<EventTitle {...defaultProps} />);
  110. expect(
  111. await screen.findByRole('button', {name: 'Processing Error'})
  112. ).toBeInTheDocument();
  113. });
  114. });