@scality/data-browser-library 1.0.0-preview.8 → 1.0.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (303) hide show
  1. package/dist/components/DataBrowserUI.d.ts +12 -0
  2. package/dist/components/DataBrowserUI.js +99 -0
  3. package/dist/components/Editor.d.ts +1 -1
  4. package/dist/components/Editor.js +3 -3
  5. package/dist/components/__tests__/BucketAccessor.test.js +214 -0
  6. package/dist/components/__tests__/BucketCorsPage.test.d.ts +1 -0
  7. package/dist/components/__tests__/BucketCorsPage.test.js +263 -0
  8. package/dist/components/__tests__/BucketCreate.test.d.ts +1 -0
  9. package/dist/components/__tests__/BucketCreate.test.js +574 -0
  10. package/dist/components/__tests__/BucketDetails.test.d.ts +1 -0
  11. package/dist/components/__tests__/BucketDetails.test.js +421 -0
  12. package/dist/components/__tests__/BucketLifecycleFormPage.test.d.ts +14 -0
  13. package/dist/components/__tests__/BucketLifecycleFormPage.test.js +618 -0
  14. package/dist/components/__tests__/BucketLifecycleList.test.d.ts +1 -0
  15. package/dist/components/__tests__/BucketLifecycleList.test.js +325 -0
  16. package/dist/components/__tests__/BucketList.test.js +495 -81
  17. package/dist/components/__tests__/BucketNotificationFormPage.test.d.ts +1 -0
  18. package/dist/components/__tests__/BucketNotificationFormPage.test.js +348 -0
  19. package/dist/components/__tests__/BucketNotificationList.test.d.ts +1 -0
  20. package/dist/components/__tests__/BucketNotificationList.test.js +379 -0
  21. package/dist/components/__tests__/BucketOverview.test.js +484 -179
  22. package/dist/components/__tests__/BucketPolicyPage.test.js +151 -99
  23. package/dist/components/__tests__/BucketReplicationFormPage.test.d.ts +16 -0
  24. package/dist/components/__tests__/BucketReplicationFormPage.test.js +1757 -0
  25. package/dist/components/__tests__/BucketReplicationList.test.d.ts +1 -0
  26. package/dist/components/__tests__/BucketReplicationList.test.js +344 -0
  27. package/dist/components/__tests__/CreateFolderButton.test.js +56 -56
  28. package/dist/components/__tests__/DeleteBucketButton.test.js +64 -64
  29. package/dist/components/__tests__/DeleteBucketConfigRuleButton.test.d.ts +1 -0
  30. package/dist/components/__tests__/DeleteBucketConfigRuleButton.test.js +196 -0
  31. package/dist/components/__tests__/DeleteObjectButton.test.js +64 -64
  32. package/dist/components/__tests__/EmptyBucketButton.test.d.ts +1 -0
  33. package/dist/components/__tests__/EmptyBucketButton.test.js +302 -0
  34. package/dist/components/__tests__/MetadataSearch.test.js +65 -65
  35. package/dist/components/__tests__/ObjectList.test.js +741 -240
  36. package/dist/components/__tests__/UploadButton.test.js +45 -45
  37. package/dist/components/breadcrumb/Breadcrumb.d.ts +6 -0
  38. package/dist/components/breadcrumb/Breadcrumb.js +37 -0
  39. package/dist/components/breadcrumb/DataBrowserBreadcrumb.d.ts +1 -0
  40. package/dist/components/breadcrumb/DataBrowserBreadcrumb.js +10 -0
  41. package/dist/components/breadcrumb/__tests__/Breadcrumb.test.d.ts +1 -0
  42. package/dist/components/breadcrumb/__tests__/Breadcrumb.test.js +196 -0
  43. package/dist/components/breadcrumb/__tests__/DataBrowserBreadcrumb.test.d.ts +1 -0
  44. package/dist/components/breadcrumb/__tests__/DataBrowserBreadcrumb.test.js +153 -0
  45. package/dist/components/breadcrumb/__tests__/useBreadcrumbPaths.test.d.ts +1 -0
  46. package/dist/components/breadcrumb/__tests__/useBreadcrumbPaths.test.js +134 -0
  47. package/dist/components/breadcrumb/index.d.ts +8 -0
  48. package/dist/components/breadcrumb/index.js +4 -0
  49. package/dist/components/breadcrumb/useBreadcrumbPaths.d.ts +2 -0
  50. package/dist/components/breadcrumb/useBreadcrumbPaths.js +82 -0
  51. package/dist/components/buckets/BucketAccessor.d.ts +2 -0
  52. package/dist/components/buckets/BucketAccessor.js +125 -0
  53. package/dist/components/buckets/BucketConfigEditButton.d.ts +8 -0
  54. package/dist/components/buckets/{BucketPolicyButton.js → BucketConfigEditButton.js} +9 -5
  55. package/dist/components/buckets/BucketCorsPage.d.ts +1 -0
  56. package/dist/components/buckets/BucketCorsPage.js +234 -0
  57. package/dist/components/buckets/BucketCreate.d.ts +50 -0
  58. package/dist/components/buckets/BucketCreate.js +279 -0
  59. package/dist/components/buckets/BucketDetails.d.ts +42 -0
  60. package/dist/components/buckets/BucketDetails.js +256 -40
  61. package/dist/components/buckets/BucketLifecycleFormPage.d.ts +15 -0
  62. package/dist/components/buckets/BucketLifecycleFormPage.js +1086 -0
  63. package/dist/components/buckets/BucketLifecycleList.d.ts +10 -0
  64. package/dist/components/buckets/BucketLifecycleList.js +270 -0
  65. package/dist/components/buckets/BucketList.d.ts +6 -4
  66. package/dist/components/buckets/BucketList.js +161 -94
  67. package/dist/components/buckets/BucketLocation.js +4 -4
  68. package/dist/components/buckets/BucketOverview.d.ts +86 -5
  69. package/dist/components/buckets/BucketOverview.js +481 -192
  70. package/dist/components/buckets/BucketPage.js +44 -22
  71. package/dist/components/buckets/BucketPolicyPage.js +155 -127
  72. package/dist/components/buckets/BucketReplicationFormPage.d.ts +1 -0
  73. package/dist/components/buckets/BucketReplicationFormPage.js +835 -0
  74. package/dist/components/buckets/BucketReplicationList.d.ts +11 -0
  75. package/dist/components/buckets/BucketReplicationList.js +189 -0
  76. package/dist/components/buckets/BucketVersioning.d.ts +4 -0
  77. package/dist/components/buckets/BucketVersioning.js +76 -0
  78. package/dist/components/buckets/DeleteBucketButton.js +8 -8
  79. package/dist/components/buckets/DeleteBucketConfigRuleButton.d.ts +18 -0
  80. package/dist/components/buckets/DeleteBucketConfigRuleButton.js +53 -0
  81. package/dist/components/buckets/EmptyBucketButton.d.ts +5 -0
  82. package/dist/components/buckets/EmptyBucketButton.js +232 -0
  83. package/dist/components/buckets/EmptyBucketSummary.d.ts +9 -0
  84. package/dist/components/buckets/EmptyBucketSummary.js +60 -0
  85. package/dist/components/buckets/EmptyBucketSummaryList.d.ts +13 -0
  86. package/dist/components/buckets/EmptyBucketSummaryList.js +140 -0
  87. package/dist/components/buckets/__tests__/BucketVersioning.test.d.ts +1 -0
  88. package/dist/components/buckets/__tests__/BucketVersioning.test.js +163 -0
  89. package/dist/components/buckets/notifications/BucketNotificationFormPage.d.ts +1 -0
  90. package/dist/components/buckets/notifications/BucketNotificationFormPage.js +316 -0
  91. package/dist/components/buckets/notifications/BucketNotificationList.d.ts +10 -0
  92. package/dist/components/buckets/notifications/BucketNotificationList.js +267 -0
  93. package/dist/components/buckets/notifications/EventsSection.js +145 -29
  94. package/dist/components/buckets/notifications/__tests__/events.test.d.ts +1 -0
  95. package/dist/components/buckets/notifications/__tests__/events.test.js +56 -0
  96. package/dist/components/buckets/notifications/events.d.ts +71 -7
  97. package/dist/components/buckets/notifications/events.js +98 -16
  98. package/dist/components/index.d.ts +27 -13
  99. package/dist/components/index.js +20 -6
  100. package/dist/components/layouts/ArrowNavigation.d.ts +3 -0
  101. package/dist/components/layouts/ArrowNavigation.js +28 -0
  102. package/dist/components/layouts/BrowserPageLayout.d.ts +5 -1
  103. package/dist/components/layouts/BrowserPageLayout.js +10 -5
  104. package/dist/components/objects/CreateFolderButton.d.ts +2 -2
  105. package/dist/components/objects/CreateFolderButton.js +12 -12
  106. package/dist/components/objects/DeleteObjectButton.d.ts +1 -1
  107. package/dist/components/objects/DeleteObjectButton.js +19 -21
  108. package/dist/components/objects/GetPresignedUrlButton.d.ts +7 -0
  109. package/dist/components/objects/GetPresignedUrlButton.js +255 -0
  110. package/dist/components/objects/ObjectDetails/ObjectMetadata.d.ts +2 -2
  111. package/dist/components/objects/ObjectDetails/ObjectMetadata.js +263 -230
  112. package/dist/components/objects/ObjectDetails/ObjectSummary.d.ts +2 -2
  113. package/dist/components/objects/ObjectDetails/ObjectSummary.js +540 -138
  114. package/dist/components/objects/ObjectDetails/ObjectTags.d.ts +2 -2
  115. package/dist/components/objects/ObjectDetails/ObjectTags.js +95 -123
  116. package/dist/components/objects/ObjectDetails/__tests__/ObjectDetails.test.d.ts +1 -0
  117. package/dist/components/objects/ObjectDetails/__tests__/ObjectDetails.test.js +516 -0
  118. package/dist/components/objects/ObjectDetails/__tests__/ObjectSummary.test.d.ts +1 -0
  119. package/dist/components/objects/ObjectDetails/__tests__/ObjectSummary.test.js +1064 -0
  120. package/dist/components/objects/ObjectDetails/index.d.ts +18 -2
  121. package/dist/components/objects/ObjectDetails/index.js +152 -40
  122. package/dist/components/objects/ObjectList.d.ts +12 -10
  123. package/dist/components/objects/ObjectList.js +590 -263
  124. package/dist/components/objects/ObjectLock/EditRetentionButton.d.ts +4 -0
  125. package/dist/components/objects/ObjectLock/EditRetentionButton.js +32 -0
  126. package/dist/components/objects/ObjectLock/ObjectLockRetentionSettings.d.ts +3 -0
  127. package/dist/components/objects/ObjectLock/ObjectLockRetentionSettings.js +211 -0
  128. package/dist/components/objects/ObjectLock/ObjectLockSettings.d.ts +9 -0
  129. package/dist/components/objects/ObjectLock/ObjectLockSettings.js +159 -0
  130. package/dist/components/objects/ObjectLock/ObjectLockSettingsUtils.d.ts +8 -0
  131. package/dist/components/objects/ObjectLock/ObjectLockSettingsUtils.js +39 -0
  132. package/dist/components/objects/ObjectLock/__tests__/EditRetentionButton.test.d.ts +1 -0
  133. package/dist/components/objects/ObjectLock/__tests__/EditRetentionButton.test.js +204 -0
  134. package/dist/components/objects/ObjectLock/__tests__/ObjectLockSettings.test.d.ts +1 -0
  135. package/dist/components/objects/ObjectLock/__tests__/ObjectLockSettings.test.js +374 -0
  136. package/dist/components/objects/ObjectPage.js +12 -8
  137. package/dist/components/objects/UploadButton.d.ts +3 -3
  138. package/dist/components/objects/UploadButton.js +10 -10
  139. package/dist/components/objects/__tests__/GetPresignedUrlButton.test.d.ts +1 -0
  140. package/dist/components/objects/__tests__/GetPresignedUrlButton.test.js +531 -0
  141. package/dist/components/providers/DataBrowserProvider.d.ts +23 -12
  142. package/dist/components/providers/DataBrowserProvider.js +60 -38
  143. package/dist/components/providers/QueryProvider.d.ts +9 -0
  144. package/dist/components/providers/QueryProvider.js +21 -0
  145. package/dist/components/search/MetadataSearch.js +29 -28
  146. package/dist/components/search/SearchHints.js +1 -1
  147. package/dist/components/ui/ArrayFieldActions.d.ts +36 -0
  148. package/dist/components/ui/ArrayFieldActions.js +43 -0
  149. package/dist/components/ui/ConfirmDeleteRuleModal.d.ts +16 -0
  150. package/dist/components/ui/ConfirmDeleteRuleModal.js +48 -0
  151. package/dist/components/ui/DeleteObjectModalContent.d.ts +1 -1
  152. package/dist/components/ui/DeleteObjectModalContent.js +12 -12
  153. package/dist/components/ui/FilterFormSection.d.ts +44 -0
  154. package/dist/components/ui/FilterFormSection.js +159 -0
  155. package/dist/components/ui/Search.elements.d.ts +2 -2
  156. package/dist/components/ui/Search.elements.js +7 -7
  157. package/dist/components/ui/Table.elements.d.ts +2 -1
  158. package/dist/components/ui/Table.elements.js +18 -12
  159. package/dist/config/__tests__/factory.test.d.ts +1 -0
  160. package/dist/config/__tests__/factory.test.js +311 -0
  161. package/dist/config/factory.d.ts +14 -49
  162. package/dist/config/factory.js +23 -68
  163. package/dist/config/types.d.ts +212 -34
  164. package/dist/contexts/DataBrowserUICustomizationContext.d.ts +27 -0
  165. package/dist/contexts/DataBrowserUICustomizationContext.js +13 -0
  166. package/dist/hooks/__tests__/useAccessibleBuckets.test.d.ts +1 -0
  167. package/dist/hooks/__tests__/useAccessibleBuckets.test.js +145 -0
  168. package/dist/hooks/__tests__/useISVBucketDetection.test.d.ts +1 -0
  169. package/dist/hooks/__tests__/useISVBucketDetection.test.js +188 -0
  170. package/dist/hooks/__tests__/useIsBucketEmpty.test.js +27 -27
  171. package/dist/hooks/__tests__/useLoginMutation.test.d.ts +1 -0
  172. package/dist/hooks/__tests__/useLoginMutation.test.js +194 -0
  173. package/dist/hooks/bucketConfiguration.d.ts +8 -1
  174. package/dist/hooks/bucketConfiguration.js +52 -51
  175. package/dist/hooks/bucketOperations.d.ts +10 -1
  176. package/dist/hooks/bucketOperations.js +10 -9
  177. package/dist/hooks/factories/__tests__/useCreateS3FunctionMutationHook.test.js +80 -80
  178. package/dist/hooks/factories/__tests__/useCreateS3InfiniteQueryHook.test.js +80 -80
  179. package/dist/hooks/factories/__tests__/useCreateS3LoginHook.test.js +44 -44
  180. package/dist/hooks/factories/__tests__/useCreateS3MutationHook.test.js +63 -63
  181. package/dist/hooks/factories/__tests__/useCreateS3QueryHook.test.js +95 -52
  182. package/dist/hooks/factories/index.d.ts +4 -4
  183. package/dist/hooks/factories/index.js +2 -2
  184. package/dist/hooks/factories/useCreateS3InfiniteQueryHook.d.ts +2 -2
  185. package/dist/hooks/factories/useCreateS3InfiniteQueryHook.js +16 -13
  186. package/dist/hooks/factories/useCreateS3LoginHook.d.ts +2 -2
  187. package/dist/hooks/factories/useCreateS3LoginHook.js +1 -1
  188. package/dist/hooks/factories/useCreateS3MutationHook.d.ts +3 -3
  189. package/dist/hooks/factories/useCreateS3MutationHook.js +7 -2
  190. package/dist/hooks/factories/useCreateS3QueryHook.d.ts +2 -2
  191. package/dist/hooks/factories/useCreateS3QueryHook.js +29 -3
  192. package/dist/hooks/index.d.ts +19 -8
  193. package/dist/hooks/index.js +16 -5
  194. package/dist/hooks/loginOperations.d.ts +1 -1
  195. package/dist/hooks/loginOperations.js +1 -1
  196. package/dist/hooks/objectOperations.d.ts +2 -2
  197. package/dist/hooks/objectOperations.js +50 -49
  198. package/dist/hooks/presignedOperations.d.ts +4 -4
  199. package/dist/hooks/presignedOperations.js +5 -5
  200. package/dist/hooks/useAccessibleBuckets.d.ts +11 -0
  201. package/dist/hooks/useAccessibleBuckets.js +115 -0
  202. package/dist/hooks/useBatchObjectLegalHold.d.ts +11 -0
  203. package/dist/hooks/useBatchObjectLegalHold.js +48 -0
  204. package/dist/hooks/useBucketConfigEditor.d.ts +31 -0
  205. package/dist/hooks/useBucketConfigEditor.js +82 -0
  206. package/dist/hooks/useDataBrowserNavigate.d.ts +28 -0
  207. package/dist/hooks/useDataBrowserNavigate.js +24 -0
  208. package/dist/hooks/useDeleteBucketConfigRule.d.ts +26 -0
  209. package/dist/hooks/useDeleteBucketConfigRule.js +46 -0
  210. package/dist/hooks/useEmptyBucket.d.ts +27 -0
  211. package/dist/hooks/useEmptyBucket.js +116 -0
  212. package/dist/hooks/useFeatures.d.ts +7 -0
  213. package/dist/hooks/useFeatures.js +8 -0
  214. package/dist/hooks/useISVBucketDetection.d.ts +15 -0
  215. package/dist/hooks/useISVBucketDetection.js +27 -0
  216. package/dist/hooks/useIsBucketEmpty.js +4 -4
  217. package/dist/hooks/useLimitedAccessFlow.d.ts +48 -0
  218. package/dist/hooks/useLimitedAccessFlow.js +23 -0
  219. package/dist/hooks/useS3Client.d.ts +6 -0
  220. package/dist/hooks/useS3Client.js +3 -2
  221. package/dist/hooks/useS3ConfigSwitch.d.ts +11 -0
  222. package/dist/hooks/useS3ConfigSwitch.js +37 -0
  223. package/dist/hooks/useSupportedNotificationEvents.d.ts +6 -0
  224. package/dist/hooks/useSupportedNotificationEvents.js +8 -0
  225. package/dist/hooks/useTableRowSelection.d.ts +9 -0
  226. package/dist/hooks/useTableRowSelection.js +45 -0
  227. package/dist/index.d.ts +6 -6
  228. package/dist/index.js +2 -2
  229. package/dist/schemas/bucketPolicySchema.json +3 -13
  230. package/dist/test/msw/handlers/deleteBucket.d.ts +1 -1
  231. package/dist/test/msw/handlers/deleteBucket.js +20 -10
  232. package/dist/test/msw/handlers/getBucketAcl.d.ts +1 -1
  233. package/dist/test/msw/handlers/getBucketAcl.js +29 -17
  234. package/dist/test/msw/handlers/getBucketLocation.d.ts +1 -1
  235. package/dist/test/msw/handlers/getBucketLocation.js +29 -15
  236. package/dist/test/msw/handlers/getBucketPolicy.d.ts +1 -1
  237. package/dist/test/msw/handlers/getBucketPolicy.js +52 -32
  238. package/dist/test/msw/handlers/headObject.d.ts +1 -1
  239. package/dist/test/msw/handlers/headObject.js +31 -13
  240. package/dist/test/msw/handlers/listBuckets.d.ts +1 -1
  241. package/dist/test/msw/handlers/listBuckets.js +5 -3
  242. package/dist/test/msw/handlers/listObjectVersions.d.ts +1 -1
  243. package/dist/test/msw/handlers/listObjectVersions.js +38 -26
  244. package/dist/test/msw/handlers/listObjects.d.ts +1 -1
  245. package/dist/test/msw/handlers/listObjects.js +35 -23
  246. package/dist/test/msw/handlers/objectLegalHold.d.ts +1 -1
  247. package/dist/test/msw/handlers/objectLegalHold.js +32 -17
  248. package/dist/test/msw/handlers/objectRetention.d.ts +1 -1
  249. package/dist/test/msw/handlers/objectRetention.js +31 -17
  250. package/dist/test/msw/handlers/putBucketAcl.d.ts +1 -1
  251. package/dist/test/msw/handlers/putBucketAcl.js +29 -14
  252. package/dist/test/msw/handlers/putObject.d.ts +1 -1
  253. package/dist/test/msw/handlers/putObject.js +27 -12
  254. package/dist/test/msw/handlers.d.ts +3 -3
  255. package/dist/test/msw/handlers.js +77 -54
  256. package/dist/test/msw/index.d.ts +2 -2
  257. package/dist/test/msw/index.js +1 -1
  258. package/dist/test/msw/server.d.ts +1 -1
  259. package/dist/test/msw/server.js +1 -1
  260. package/dist/test/msw/utils.js +2 -2
  261. package/dist/test/setup.d.ts +1 -1
  262. package/dist/test/setup.js +13 -30
  263. package/dist/test/testUtils.d.ts +170 -36
  264. package/dist/test/testUtils.js +229 -116
  265. package/dist/test/utils/errorHandling.test.js +146 -108
  266. package/dist/types/index.d.ts +49 -36
  267. package/dist/types/monaco.d.ts +13 -0
  268. package/dist/types/monaco.js +0 -0
  269. package/dist/utils/__tests__/proxyMiddleware.test.d.ts +1 -0
  270. package/dist/utils/__tests__/proxyMiddleware.test.js +579 -0
  271. package/dist/utils/__tests__/s3Client.test.d.ts +1 -0
  272. package/dist/utils/__tests__/s3Client.test.js +340 -0
  273. package/dist/utils/__tests__/s3ConfigIdentifier.test.d.ts +1 -0
  274. package/dist/utils/__tests__/s3ConfigIdentifier.test.js +437 -0
  275. package/dist/utils/constants.d.ts +22 -0
  276. package/dist/utils/constants.js +19 -0
  277. package/dist/utils/deletion/index.d.ts +2 -2
  278. package/dist/utils/deletion/index.js +1 -1
  279. package/dist/utils/deletion/messages.d.ts +1 -1
  280. package/dist/utils/deletion/messages.js +4 -4
  281. package/dist/utils/errorHandling.d.ts +12 -3
  282. package/dist/utils/errorHandling.js +12 -7
  283. package/dist/utils/hooks.js +8 -8
  284. package/dist/utils/index.d.ts +5 -2
  285. package/dist/utils/index.js +5 -1
  286. package/dist/utils/proxyMiddleware.d.ts +32 -13
  287. package/dist/utils/proxyMiddleware.js +90 -36
  288. package/dist/utils/s3Client.d.ts +14 -4
  289. package/dist/utils/s3Client.js +5 -26
  290. package/dist/utils/s3ConfigIdentifier.d.ts +79 -0
  291. package/dist/utils/s3ConfigIdentifier.js +57 -0
  292. package/dist/utils/s3RuleUtils.d.ts +53 -0
  293. package/dist/utils/s3RuleUtils.js +101 -0
  294. package/package.json +10 -8
  295. package/dist/components/__tests__/BucketNotificationCreatePage.test.js +0 -316
  296. package/dist/components/buckets/BucketPolicyButton.d.ts +0 -7
  297. package/dist/components/buckets/notifications/BucketNotificationCreatePage.d.ts +0 -1
  298. package/dist/components/buckets/notifications/BucketNotificationCreatePage.js +0 -234
  299. package/dist/hooks/useLoginMutation.d.ts +0 -21
  300. package/dist/hooks/useLoginMutation.js +0 -9
  301. package/dist/utils/useFeatures.d.ts +0 -1
  302. package/dist/utils/useFeatures.js +0 -7
  303. /package/dist/components/__tests__/{BucketNotificationCreatePage.test.d.ts → BucketAccessor.test.d.ts} +0 -0
