@scality/data-browser-library 1.0.0-preview.13 → 1.0.0-preview.15
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.
- package/dist/components/DataBrowserUI.d.ts +15 -8
- package/dist/components/DataBrowserUI.js +79 -55
- package/dist/components/Editor.d.ts +1 -1
- package/dist/components/Editor.js +3 -3
- package/dist/components/__tests__/BucketCreate.test.js +102 -102
- package/dist/components/__tests__/BucketDetails.test.js +121 -122
- package/dist/components/__tests__/BucketLifecycleFormPage.test.js +177 -177
- package/dist/components/__tests__/BucketLifecycleList.test.js +85 -85
- package/dist/components/__tests__/BucketList.test.js +175 -176
- package/dist/components/__tests__/BucketNotificationCreatePage.test.js +84 -84
- package/dist/components/__tests__/BucketOverview.test.js +256 -200
- package/dist/components/__tests__/BucketPolicyPage.test.js +62 -62
- package/dist/components/__tests__/BucketReplicationFormPage.test.js +542 -542
- package/dist/components/__tests__/BucketReplicationList.test.js +106 -106
- package/dist/components/__tests__/CreateFolderButton.test.js +56 -56
- package/dist/components/__tests__/DeleteBucketButton.test.js +62 -62
- package/dist/components/__tests__/DeleteBucketConfigRuleButton.test.js +47 -47
- package/dist/components/__tests__/DeleteObjectButton.test.js +63 -63
- package/dist/components/__tests__/EmptyBucketButton.test.js +56 -56
- package/dist/components/__tests__/MetadataSearch.test.js +65 -65
- package/dist/components/__tests__/ObjectList.test.js +251 -250
- package/dist/components/__tests__/UploadButton.test.js +45 -45
- package/dist/components/buckets/BucketCreate.d.ts +2 -2
- package/dist/components/buckets/BucketCreate.js +41 -41
- package/dist/components/buckets/BucketDetails.d.ts +2 -2
- package/dist/components/buckets/BucketDetails.js +48 -36
- package/dist/components/buckets/BucketLifecycleFormPage.js +161 -160
- package/dist/components/buckets/BucketLifecycleList.d.ts +2 -2
- package/dist/components/buckets/BucketLifecycleList.js +46 -46
- package/dist/components/buckets/BucketList.d.ts +2 -2
- package/dist/components/buckets/BucketList.js +28 -27
- package/dist/components/buckets/BucketLocation.js +3 -3
- package/dist/components/buckets/BucketOverview.d.ts +1 -1
- package/dist/components/buckets/BucketOverview.js +62 -62
- package/dist/components/buckets/BucketPage.js +19 -11
- package/dist/components/buckets/BucketPolicyButton.js +2 -2
- package/dist/components/buckets/BucketPolicyPage.js +27 -25
- package/dist/components/buckets/BucketReplicationFormPage.js +133 -132
- package/dist/components/buckets/BucketReplicationList.d.ts +2 -2
- package/dist/components/buckets/BucketReplicationList.js +41 -41
- package/dist/components/buckets/BucketVersioning.js +11 -11
- package/dist/components/buckets/DeleteBucketButton.js +5 -5
- package/dist/components/buckets/DeleteBucketConfigRuleButton.d.ts +2 -2
- package/dist/components/buckets/DeleteBucketConfigRuleButton.js +1 -1
- package/dist/components/buckets/EmptyBucketButton.js +19 -19
- package/dist/components/buckets/EmptyBucketSummary.d.ts +1 -1
- package/dist/components/buckets/EmptyBucketSummary.js +1 -1
- package/dist/components/buckets/EmptyBucketSummaryList.js +22 -22
- package/dist/components/buckets/__tests__/BucketVersioning.test.js +45 -45
- package/dist/components/buckets/notifications/BucketNotificationCreatePage.js +34 -33
- package/dist/components/buckets/notifications/EventsSection.js +144 -28
- package/dist/components/buckets/notifications/__tests__/events.test.d.ts +1 -0
- package/dist/components/buckets/notifications/__tests__/events.test.js +56 -0
- package/dist/components/buckets/notifications/events.d.ts +71 -7
- package/dist/components/buckets/notifications/events.js +98 -16
- package/dist/components/index.d.ts +23 -22
- package/dist/components/index.js +3 -2
- package/dist/components/layouts/ArrowNavigation.d.ts +1 -2
- package/dist/components/layouts/ArrowNavigation.js +3 -3
- package/dist/components/layouts/BrowserPageLayout.d.ts +2 -3
- package/dist/components/layouts/BrowserPageLayout.js +1 -1
- package/dist/components/objects/CreateFolderButton.d.ts +2 -2
- package/dist/components/objects/CreateFolderButton.js +9 -9
- package/dist/components/objects/DeleteObjectButton.d.ts +1 -1
- package/dist/components/objects/DeleteObjectButton.js +20 -20
- package/dist/components/objects/ObjectDetails/ObjectMetadata.d.ts +1 -1
- package/dist/components/objects/ObjectDetails/ObjectMetadata.js +56 -56
- package/dist/components/objects/ObjectDetails/ObjectSummary.d.ts +1 -1
- package/dist/components/objects/ObjectDetails/ObjectSummary.js +39 -39
- package/dist/components/objects/ObjectDetails/ObjectTags.d.ts +1 -1
- package/dist/components/objects/ObjectDetails/ObjectTags.js +25 -25
- package/dist/components/objects/ObjectDetails/__tests__/ObjectDetails.test.js +119 -119
- package/dist/components/objects/ObjectDetails/__tests__/ObjectSummary.test.js +211 -211
- package/dist/components/objects/ObjectDetails/index.d.ts +1 -1
- package/dist/components/objects/ObjectDetails/index.js +30 -30
- package/dist/components/objects/ObjectList.d.ts +5 -5
- package/dist/components/objects/ObjectList.js +112 -111
- package/dist/components/objects/ObjectLock/EditRetentionButton.js +3 -3
- package/dist/components/objects/ObjectLock/ObjectLockRetentionSettings.js +14 -14
- package/dist/components/objects/ObjectLock/ObjectLockSettings.d.ts +1 -1
- package/dist/components/objects/ObjectLock/ObjectLockSettings.js +29 -28
- package/dist/components/objects/ObjectLock/ObjectLockSettingsUtils.d.ts +1 -1
- package/dist/components/objects/ObjectLock/ObjectLockSettingsUtils.js +6 -6
- package/dist/components/objects/ObjectLock/__tests__/EditRetentionButton.test.js +50 -50
- package/dist/components/objects/ObjectLock/__tests__/ObjectLockSettings.test.js +77 -77
- package/dist/components/objects/ObjectPage.js +5 -4
- package/dist/components/objects/UploadButton.d.ts +3 -3
- package/dist/components/objects/UploadButton.js +5 -5
- package/dist/components/providers/DataBrowserProvider.d.ts +15 -4
- package/dist/components/providers/DataBrowserProvider.js +33 -11
- package/dist/components/search/MetadataSearch.js +26 -25
- package/dist/components/search/SearchHints.js +1 -1
- package/dist/components/ui/ArrayFieldActions.js +4 -4
- package/dist/components/ui/ConfirmDeleteRuleModal.d.ts +1 -1
- package/dist/components/ui/ConfirmDeleteRuleModal.js +1 -1
- package/dist/components/ui/DeleteObjectModalContent.d.ts +1 -1
- package/dist/components/ui/DeleteObjectModalContent.js +12 -12
- package/dist/components/ui/FilterFormSection.d.ts +2 -2
- package/dist/components/ui/FilterFormSection.js +29 -29
- package/dist/components/ui/Search.elements.d.ts +1 -1
- package/dist/components/ui/Search.elements.js +7 -7
- package/dist/components/ui/Table.elements.js +5 -5
- package/dist/config/factory.d.ts +23 -10
- package/dist/config/factory.js +22 -7
- package/dist/config/types.d.ts +20 -3
- package/dist/contexts/DataBrowserUICustomizationContext.d.ts +2 -2
- package/dist/hooks/__tests__/useISVBucketDetection.test.js +41 -41
- package/dist/hooks/__tests__/useIsBucketEmpty.test.js +25 -25
- package/dist/hooks/bucketConfiguration.d.ts +1 -1
- package/dist/hooks/bucketConfiguration.js +48 -48
- package/dist/hooks/bucketOperations.d.ts +1 -1
- package/dist/hooks/bucketOperations.js +6 -6
- package/dist/hooks/factories/__tests__/useCreateS3FunctionMutationHook.test.js +78 -78
- package/dist/hooks/factories/__tests__/useCreateS3InfiniteQueryHook.test.js +78 -78
- package/dist/hooks/factories/__tests__/useCreateS3LoginHook.test.js +42 -42
- package/dist/hooks/factories/__tests__/useCreateS3MutationHook.test.js +61 -61
- package/dist/hooks/factories/__tests__/useCreateS3QueryHook.test.js +63 -63
- package/dist/hooks/factories/index.d.ts +4 -4
- package/dist/hooks/factories/useCreateS3InfiniteQueryHook.d.ts +2 -2
- package/dist/hooks/factories/useCreateS3InfiniteQueryHook.js +15 -12
- package/dist/hooks/factories/useCreateS3LoginHook.d.ts +2 -2
- package/dist/hooks/factories/useCreateS3MutationHook.d.ts +3 -3
- package/dist/hooks/factories/useCreateS3MutationHook.js +6 -1
- package/dist/hooks/factories/useCreateS3QueryHook.d.ts +2 -2
- package/dist/hooks/factories/useCreateS3QueryHook.js +8 -5
- package/dist/hooks/index.d.ts +14 -13
- package/dist/hooks/index.js +2 -1
- package/dist/hooks/loginOperations.d.ts +1 -1
- package/dist/hooks/loginOperations.js +1 -1
- package/dist/hooks/objectOperations.d.ts +2 -2
- package/dist/hooks/objectOperations.js +49 -49
- package/dist/hooks/presignedOperations.d.ts +2 -2
- package/dist/hooks/presignedOperations.js +3 -3
- package/dist/hooks/useBatchObjectLegalHold.js +7 -4
- package/dist/hooks/useDataBrowserNavigate.d.ts +14 -0
- package/dist/hooks/useDataBrowserNavigate.js +24 -0
- package/dist/hooks/useDeleteBucketConfigRule.d.ts +2 -2
- package/dist/hooks/useDeleteBucketConfigRule.js +4 -4
- package/dist/hooks/useEmptyBucket.js +10 -10
- package/dist/hooks/useISVBucketDetection.js +3 -3
- package/dist/hooks/useIsBucketEmpty.js +4 -4
- package/dist/hooks/useLoginMutation.d.ts +1 -1
- package/dist/hooks/useLoginMutation.js +1 -1
- package/dist/hooks/useS3Client.d.ts +5 -0
- package/dist/hooks/useS3Client.js +3 -2
- package/dist/hooks/useS3ConfigSwitch.d.ts +11 -0
- package/dist/hooks/useS3ConfigSwitch.js +37 -0
- package/dist/index.d.ts +6 -6
- package/dist/test/msw/handlers/deleteBucket.d.ts +1 -1
- package/dist/test/msw/handlers/deleteBucket.js +20 -10
- package/dist/test/msw/handlers/getBucketAcl.d.ts +1 -1
- package/dist/test/msw/handlers/getBucketAcl.js +29 -17
- package/dist/test/msw/handlers/getBucketLocation.d.ts +1 -1
- package/dist/test/msw/handlers/getBucketLocation.js +29 -15
- package/dist/test/msw/handlers/getBucketPolicy.d.ts +1 -1
- package/dist/test/msw/handlers/getBucketPolicy.js +52 -32
- package/dist/test/msw/handlers/headObject.d.ts +1 -1
- package/dist/test/msw/handlers/headObject.js +31 -13
- package/dist/test/msw/handlers/listBuckets.d.ts +1 -1
- package/dist/test/msw/handlers/listBuckets.js +5 -3
- package/dist/test/msw/handlers/listObjectVersions.d.ts +1 -1
- package/dist/test/msw/handlers/listObjectVersions.js +38 -26
- package/dist/test/msw/handlers/listObjects.d.ts +1 -1
- package/dist/test/msw/handlers/listObjects.js +35 -23
- package/dist/test/msw/handlers/objectLegalHold.d.ts +1 -1
- package/dist/test/msw/handlers/objectLegalHold.js +31 -16
- package/dist/test/msw/handlers/objectRetention.d.ts +1 -1
- package/dist/test/msw/handlers/objectRetention.js +31 -17
- package/dist/test/msw/handlers/putBucketAcl.d.ts +1 -1
- package/dist/test/msw/handlers/putBucketAcl.js +29 -14
- package/dist/test/msw/handlers/putObject.d.ts +1 -1
- package/dist/test/msw/handlers/putObject.js +27 -12
- package/dist/test/msw/handlers.d.ts +3 -3
- package/dist/test/msw/handlers.js +72 -49
- package/dist/test/msw/index.d.ts +2 -2
- package/dist/test/msw/server.d.ts +1 -1
- package/dist/test/msw/server.js +1 -1
- package/dist/test/msw/utils.js +2 -2
- package/dist/test/setup.d.ts +1 -1
- package/dist/test/setup.js +19 -19
- package/dist/test/testUtils.d.ts +9 -15
- package/dist/test/testUtils.js +78 -92
- package/dist/test/utils/errorHandling.test.js +119 -119
- package/dist/types/index.d.ts +6 -31
- package/dist/utils/__tests__/s3ConfigIdentifier.test.d.ts +1 -0
- package/dist/utils/__tests__/s3ConfigIdentifier.test.js +429 -0
- package/dist/utils/constants.js +8 -8
- package/dist/utils/deletion/index.d.ts +2 -2
- package/dist/utils/deletion/messages.d.ts +1 -1
- package/dist/utils/deletion/messages.js +4 -4
- package/dist/utils/errorHandling.d.ts +3 -3
- package/dist/utils/errorHandling.js +6 -6
- package/dist/utils/hooks.js +8 -8
- package/dist/utils/index.d.ts +5 -4
- package/dist/utils/index.js +2 -0
- package/dist/utils/proxyMiddleware.d.ts +1 -1
- package/dist/utils/proxyMiddleware.js +6 -11
- package/dist/utils/s3Client.d.ts +2 -2
- package/dist/utils/s3Client.js +1 -1
- package/dist/utils/s3ConfigIdentifier.d.ts +68 -0
- package/dist/utils/s3ConfigIdentifier.js +55 -0
- package/dist/utils/s3RuleUtils.d.ts +5 -5
- package/dist/utils/s3RuleUtils.js +17 -17
- package/dist/utils/useSupportedNotificationEvents.d.ts +6 -0
- package/dist/utils/useSupportedNotificationEvents.js +7 -0
- package/package.json +2 -2
|
@@ -1,11 +1,11 @@
|
|
|
1
1
|
import * as __WEBPACK_EXTERNAL_MODULE__index_js_95fdb65a__ from "../index.js";
|
|
2
2
|
import { jsx } from "react/jsx-runtime";
|
|
3
3
|
import { cleanup, render, screen } from "@testing-library/react";
|
|
4
|
-
import { MemoryRouter, Route, Routes } from "react-router
|
|
4
|
+
import { MemoryRouter, Route, Routes } from "react-router";
|
|
5
5
|
import { QueryClient, QueryClientProvider } from "@tanstack/react-query";
|
|
6
6
|
import { DataBrowserUICustomizationProvider } from "../../../../contexts/DataBrowserUICustomizationContext.js";
|
|
7
7
|
var __webpack_modules__ = {
|
|
8
|
-
"
|
|
8
|
+
"..": function(module) {
|
|
9
9
|
module.exports = __WEBPACK_EXTERNAL_MODULE__index_js_95fdb65a__;
|
|
10
10
|
}
|
|
11
11
|
};
|
|
@@ -19,57 +19,57 @@ function __webpack_require__(moduleId) {
|
|
|
19
19
|
__webpack_modules__[moduleId](module, module.exports, __webpack_require__);
|
|
20
20
|
return module.exports;
|
|
21
21
|
}
|
|
22
|
-
var external_index_js_ = __webpack_require__("
|
|
23
|
-
jest.mock(
|
|
22
|
+
var external_index_js_ = __webpack_require__("..");
|
|
23
|
+
jest.mock('../ObjectSummary', ()=>({
|
|
24
24
|
ObjectSummary: ()=>/*#__PURE__*/ jsx("div", {
|
|
25
25
|
"data-testid": "object-summary",
|
|
26
26
|
children: "ObjectSummary"
|
|
27
27
|
})
|
|
28
28
|
}));
|
|
29
|
-
jest.mock(
|
|
29
|
+
jest.mock('../ObjectMetadata', ()=>({
|
|
30
30
|
ObjectMetadata: ()=>/*#__PURE__*/ jsx("div", {
|
|
31
31
|
"data-testid": "object-metadata",
|
|
32
32
|
children: "ObjectMetadata"
|
|
33
33
|
})
|
|
34
34
|
}));
|
|
35
|
-
jest.mock(
|
|
35
|
+
jest.mock('../ObjectTags', ()=>({
|
|
36
36
|
ObjectTags: ()=>/*#__PURE__*/ jsx("div", {
|
|
37
37
|
"data-testid": "object-tags",
|
|
38
38
|
children: "ObjectTags"
|
|
39
39
|
})
|
|
40
40
|
}));
|
|
41
41
|
const createMockObjectItem = (overrides)=>({
|
|
42
|
-
Key:
|
|
43
|
-
LastModified: new Date(
|
|
42
|
+
Key: 'test-object.txt',
|
|
43
|
+
LastModified: new Date('2024-01-01'),
|
|
44
44
|
Size: 1024,
|
|
45
|
-
type:
|
|
46
|
-
displayName:
|
|
45
|
+
type: 'object',
|
|
46
|
+
displayName: 'test-object.txt',
|
|
47
47
|
...overrides
|
|
48
48
|
});
|
|
49
49
|
const createMockVersionItem = ()=>({
|
|
50
|
-
Key:
|
|
51
|
-
VersionId:
|
|
52
|
-
LastModified: new Date(
|
|
50
|
+
Key: 'test-object.txt',
|
|
51
|
+
VersionId: 'version-123',
|
|
52
|
+
LastModified: new Date('2024-01-01'),
|
|
53
53
|
Size: 1024,
|
|
54
|
-
type:
|
|
55
|
-
displayName:
|
|
54
|
+
type: 'version',
|
|
55
|
+
displayName: 'test-object.txt',
|
|
56
56
|
IsLatest: true
|
|
57
57
|
});
|
|
58
58
|
const createMockFolderItem = ()=>({
|
|
59
|
-
Key:
|
|
60
|
-
type:
|
|
61
|
-
displayName:
|
|
59
|
+
Key: 'test-folder/',
|
|
60
|
+
type: 'folder',
|
|
61
|
+
displayName: 'test-folder/'
|
|
62
62
|
});
|
|
63
63
|
const createMockDeleteMarkerItem = ()=>({
|
|
64
|
-
Key:
|
|
65
|
-
VersionId:
|
|
66
|
-
LastModified: new Date(
|
|
67
|
-
type:
|
|
68
|
-
displayName:
|
|
64
|
+
Key: 'deleted-object.txt',
|
|
65
|
+
VersionId: 'delete-marker-123',
|
|
66
|
+
LastModified: new Date('2024-01-01'),
|
|
67
|
+
type: 'deleteMarker',
|
|
68
|
+
displayName: 'deleted-object.txt',
|
|
69
69
|
IsLatest: true,
|
|
70
70
|
isDeleteMarker: true
|
|
71
71
|
});
|
|
72
|
-
const renderWithProviders = (ui, { initialRoute =
|
|
72
|
+
const renderWithProviders = (ui, { initialRoute = '/buckets/test-bucket/objects', customizationConfig = {} } = {})=>{
|
|
73
73
|
const queryClient = new QueryClient({
|
|
74
74
|
defaultOptions: {
|
|
75
75
|
queries: {
|
|
@@ -98,78 +98,78 @@ const renderWithProviders = (ui, { initialRoute = "/buckets/test-bucket/objects"
|
|
|
98
98
|
})
|
|
99
99
|
}));
|
|
100
100
|
};
|
|
101
|
-
describe(
|
|
102
|
-
describe(
|
|
103
|
-
it(
|
|
101
|
+
describe('ObjectDetails', ()=>{
|
|
102
|
+
describe('Default Tabs', ()=>{
|
|
103
|
+
it('should render three default tabs', ()=>{
|
|
104
104
|
const item = createMockObjectItem();
|
|
105
105
|
renderWithProviders(/*#__PURE__*/ jsx(external_index_js_.ObjectDetails, {
|
|
106
106
|
item: item
|
|
107
107
|
}));
|
|
108
|
-
expect(screen.getByRole(
|
|
108
|
+
expect(screen.getByRole('tab', {
|
|
109
109
|
name: /summary/i
|
|
110
110
|
})).toBeInTheDocument();
|
|
111
|
-
expect(screen.getByRole(
|
|
111
|
+
expect(screen.getByRole('tab', {
|
|
112
112
|
name: /metadata/i
|
|
113
113
|
})).toBeInTheDocument();
|
|
114
|
-
expect(screen.getByRole(
|
|
114
|
+
expect(screen.getByRole('tab', {
|
|
115
115
|
name: /tags/i
|
|
116
116
|
})).toBeInTheDocument();
|
|
117
117
|
});
|
|
118
|
-
it(
|
|
118
|
+
it('should render Summary tab content by default', ()=>{
|
|
119
119
|
const item = createMockObjectItem();
|
|
120
120
|
renderWithProviders(/*#__PURE__*/ jsx(external_index_js_.ObjectDetails, {
|
|
121
121
|
item: item
|
|
122
122
|
}));
|
|
123
|
-
expect(screen.getByTestId(
|
|
123
|
+
expect(screen.getByTestId('object-summary')).toBeInTheDocument();
|
|
124
124
|
});
|
|
125
|
-
it(
|
|
125
|
+
it('should render child components when valid item is provided', ()=>{
|
|
126
126
|
const item = createMockObjectItem({
|
|
127
|
-
Key:
|
|
127
|
+
Key: 'my-file.txt'
|
|
128
128
|
});
|
|
129
129
|
renderWithProviders(/*#__PURE__*/ jsx(external_index_js_.ObjectDetails, {
|
|
130
130
|
item: item
|
|
131
131
|
}));
|
|
132
|
-
expect(screen.getByTestId(
|
|
132
|
+
expect(screen.getByTestId('object-summary')).toBeInTheDocument();
|
|
133
133
|
});
|
|
134
134
|
});
|
|
135
|
-
describe(
|
|
136
|
-
it(
|
|
135
|
+
describe('Version ID handling', ()=>{
|
|
136
|
+
it('should pass versionId when item is a version', ()=>{
|
|
137
137
|
const versionItem = createMockVersionItem();
|
|
138
138
|
renderWithProviders(/*#__PURE__*/ jsx(external_index_js_.ObjectDetails, {
|
|
139
139
|
item: versionItem
|
|
140
140
|
}));
|
|
141
|
-
expect(screen.getByTestId(
|
|
141
|
+
expect(screen.getByTestId('object-summary')).toBeInTheDocument();
|
|
142
142
|
});
|
|
143
|
-
it(
|
|
143
|
+
it('should not pass versionId for regular objects', ()=>{
|
|
144
144
|
const item = createMockObjectItem();
|
|
145
145
|
renderWithProviders(/*#__PURE__*/ jsx(external_index_js_.ObjectDetails, {
|
|
146
146
|
item: item
|
|
147
147
|
}));
|
|
148
|
-
expect(screen.getByTestId(
|
|
148
|
+
expect(screen.getByTestId('object-summary')).toBeInTheDocument();
|
|
149
149
|
});
|
|
150
150
|
});
|
|
151
|
-
describe(
|
|
152
|
-
it(
|
|
151
|
+
describe('Placeholder States', ()=>{
|
|
152
|
+
it('should show placeholder when no item is selected', ()=>{
|
|
153
153
|
renderWithProviders(/*#__PURE__*/ jsx(external_index_js_.ObjectDetails, {
|
|
154
154
|
item: null
|
|
155
155
|
}));
|
|
156
156
|
expect(screen.getByText(/select an object to view details/i)).toBeInTheDocument();
|
|
157
157
|
});
|
|
158
|
-
it(
|
|
158
|
+
it('should show placeholder for folder items', ()=>{
|
|
159
159
|
const folderItem = createMockFolderItem();
|
|
160
160
|
renderWithProviders(/*#__PURE__*/ jsx(external_index_js_.ObjectDetails, {
|
|
161
161
|
item: folderItem
|
|
162
162
|
}));
|
|
163
163
|
expect(screen.getByText(/a "folder" is selected/i)).toBeInTheDocument();
|
|
164
164
|
});
|
|
165
|
-
it(
|
|
165
|
+
it('should show placeholder for delete marker items', ()=>{
|
|
166
166
|
const deleteMarkerItem = createMockDeleteMarkerItem();
|
|
167
167
|
renderWithProviders(/*#__PURE__*/ jsx(external_index_js_.ObjectDetails, {
|
|
168
168
|
item: deleteMarkerItem
|
|
169
169
|
}));
|
|
170
170
|
expect(screen.getByText(/a "delete marker" is selected/i)).toBeInTheDocument();
|
|
171
171
|
});
|
|
172
|
-
it(
|
|
172
|
+
it('should show placeholder when item has no Key', ()=>{
|
|
173
173
|
const item = createMockObjectItem({
|
|
174
174
|
Key: void 0
|
|
175
175
|
});
|
|
@@ -178,38 +178,38 @@ describe("ObjectDetails", ()=>{
|
|
|
178
178
|
}));
|
|
179
179
|
expect(screen.getByText(/select an object to view details/i)).toBeInTheDocument();
|
|
180
180
|
});
|
|
181
|
-
it(
|
|
181
|
+
it('should show placeholder when item has empty Key', ()=>{
|
|
182
182
|
const item = createMockObjectItem({
|
|
183
|
-
Key:
|
|
183
|
+
Key: ''
|
|
184
184
|
});
|
|
185
185
|
renderWithProviders(/*#__PURE__*/ jsx(external_index_js_.ObjectDetails, {
|
|
186
186
|
item: item
|
|
187
187
|
}));
|
|
188
188
|
expect(screen.getByText(/select an object to view details/i)).toBeInTheDocument();
|
|
189
189
|
});
|
|
190
|
-
it(
|
|
190
|
+
it('should render tabs even in placeholder state', ()=>{
|
|
191
191
|
renderWithProviders(/*#__PURE__*/ jsx(external_index_js_.ObjectDetails, {
|
|
192
192
|
item: null
|
|
193
193
|
}));
|
|
194
|
-
expect(screen.getByRole(
|
|
194
|
+
expect(screen.getByRole('tab', {
|
|
195
195
|
name: /summary/i
|
|
196
196
|
})).toBeInTheDocument();
|
|
197
|
-
expect(screen.getByRole(
|
|
197
|
+
expect(screen.getByRole('tab', {
|
|
198
198
|
name: /metadata/i
|
|
199
199
|
})).toBeInTheDocument();
|
|
200
|
-
expect(screen.getByRole(
|
|
200
|
+
expect(screen.getByRole('tab', {
|
|
201
201
|
name: /tags/i
|
|
202
202
|
})).toBeInTheDocument();
|
|
203
203
|
});
|
|
204
204
|
});
|
|
205
|
-
describe(
|
|
206
|
-
it(
|
|
205
|
+
describe('Custom Tabs', ()=>{
|
|
206
|
+
it('should render extra custom tabs', ()=>{
|
|
207
207
|
const item = createMockObjectItem();
|
|
208
208
|
const customConfig = {
|
|
209
209
|
extraObjectTabs: [
|
|
210
210
|
{
|
|
211
|
-
id:
|
|
212
|
-
title:
|
|
211
|
+
id: 'custom-tab',
|
|
212
|
+
title: 'Custom Tab',
|
|
213
213
|
render: ()=>/*#__PURE__*/ jsx("div", {
|
|
214
214
|
"data-testid": "custom-tab-content",
|
|
215
215
|
children: "Custom Content"
|
|
@@ -222,17 +222,17 @@ describe("ObjectDetails", ()=>{
|
|
|
222
222
|
}), {
|
|
223
223
|
customizationConfig: customConfig
|
|
224
224
|
});
|
|
225
|
-
expect(screen.getByRole(
|
|
225
|
+
expect(screen.getByRole('tab', {
|
|
226
226
|
name: /custom tab/i
|
|
227
227
|
})).toBeInTheDocument();
|
|
228
228
|
});
|
|
229
|
-
it(
|
|
229
|
+
it('should render custom tab in tab list', ()=>{
|
|
230
230
|
const item = createMockObjectItem();
|
|
231
231
|
const customConfig = {
|
|
232
232
|
extraObjectTabs: [
|
|
233
233
|
{
|
|
234
|
-
id:
|
|
235
|
-
title:
|
|
234
|
+
id: 'versions',
|
|
235
|
+
title: 'Versions',
|
|
236
236
|
render: ()=>/*#__PURE__*/ jsx("div", {
|
|
237
237
|
"data-testid": "versions-tab",
|
|
238
238
|
children: "Version History"
|
|
@@ -245,18 +245,18 @@ describe("ObjectDetails", ()=>{
|
|
|
245
245
|
}), {
|
|
246
246
|
customizationConfig: customConfig
|
|
247
247
|
});
|
|
248
|
-
const versionsTab = screen.getByRole(
|
|
248
|
+
const versionsTab = screen.getByRole('tab', {
|
|
249
249
|
name: /versions/i
|
|
250
250
|
});
|
|
251
251
|
expect(versionsTab).toBeInTheDocument();
|
|
252
252
|
});
|
|
253
|
-
it(
|
|
253
|
+
it('should replace default tabs when custom tab has same ID', ()=>{
|
|
254
254
|
const item = createMockObjectItem();
|
|
255
255
|
const customConfig = {
|
|
256
256
|
extraObjectTabs: [
|
|
257
257
|
{
|
|
258
|
-
id:
|
|
259
|
-
title:
|
|
258
|
+
id: 'summary',
|
|
259
|
+
title: 'Custom Summary',
|
|
260
260
|
render: ()=>/*#__PURE__*/ jsx("div", {
|
|
261
261
|
"data-testid": "custom-summary",
|
|
262
262
|
children: "Custom Summary Content"
|
|
@@ -269,34 +269,34 @@ describe("ObjectDetails", ()=>{
|
|
|
269
269
|
}), {
|
|
270
270
|
customizationConfig: customConfig
|
|
271
271
|
});
|
|
272
|
-
expect(screen.getByRole(
|
|
272
|
+
expect(screen.getByRole('tab', {
|
|
273
273
|
name: /custom summary/i
|
|
274
274
|
})).toBeInTheDocument();
|
|
275
|
-
expect(screen.queryByRole(
|
|
275
|
+
expect(screen.queryByRole('tab', {
|
|
276
276
|
name: /^summary$/i
|
|
277
277
|
})).not.toBeInTheDocument();
|
|
278
278
|
});
|
|
279
|
-
it(
|
|
279
|
+
it('should support multiple custom tabs', ()=>{
|
|
280
280
|
const item = createMockObjectItem();
|
|
281
281
|
const customConfig = {
|
|
282
282
|
extraObjectTabs: [
|
|
283
283
|
{
|
|
284
|
-
id:
|
|
285
|
-
title:
|
|
284
|
+
id: 'versions',
|
|
285
|
+
title: 'Versions',
|
|
286
286
|
render: ()=>/*#__PURE__*/ jsx("div", {
|
|
287
287
|
children: "Versions"
|
|
288
288
|
})
|
|
289
289
|
},
|
|
290
290
|
{
|
|
291
|
-
id:
|
|
292
|
-
title:
|
|
291
|
+
id: 'permissions',
|
|
292
|
+
title: 'Permissions',
|
|
293
293
|
render: ()=>/*#__PURE__*/ jsx("div", {
|
|
294
294
|
children: "Permissions"
|
|
295
295
|
})
|
|
296
296
|
},
|
|
297
297
|
{
|
|
298
|
-
id:
|
|
299
|
-
title:
|
|
298
|
+
id: 'activity',
|
|
299
|
+
title: 'Activity',
|
|
300
300
|
render: ()=>/*#__PURE__*/ jsx("div", {
|
|
301
301
|
children: "Activity"
|
|
302
302
|
})
|
|
@@ -308,23 +308,23 @@ describe("ObjectDetails", ()=>{
|
|
|
308
308
|
}), {
|
|
309
309
|
customizationConfig: customConfig
|
|
310
310
|
});
|
|
311
|
-
expect(screen.getByRole(
|
|
311
|
+
expect(screen.getByRole('tab', {
|
|
312
312
|
name: /versions/i
|
|
313
313
|
})).toBeInTheDocument();
|
|
314
|
-
expect(screen.getByRole(
|
|
314
|
+
expect(screen.getByRole('tab', {
|
|
315
315
|
name: /permissions/i
|
|
316
316
|
})).toBeInTheDocument();
|
|
317
|
-
expect(screen.getByRole(
|
|
317
|
+
expect(screen.getByRole('tab', {
|
|
318
318
|
name: /activity/i
|
|
319
319
|
})).toBeInTheDocument();
|
|
320
320
|
});
|
|
321
|
-
it(
|
|
321
|
+
it('should support withoutPadding option for custom tabs', ()=>{
|
|
322
322
|
const item = createMockObjectItem();
|
|
323
323
|
const customConfig = {
|
|
324
324
|
extraObjectTabs: [
|
|
325
325
|
{
|
|
326
|
-
id:
|
|
327
|
-
title:
|
|
326
|
+
id: 'full-width',
|
|
327
|
+
title: 'Full Width',
|
|
328
328
|
withoutPadding: true,
|
|
329
329
|
render: ()=>/*#__PURE__*/ jsx("div", {
|
|
330
330
|
"data-testid": "full-width-content",
|
|
@@ -338,36 +338,36 @@ describe("ObjectDetails", ()=>{
|
|
|
338
338
|
}), {
|
|
339
339
|
customizationConfig: customConfig
|
|
340
340
|
});
|
|
341
|
-
expect(screen.getByRole(
|
|
341
|
+
expect(screen.getByRole('tab', {
|
|
342
342
|
name: /full width/i
|
|
343
343
|
})).toBeInTheDocument();
|
|
344
344
|
});
|
|
345
345
|
});
|
|
346
|
-
describe(
|
|
347
|
-
it(
|
|
346
|
+
describe('Tab Ordering', ()=>{
|
|
347
|
+
it('should maintain default tab order', ()=>{
|
|
348
348
|
const item = createMockObjectItem();
|
|
349
349
|
renderWithProviders(/*#__PURE__*/ jsx(external_index_js_.ObjectDetails, {
|
|
350
350
|
item: item
|
|
351
351
|
}));
|
|
352
|
-
const tabs = screen.getAllByRole(
|
|
352
|
+
const tabs = screen.getAllByRole('tab');
|
|
353
353
|
expect(tabs[0]).toHaveTextContent(/summary/i);
|
|
354
354
|
expect(tabs[1]).toHaveTextContent(/metadata/i);
|
|
355
355
|
expect(tabs[2]).toHaveTextContent(/tags/i);
|
|
356
356
|
});
|
|
357
|
-
it(
|
|
357
|
+
it('should append custom tabs after default tabs', ()=>{
|
|
358
358
|
const item = createMockObjectItem();
|
|
359
359
|
const customConfig = {
|
|
360
360
|
extraObjectTabs: [
|
|
361
361
|
{
|
|
362
|
-
id:
|
|
363
|
-
title:
|
|
362
|
+
id: 'custom1',
|
|
363
|
+
title: 'Custom 1',
|
|
364
364
|
render: ()=>/*#__PURE__*/ jsx("div", {
|
|
365
365
|
children: "Custom 1"
|
|
366
366
|
})
|
|
367
367
|
},
|
|
368
368
|
{
|
|
369
|
-
id:
|
|
370
|
-
title:
|
|
369
|
+
id: 'custom2',
|
|
370
|
+
title: 'Custom 2',
|
|
371
371
|
render: ()=>/*#__PURE__*/ jsx("div", {
|
|
372
372
|
children: "Custom 2"
|
|
373
373
|
})
|
|
@@ -379,7 +379,7 @@ describe("ObjectDetails", ()=>{
|
|
|
379
379
|
}), {
|
|
380
380
|
customizationConfig: customConfig
|
|
381
381
|
});
|
|
382
|
-
const tabs = screen.getAllByRole(
|
|
382
|
+
const tabs = screen.getAllByRole('tab');
|
|
383
383
|
expect(tabs[0]).toHaveTextContent(/summary/i);
|
|
384
384
|
expect(tabs[1]).toHaveTextContent(/metadata/i);
|
|
385
385
|
expect(tabs[2]).toHaveTextContent(/tags/i);
|
|
@@ -387,18 +387,18 @@ describe("ObjectDetails", ()=>{
|
|
|
387
387
|
expect(tabs[4]).toHaveTextContent(/custom 2/i);
|
|
388
388
|
});
|
|
389
389
|
});
|
|
390
|
-
describe(
|
|
391
|
-
it(
|
|
390
|
+
describe('Context Provider', ()=>{
|
|
391
|
+
it('should render child components when context is provided', ()=>{
|
|
392
392
|
const item = createMockObjectItem({
|
|
393
|
-
Key:
|
|
393
|
+
Key: 'test-file.txt'
|
|
394
394
|
});
|
|
395
395
|
renderWithProviders(/*#__PURE__*/ jsx(external_index_js_.ObjectDetails, {
|
|
396
396
|
item: item
|
|
397
397
|
}));
|
|
398
|
-
expect(screen.getByTestId(
|
|
398
|
+
expect(screen.getByTestId('object-summary')).toBeInTheDocument();
|
|
399
399
|
});
|
|
400
|
-
it(
|
|
401
|
-
const { useObjectDetailsContext } = __webpack_require__("
|
|
400
|
+
it('should throw error when useObjectDetailsContext is used outside provider', ()=>{
|
|
401
|
+
const { useObjectDetailsContext } = __webpack_require__("..");
|
|
402
402
|
const TestComponent = ()=>{
|
|
403
403
|
useObjectDetailsContext();
|
|
404
404
|
return null;
|
|
@@ -410,21 +410,21 @@ describe("ObjectDetails", ()=>{
|
|
|
410
410
|
client: new QueryClient(),
|
|
411
411
|
children: /*#__PURE__*/ jsx(TestComponent, {})
|
|
412
412
|
}));
|
|
413
|
-
}).toThrow(
|
|
413
|
+
}).toThrow('ObjectDetails components must be used within ObjectDetails');
|
|
414
414
|
console.error = originalError;
|
|
415
415
|
});
|
|
416
|
-
it(
|
|
416
|
+
it('should provide correct context values to nested components', ()=>{
|
|
417
417
|
const item = createMockObjectItem({
|
|
418
|
-
Key:
|
|
418
|
+
Key: 'context-test.txt'
|
|
419
419
|
});
|
|
420
420
|
renderWithProviders(/*#__PURE__*/ jsx(external_index_js_.ObjectDetails, {
|
|
421
421
|
item: item
|
|
422
422
|
}));
|
|
423
|
-
expect(screen.getByTestId(
|
|
423
|
+
expect(screen.getByTestId('object-summary')).toBeInTheDocument();
|
|
424
424
|
});
|
|
425
425
|
});
|
|
426
|
-
describe(
|
|
427
|
-
it(
|
|
426
|
+
describe('Edge Cases', ()=>{
|
|
427
|
+
it('should handle missing bucketName in route', ()=>{
|
|
428
428
|
const item = createMockObjectItem();
|
|
429
429
|
const queryClient = new QueryClient();
|
|
430
430
|
render(/*#__PURE__*/ jsx(QueryClientProvider, {
|
|
@@ -433,7 +433,7 @@ describe("ObjectDetails", ()=>{
|
|
|
433
433
|
config: {},
|
|
434
434
|
children: /*#__PURE__*/ jsx(MemoryRouter, {
|
|
435
435
|
initialEntries: [
|
|
436
|
-
|
|
436
|
+
'/invalid-route'
|
|
437
437
|
],
|
|
438
438
|
children: /*#__PURE__*/ jsx(Routes, {
|
|
439
439
|
children: /*#__PURE__*/ jsx(Route, {
|
|
@@ -448,69 +448,69 @@ describe("ObjectDetails", ()=>{
|
|
|
448
448
|
}));
|
|
449
449
|
expect(screen.getByText(/select an object to view details/i)).toBeInTheDocument();
|
|
450
450
|
});
|
|
451
|
-
it(
|
|
451
|
+
it('should handle item type changes', ()=>{
|
|
452
452
|
renderWithProviders(/*#__PURE__*/ jsx(external_index_js_.ObjectDetails, {
|
|
453
453
|
item: createMockObjectItem()
|
|
454
454
|
}));
|
|
455
|
-
expect(screen.getByTestId(
|
|
455
|
+
expect(screen.getByTestId('object-summary')).toBeInTheDocument();
|
|
456
456
|
cleanup();
|
|
457
457
|
renderWithProviders(/*#__PURE__*/ jsx(external_index_js_.ObjectDetails, {
|
|
458
458
|
item: createMockFolderItem()
|
|
459
459
|
}));
|
|
460
460
|
expect(screen.getByText(/a "folder" is selected/i)).toBeInTheDocument();
|
|
461
461
|
});
|
|
462
|
-
it(
|
|
462
|
+
it('should memoize tabs content efficiently', ()=>{
|
|
463
463
|
const item = createMockObjectItem();
|
|
464
464
|
renderWithProviders(/*#__PURE__*/ jsx(external_index_js_.ObjectDetails, {
|
|
465
465
|
item: item
|
|
466
466
|
}));
|
|
467
|
-
screen.getByTestId(
|
|
467
|
+
screen.getByTestId('object-summary');
|
|
468
468
|
cleanup();
|
|
469
469
|
renderWithProviders(/*#__PURE__*/ jsx(external_index_js_.ObjectDetails, {
|
|
470
470
|
item: item
|
|
471
471
|
}));
|
|
472
|
-
expect(screen.getByTestId(
|
|
472
|
+
expect(screen.getByTestId('object-summary')).toBeInTheDocument();
|
|
473
473
|
});
|
|
474
474
|
});
|
|
475
|
-
describe(
|
|
476
|
-
it(
|
|
475
|
+
describe('Performance', ()=>{
|
|
476
|
+
it('should not recreate context value unnecessarily', ()=>{
|
|
477
477
|
const item = createMockObjectItem({
|
|
478
|
-
Key:
|
|
478
|
+
Key: 'same-key.txt'
|
|
479
479
|
});
|
|
480
480
|
renderWithProviders(/*#__PURE__*/ jsx(external_index_js_.ObjectDetails, {
|
|
481
481
|
item: item
|
|
482
482
|
}));
|
|
483
|
-
screen.getByTestId(
|
|
483
|
+
screen.getByTestId('object-summary');
|
|
484
484
|
cleanup();
|
|
485
485
|
const sameKeyItem = createMockObjectItem({
|
|
486
|
-
Key:
|
|
486
|
+
Key: 'same-key.txt'
|
|
487
487
|
});
|
|
488
488
|
renderWithProviders(/*#__PURE__*/ jsx(external_index_js_.ObjectDetails, {
|
|
489
489
|
item: sameKeyItem
|
|
490
490
|
}));
|
|
491
|
-
expect(screen.getByTestId(
|
|
491
|
+
expect(screen.getByTestId('object-summary')).toBeInTheDocument();
|
|
492
492
|
});
|
|
493
|
-
it(
|
|
493
|
+
it('should handle rapid item changes', ()=>{
|
|
494
494
|
renderWithProviders(/*#__PURE__*/ jsx(external_index_js_.ObjectDetails, {
|
|
495
495
|
item: createMockObjectItem({
|
|
496
|
-
Key:
|
|
496
|
+
Key: 'file1.txt'
|
|
497
497
|
})
|
|
498
498
|
}));
|
|
499
|
-
expect(screen.getByTestId(
|
|
499
|
+
expect(screen.getByTestId('object-summary')).toBeInTheDocument();
|
|
500
500
|
cleanup();
|
|
501
501
|
renderWithProviders(/*#__PURE__*/ jsx(external_index_js_.ObjectDetails, {
|
|
502
502
|
item: createMockObjectItem({
|
|
503
|
-
Key:
|
|
503
|
+
Key: 'file2.txt'
|
|
504
504
|
})
|
|
505
505
|
}));
|
|
506
|
-
expect(screen.getByTestId(
|
|
506
|
+
expect(screen.getByTestId('object-summary')).toBeInTheDocument();
|
|
507
507
|
cleanup();
|
|
508
508
|
renderWithProviders(/*#__PURE__*/ jsx(external_index_js_.ObjectDetails, {
|
|
509
509
|
item: createMockObjectItem({
|
|
510
|
-
Key:
|
|
510
|
+
Key: 'file3.txt'
|
|
511
511
|
})
|
|
512
512
|
}));
|
|
513
|
-
expect(screen.getByTestId(
|
|
513
|
+
expect(screen.getByTestId('object-summary')).toBeInTheDocument();
|
|
514
514
|
});
|
|
515
515
|
});
|
|
516
516
|
});
|