index.spec.jsx 5.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149
  1. import * as PropTypes from 'prop-types';
  2. import {
  3. render,
  4. renderGlobalModal,
  5. screen,
  6. userEvent,
  7. } from 'sentry-test/reactTestingLibrary';
  8. import ProjectKeyDetails from 'sentry/views/settings/project/projectKeys/details';
  9. describe('ProjectKeyDetails', function () {
  10. let org;
  11. let project;
  12. let deleteMock;
  13. let statsMock;
  14. let putMock;
  15. let projectKeys;
  16. beforeEach(function () {
  17. org = TestStubs.Organization();
  18. project = TestStubs.Project();
  19. projectKeys = TestStubs.ProjectKeys();
  20. MockApiClient.clearMockResponses();
  21. MockApiClient.addMockResponse({
  22. url: `/projects/${org.slug}/${project.slug}/keys/${projectKeys[0].id}/`,
  23. method: 'GET',
  24. body: projectKeys[0],
  25. });
  26. putMock = MockApiClient.addMockResponse({
  27. url: `/projects/${org.slug}/${project.slug}/keys/${projectKeys[0].id}/`,
  28. method: 'PUT',
  29. });
  30. statsMock = MockApiClient.addMockResponse({
  31. url: `/projects/${org.slug}/${project.slug}/keys/${projectKeys[0].id}/stats/`,
  32. method: 'GET',
  33. body: [
  34. {filtered: 0, accepted: 0, total: 0, ts: 1517270400, dropped: 0},
  35. {filtered: 0, accepted: 0, total: 0, ts: 1517356800, dropped: 0},
  36. {filtered: 0, accepted: 0, total: 0, ts: 1517443200, dropped: 0},
  37. {filtered: 0, accepted: 0, total: 0, ts: 1517529600, dropped: 0},
  38. {filtered: 0, accepted: 0, total: 0, ts: 1517616000, dropped: 0},
  39. {filtered: 0, accepted: 0, total: 0, ts: 1517702400, dropped: 0},
  40. {filtered: 0, accepted: 0, total: 0, ts: 1517788800, dropped: 0},
  41. {filtered: 0, accepted: 0, total: 0, ts: 1517875200, dropped: 0},
  42. {filtered: 0, accepted: 0, total: 0, ts: 1517961600, dropped: 0},
  43. {filtered: 0, accepted: 0, total: 0, ts: 1518048000, dropped: 0},
  44. {filtered: 0, accepted: 0, total: 0, ts: 1518134400, dropped: 0},
  45. {filtered: 0, accepted: 0, total: 0, ts: 1518220800, dropped: 0},
  46. {filtered: 0, accepted: 0, total: 0, ts: 1518307200, dropped: 0},
  47. {filtered: 0, accepted: 0, total: 0, ts: 1518393600, dropped: 0},
  48. {filtered: 0, accepted: 0, total: 0, ts: 1518480000, dropped: 0},
  49. {filtered: 0, accepted: 0, total: 0, ts: 1518566400, dropped: 0},
  50. {filtered: 0, accepted: 0, total: 0, ts: 1518652800, dropped: 0},
  51. {filtered: 0, accepted: 0, total: 0, ts: 1518739200, dropped: 0},
  52. {filtered: 0, accepted: 0, total: 0, ts: 1518825600, dropped: 0},
  53. {filtered: 0, accepted: 0, total: 0, ts: 1518912000, dropped: 0},
  54. {filtered: 0, accepted: 0, total: 0, ts: 1518998400, dropped: 0},
  55. {filtered: 0, accepted: 0, total: 0, ts: 1519084800, dropped: 0},
  56. {filtered: 0, accepted: 0, total: 0, ts: 1519171200, dropped: 0},
  57. {filtered: 0, accepted: 0, total: 0, ts: 1519257600, dropped: 0},
  58. {filtered: 0, accepted: 0, total: 0, ts: 1519344000, dropped: 0},
  59. {filtered: 0, accepted: 0, total: 0, ts: 1519430400, dropped: 0},
  60. {filtered: 0, accepted: 0, total: 0, ts: 1519516800, dropped: 0},
  61. {filtered: 0, accepted: 0, total: 0, ts: 1519603200, dropped: 0},
  62. {filtered: 0, accepted: 0, total: 0, ts: 1519689600, dropped: 0},
  63. {filtered: 0, accepted: 5, total: 12, ts: 1519776000, dropped: 7},
  64. {filtered: 0, accepted: 14, total: 14, ts: 1519862400, dropped: 0},
  65. ],
  66. });
  67. deleteMock = MockApiClient.addMockResponse({
  68. url: `/projects/${org.slug}/${project.slug}/keys/${projectKeys[0].id}/`,
  69. method: 'DELETE',
  70. });
  71. const context = {
  72. context: {
  73. project: TestStubs.Project(),
  74. },
  75. childContextTypes: {
  76. project: PropTypes.object,
  77. },
  78. };
  79. render(
  80. <ProjectKeyDetails
  81. routes={[]}
  82. organization={org}
  83. project={project}
  84. params={{
  85. keyId: projectKeys[0].id,
  86. orgId: org.slug,
  87. projectId: project.slug,
  88. }}
  89. />,
  90. {context}
  91. );
  92. });
  93. it('has stats box', function () {
  94. expect(screen.getByText('Key Details')).toBeInTheDocument();
  95. expect(statsMock).toHaveBeenCalled();
  96. });
  97. it('changes name', async function () {
  98. await userEvent.clear(screen.getByRole('textbox', {name: 'Name'}));
  99. await userEvent.type(screen.getByRole('textbox', {name: 'Name'}), 'New Name');
  100. await userEvent.tab();
  101. expect(putMock).toHaveBeenCalledWith(
  102. `/projects/${org.slug}/${project.slug}/keys/${projectKeys[0].id}/`,
  103. expect.objectContaining({
  104. data: {
  105. name: 'New Name',
  106. },
  107. })
  108. );
  109. });
  110. it('disable and enables key', async function () {
  111. await userEvent.click(screen.getByRole('checkbox', {name: 'Enabled'}));
  112. expect(putMock).toHaveBeenCalledWith(
  113. `/projects/${org.slug}/${project.slug}/keys/${projectKeys[0].id}/`,
  114. expect.objectContaining({
  115. data: {isActive: false},
  116. })
  117. );
  118. await userEvent.click(screen.getByRole('checkbox', {name: 'Enabled'}));
  119. expect(putMock).toHaveBeenCalledWith(
  120. `/projects/${org.slug}/${project.slug}/keys/${projectKeys[0].id}/`,
  121. expect.objectContaining({
  122. data: {isActive: false},
  123. })
  124. );
  125. });
  126. it('revokes a key', async function () {
  127. await userEvent.click(screen.getByRole('button', {name: 'Revoke Key'}));
  128. renderGlobalModal();
  129. await userEvent.click(screen.getByTestId('confirm-button'));
  130. expect(deleteMock).toHaveBeenCalled();
  131. });
  132. });