duplicate.spec.tsx 4.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175
  1. import {Fragment} from 'react';
  2. import {initializeOrg} from 'sentry-test/initializeOrg';
  3. import {render, screen} from 'sentry-test/reactTestingLibrary';
  4. import GlobalModal from 'sentry/components/globalModal';
  5. import MetricRulesDuplicate from 'sentry/views/alerts/rules/metric/duplicate';
  6. import {AlertRuleTriggerType} from 'sentry/views/alerts/rules/metric/types';
  7. describe('Incident Rules Duplicate', function () {
  8. beforeAll(function () {
  9. MockApiClient.addMockResponse({
  10. url: '/organizations/org-slug/users/',
  11. body: [],
  12. });
  13. MockApiClient.addMockResponse({
  14. url: '/organizations/org-slug/tags/',
  15. body: [],
  16. });
  17. MockApiClient.addMockResponse({
  18. url: '/projects/org-slug/project-slug/environments/',
  19. body: [],
  20. });
  21. MockApiClient.addMockResponse({
  22. url: '/organizations/org-slug/events-stats/',
  23. body: null,
  24. });
  25. MockApiClient.addMockResponse({
  26. url: '/organizations/org-slug/events-meta/',
  27. body: {count: 5},
  28. });
  29. MockApiClient.addMockResponse({
  30. url: '/organizations/org-slug/alert-rules/available-actions/',
  31. body: [
  32. {
  33. allowedTargetTypes: ['user', 'team'],
  34. integrationName: null,
  35. type: 'email',
  36. integrationId: null,
  37. },
  38. {
  39. allowedTargetTypes: ['specific'],
  40. integrationName: null,
  41. type: 'slack',
  42. integrationId: 1,
  43. },
  44. ],
  45. });
  46. MockApiClient.addMockResponse({
  47. url: '/organizations/org-slug/members/',
  48. body: [TestStubs.Member()],
  49. });
  50. });
  51. it('renders new alert form with values copied over', function () {
  52. const rule = TestStubs.MetricRule();
  53. rule.triggers.push({
  54. label: AlertRuleTriggerType.WARNING,
  55. alertThreshold: 60,
  56. actions: [],
  57. });
  58. rule.resolveThreshold = 50;
  59. const {organization, project, router} = initializeOrg({
  60. organization: {
  61. access: ['alerts:write'],
  62. },
  63. router: {
  64. params: {},
  65. location: {
  66. query: {
  67. createFromDuplicate: true,
  68. duplicateRuleId: `${rule.id}`,
  69. },
  70. },
  71. },
  72. project: rule.projects[0],
  73. projects: rule.projects,
  74. });
  75. const req = MockApiClient.addMockResponse({
  76. url: `/organizations/${organization.slug}/alert-rules/${rule.id}/`,
  77. body: rule,
  78. });
  79. render(
  80. <Fragment>
  81. <GlobalModal />
  82. <MetricRulesDuplicate
  83. params={{}}
  84. route={{}}
  85. routeParams={router.params}
  86. router={router}
  87. routes={router.routes}
  88. location={router.location}
  89. organization={organization}
  90. project={project}
  91. userTeamIds={[]}
  92. />
  93. </Fragment>
  94. );
  95. // Duplicated alert has been called
  96. expect(req).toHaveBeenCalled();
  97. // Has correct values copied from the duplicated alert
  98. expect(screen.getByTestId('critical-threshold')).toHaveValue('70');
  99. expect(screen.getByTestId('warning-threshold')).toHaveValue('60');
  100. expect(screen.getByTestId('resolve-threshold')).toHaveValue('50');
  101. // Has the updated alert rule name
  102. expect(screen.getByTestId('alert-name')).toHaveValue(`${rule.name} copy`);
  103. });
  104. it('duplicates slack actions', function () {
  105. const rule = TestStubs.MetricRule();
  106. rule.triggers[0].actions.push({
  107. id: '13',
  108. alertRuleTriggerId: '12',
  109. type: 'slack',
  110. targetType: 'specific',
  111. targetIdentifier: '#feed-ecosystem',
  112. inputChannelId: 'ABC123',
  113. integrationId: 1,
  114. sentryAppId: null,
  115. desc: 'Send a Slack notification to #feed-ecosystem',
  116. });
  117. const {organization, project, router} = initializeOrg({
  118. organization: {
  119. access: ['alerts:write'],
  120. },
  121. router: {
  122. params: {},
  123. location: {
  124. query: {
  125. createFromDuplicate: true,
  126. duplicateRuleId: `${rule.id}`,
  127. },
  128. },
  129. },
  130. project: rule.projects[0],
  131. projects: rule.projects,
  132. });
  133. const req = MockApiClient.addMockResponse({
  134. url: `/organizations/${organization.slug}/alert-rules/${rule.id}/`,
  135. body: rule,
  136. });
  137. render(
  138. <MetricRulesDuplicate
  139. params={{}}
  140. route={{}}
  141. routeParams={router.params}
  142. router={router}
  143. routes={router.routes}
  144. location={router.location}
  145. organization={organization}
  146. project={project}
  147. userTeamIds={[]}
  148. />
  149. );
  150. // Duplicated alert has been called
  151. expect(req).toHaveBeenCalled();
  152. // Still has a selected slack action
  153. expect(screen.getByText('Slack')).toBeInTheDocument();
  154. expect(screen.getByPlaceholderText('optional: channel ID or user ID')).toHaveValue(
  155. 'ABC123'
  156. );
  157. expect(screen.getByText(/Enter a channel or user ID/)).toBeInTheDocument();
  158. });
  159. });