@@ -0,0 +1,379 @@
1
+ import { jsx } from "react/jsx-runtime";
2
+ import { fireEvent, render, screen, waitFor } from "@testing-library/react";
3
+ import { MemoryRouter } from "react-router";
4
+ import { createTestWrapper, mockOffsetSize } from "../../test/testUtils.js";
5
+ import { BucketNotificationList } from "../buckets/notifications/BucketNotificationList.js";
6
+ const mockMutate = jest.fn();
7
+ const mockShowToast = jest.fn();
8
+ jest.mock('../../hooks/bucketConfiguration', ()=>({
9
+ useSetBucketNotification: jest.fn(()=>({
10
+ mutate: mockMutate,
11
+ isPending: false
12
+ }))
13
+ }));
14
+ jest.mock('@scality/core-ui', ()=>{
15
+ const actual = jest.requireActual('@scality/core-ui');
16
+ return {
17
+ ...actual,
18
+ useToast: ()=>({
19
+ showToast: mockShowToast
20
+ })
21
+ };
22
+ });
23
+ const renderBucketNotificationList = (props = {})=>{
24
+ const Wrapper = createTestWrapper();
25
+ return render(/*#__PURE__*/ jsx(MemoryRouter, {
26
+ children: /*#__PURE__*/ jsx(Wrapper, {
27
+ children: /*#__PURE__*/ jsx(BucketNotificationList, {
28
+ bucketName: "test-bucket",
29
+ notificationRules: [],
30
+ ...props
31
+ })
32
+ })
33
+ }));
34
+ };
35
+ const mockNotificationRules = [
36
+ {
37
+ Id: 'rule-1',
38
+ QueueArn: 'arn:aws:sqs:us-east-1:123456789012:my-queue',
39
+ Events: [
40
+ 's3:ObjectCreated:*'
41
+ ]
42
+ },
43
+ {
44
+ Id: 'rule-2',
45
+ QueueArn: 'arn:aws:sqs:us-west-2:987654321098:backup-queue',
46
+ Events: [
47
+ 's3:ObjectRemoved:*',
48
+ 's3:ObjectRestore:*'
49
+ ]
50
+ },
51
+ {
52
+ Id: 'rule-3',
53
+ QueueArn: 'arn:aws:sqs:eu-west-1:111222333444:logs-queue',
54
+ Events: [
55
+ 's3:ObjectCreated:Put',
56
+ 's3:ObjectCreated:Post',
57
+ 's3:ObjectCreated:Copy'
58
+ ]
59
+ }
60
+ ];
61
+ const mockRuleWithSingleEvent = {
62
+ Id: 'single-event-rule',
63
+ QueueArn: 'arn:aws:sqs:us-east-1:123456789012:simple-queue',
64
+ Events: [
65
+ 's3:ObjectCreated:*'
66
+ ]
67
+ };
68
+ describe('BucketNotificationList', ()=>{
69
+ beforeEach(()=>{
70
+ jest.clearAllMocks();
71
+ mockOffsetSize(800, 600);
72
+ mockShowToast.mockClear();
73
+ });
74
+ it('shows a table with proper headers', ()=>{
75
+ renderBucketNotificationList({
76
+ notificationRules: mockNotificationRules
77
+ });
78
+ expect(screen.getByRole('grid')).toBeInTheDocument();
79
+ expect(screen.getByText('Rule Name')).toBeInTheDocument();
80
+ expect(screen.getByText('Events')).toBeInTheDocument();
81
+ });
82
+ it('does not show Destination column', ()=>{
83
+ renderBucketNotificationList({
84
+ notificationRules: mockNotificationRules
85
+ });
86
+ expect(screen.queryByText('Destination')).not.toBeInTheDocument();
87
+ });
88
+ it('displays notification rules with their IDs', ()=>{
89
+ renderBucketNotificationList({
90
+ notificationRules: mockNotificationRules
91
+ });
92
+ expect(screen.getByText('rule-1')).toBeInTheDocument();
93
+ expect(screen.getByText('rule-2')).toBeInTheDocument();
94
+ expect(screen.getByText('rule-3')).toBeInTheDocument();
95
+ });
96
+ it('displays single event correctly', ()=>{
97
+ renderBucketNotificationList({
98
+ notificationRules: [
99
+ mockRuleWithSingleEvent
100
+ ]
101
+ });
102
+ expect(screen.getByText('s3:ObjectCreated:*')).toBeInTheDocument();
103
+ });
104
+ it('displays multiple events on separate lines', ()=>{
105
+ renderBucketNotificationList({
106
+ notificationRules: [
107
+ mockNotificationRules[1]
108
+ ]
109
+ });
110
+ expect(screen.getByText('s3:ObjectRemoved:*')).toBeInTheDocument();
111
+ expect(screen.getByText('s3:ObjectRestore:*')).toBeInTheDocument();
112
+ });
113
+ it('displays up to 3 events and shows +N more for additional events', ()=>{
114
+ const ruleWithManyEvents = {
115
+ Id: 'many-events-rule',
116
+ QueueArn: 'arn:aws:sqs:us-east-1:123456789012:queue',
117
+ Events: [
118
+ 's3:ObjectCreated:Put',
119
+ 's3:ObjectCreated:Post',
120
+ 's3:ObjectCreated:Copy',
121
+ 's3:ObjectRemoved:Delete',
122
+ 's3:ObjectRemoved:DeleteMarkerCreated'
123
+ ]
124
+ };
125
+ renderBucketNotificationList({
126
+ notificationRules: [
127
+ ruleWithManyEvents
128
+ ]
129
+ });
130
+ expect(screen.getByText('s3:ObjectCreated:Put')).toBeInTheDocument();
131
+ expect(screen.getByText('s3:ObjectCreated:Post')).toBeInTheDocument();
132
+ expect(screen.getByText('s3:ObjectCreated:Copy')).toBeInTheDocument();
133
+ expect(screen.getByText('+2 more')).toBeInTheDocument();
134
+ expect(screen.queryByText('s3:ObjectRemoved:Delete')).not.toBeInTheDocument();
135
+ });
136
+ it('displays all events when 3 or fewer', ()=>{
137
+ renderBucketNotificationList({
138
+ notificationRules: [
139
+ mockNotificationRules[2]
140
+ ]
141
+ });
142
+ expect(screen.getByText('s3:ObjectCreated:Put')).toBeInTheDocument();
143
+ expect(screen.getByText('s3:ObjectCreated:Post')).toBeInTheDocument();
144
+ expect(screen.getByText('s3:ObjectCreated:Copy')).toBeInTheDocument();
145
+ expect(screen.queryByText(/more/)).not.toBeInTheDocument();
146
+ });
147
+ it('renders Add Notification button', ()=>{
148
+ renderBucketNotificationList({
149
+ notificationRules: mockNotificationRules
150
+ });
151
+ const addButton = screen.getByRole('button', {
152
+ name: /add notification/i
153
+ });
154
+ expect(addButton).toBeInTheDocument();
155
+ expect(addButton).toBeEnabled();
156
+ });
157
+ it('calls create rule callback when Add Notification button is clicked', ()=>{
158
+ const onCreateRule = jest.fn();
159
+ renderBucketNotificationList({
160
+ notificationRules: mockNotificationRules,
161
+ onCreateRule
162
+ });
163
+ const addButton = screen.getByRole('button', {
164
+ name: /add notification/i
165
+ });
166
+ fireEvent.click(addButton);
167
+ expect(onCreateRule).toHaveBeenCalled();
168
+ });
169
+ it('handles edit button click', ()=>{
170
+ const onEditRule = jest.fn();
171
+ renderBucketNotificationList({
172
+ notificationRules: mockNotificationRules,
173
+ onEditRule
174
+ });
175
+ const editButtons = screen.getAllByRole('button', {
176
+ name: /edit rule/i
177
+ });
178
+ expect(editButtons.length).toBeGreaterThanOrEqual(3);
179
+ fireEvent.click(editButtons[0]);
180
+ expect(onEditRule).toHaveBeenCalledWith(expect.any(String));
181
+ });
182
+ it('renders delete buttons for each rule', ()=>{
183
+ renderBucketNotificationList({
184
+ notificationRules: mockNotificationRules
185
+ });
186
+ const deleteButtons = screen.getAllByRole('button', {
187
+ name: /delete rule/i
188
+ });
189
+ expect(deleteButtons.length).toBeGreaterThanOrEqual(3);
190
+ });
191
+ it('opens delete confirmation modal when delete button is clicked', ()=>{
192
+ renderBucketNotificationList({
193
+ notificationRules: mockNotificationRules
194
+ });
195
+ const deleteButtons = screen.getAllByRole('button', {
196
+ name: /delete rule/i
197
+ });
198
+ fireEvent.click(deleteButtons[0]);
199
+ expect(screen.getByText(/are you sure you want to delete/i)).toBeInTheDocument();
200
+ expect(screen.getByText('Delete Notification Rule')).toBeInTheDocument();
201
+ });
202
+ it('closes delete modal when cancel is clicked', async ()=>{
203
+ renderBucketNotificationList({
204
+ notificationRules: mockNotificationRules
205
+ });
206
+ const deleteButtons = screen.getAllByRole('button', {
207
+ name: /delete rule/i
208
+ });
209
+ fireEvent.click(deleteButtons[0]);
210
+ const cancelButton = screen.getByRole('button', {
211
+ name: /cancel/i
212
+ });
213
+ fireEvent.click(cancelButton);
214
+ await waitFor(()=>{
215
+ expect(screen.queryByText(/are you sure you want to delete/i)).not.toBeInTheDocument();
216
+ });
217
+ });
218
+ it('calls mutation when delete is confirmed', ()=>{
219
+ renderBucketNotificationList({
220
+ notificationRules: mockNotificationRules
221
+ });
222
+ const deleteButtons = screen.getAllByRole('button', {
223
+ name: /delete rule/i
224
+ });
225
+ fireEvent.click(deleteButtons[0]);
226
+ const confirmDeleteButton = screen.getByRole('button', {
227
+ name: 'Delete'
228
+ });
229
+ fireEvent.click(confirmDeleteButton);
230
+ expect(mockMutate).toHaveBeenCalledWith(expect.objectContaining({
231
+ Bucket: 'test-bucket',
232
+ NotificationConfiguration: expect.objectContaining({
233
+ QueueConfigurations: expect.any(Array)
234
+ })
235
+ }), expect.any(Object));
236
+ });
237
+ it('shows success toast when deletion succeeds', ()=>{
238
+ mockMutate.mockImplementation((_, options)=>{
239
+ options?.onSuccess?.();
240
+ });
241
+ renderBucketNotificationList({
242
+ notificationRules: mockNotificationRules
243
+ });
244
+ const deleteButtons = screen.getAllByRole('button', {
245
+ name: /delete rule/i
246
+ });
247
+ fireEvent.click(deleteButtons[0]);
248
+ const confirmDeleteButton = screen.getByRole('button', {
249
+ name: 'Delete'
250
+ });
251
+ fireEvent.click(confirmDeleteButton);
252
+ expect(mockShowToast).toHaveBeenCalledWith({
253
+ open: true,
254
+ message: 'Notification rule deleted successfully',
255
+ status: 'success'
256
+ });
257
+ });
258
+ it('shows error toast when deletion fails', ()=>{
259
+ const error = new Error('Network error');
260
+ mockMutate.mockImplementation((_, options)=>{
261
+ options?.onError?.(error);
262
+ });
263
+ renderBucketNotificationList({
264
+ notificationRules: mockNotificationRules
265
+ });
266
+ const deleteButtons = screen.getAllByRole('button', {
267
+ name: /delete rule/i
268
+ });
269
+ fireEvent.click(deleteButtons[0]);
270
+ const confirmDeleteButton = screen.getByRole('button', {
271
+ name: 'Delete'
272
+ });
273
+ fireEvent.click(confirmDeleteButton);
274
+ expect(mockShowToast).toHaveBeenCalledWith({
275
+ open: true,
276
+ message: 'Network error',
277
+ status: 'error'
278
+ });
279
+ });
280
+ it('handles empty notification rules list', ()=>{
281
+ renderBucketNotificationList({
282
+ notificationRules: []
283
+ });
284
+ expect(screen.getByRole('grid')).toBeInTheDocument();
285
+ expect(screen.getByText(/no notification rules found/i)).toBeInTheDocument();
286
+ });
287
+ it('handles notification rules without IDs', ()=>{
288
+ const ruleWithoutId = {
289
+ QueueArn: 'arn:aws:sqs:us-east-1:123456789012:test-queue',
290
+ Events: [
291
+ 's3:ObjectCreated:*'
292
+ ]
293
+ };
294
+ renderBucketNotificationList({
295
+ notificationRules: [
296
+ ruleWithoutId
297
+ ]
298
+ });
299
+ expect(screen.getByText('-')).toBeInTheDocument();
300
+ });
301
+ it('disables edit and delete buttons for rules without valid IDs', ()=>{
302
+ const ruleWithoutId = {
303
+ QueueArn: 'arn:aws:sqs:us-east-1:123456789012:test-queue',
304
+ Events: [
305
+ 's3:ObjectCreated:*'
306
+ ]
307
+ };
308
+ renderBucketNotificationList({
309
+ notificationRules: [
310
+ ruleWithoutId
311
+ ]
312
+ });
313
+ const editButton = screen.getByRole('button', {
314
+ name: /edit rule/i
315
+ });
316
+ const deleteButton = screen.getByRole('button', {
317
+ name: /delete rule/i
318
+ });
319
+ expect(editButton).toBeDisabled();
320
+ expect(deleteButton).toBeDisabled();
321
+ });
322
+ it('handles notification rules without events', ()=>{
323
+ const ruleWithoutEvents = {
324
+ Id: 'empty-events-rule',
325
+ QueueArn: 'arn:aws:sqs:us-east-1:123456789012:test-queue',
326
+ Events: []
327
+ };
328
+ renderBucketNotificationList({
329
+ notificationRules: [
330
+ ruleWithoutEvents
331
+ ]
332
+ });
333
+ const rows = screen.getAllByRole('row');
334
+ expect(rows.length).toBeGreaterThan(1);
335
+ });
336
+ it('shows loading state when notificationStatus is loading', ()=>{
337
+ renderBucketNotificationList({
338
+ notificationRules: [],
339
+ notificationStatus: 'loading'
340
+ });
341
+ expect(screen.getByRole('grid')).toBeInTheDocument();
342
+ expect(screen.queryByText('rule-1')).not.toBeInTheDocument();
343
+ });
344
+ it('shows error state when notificationStatus is error', ()=>{
345
+ renderBucketNotificationList({
346
+ notificationRules: [],
347
+ notificationStatus: 'error'
348
+ });
349
+ expect(screen.getByRole('grid')).toBeInTheDocument();
350
+ expect(screen.queryByText('rule-1')).not.toBeInTheDocument();
351
+ });
352
+ it('shows data when notificationStatus is success', ()=>{
353
+ renderBucketNotificationList({
354
+ notificationRules: mockNotificationRules,
355
+ notificationStatus: 'success'
356
+ });
357
+ expect(screen.getByRole('grid')).toBeInTheDocument();
358
+ expect(screen.getByText('rule-1')).toBeInTheDocument();
359
+ expect(screen.getByText('rule-2')).toBeInTheDocument();
360
+ });
361
+ it('works when no callbacks are provided', ()=>{
362
+ expect(()=>{
363
+ renderBucketNotificationList({
364
+ notificationRules: mockNotificationRules
365
+ });
366
+ }).not.toThrow();
367
+ });
368
+ it('renders rows that can be selected', ()=>{
369
+ renderBucketNotificationList({
370
+ notificationRules: mockNotificationRules
371
+ });
372
+ const rows = screen.getAllByRole('row');
373
+ expect(rows.length).toBeGreaterThan(3);
374
+ const dataRows = rows.slice(1);
375
+ dataRows.forEach((row)=>{
376
+ expect(row).toHaveAttribute('aria-selected');
377
+ });
378
+ });
379
+ });