@gravity-ui/data-source 0.9.0 → 0.10.0-alpha.0
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/build/cjs/core/types/DataSource.d.ts +8 -8
- package/build/cjs/core/types/DataSource.js.map +1 -1
- package/build/cjs/react/components/AsyncBoundary/AsyncBoundary.d.ts +3 -0
- package/build/cjs/react/components/AsyncBoundary/AsyncBoundary.js +35 -0
- package/build/cjs/react/components/AsyncBoundary/AsyncBoundary.js.map +1 -0
- package/build/cjs/react/components/AsyncBoundary/index.d.ts +3 -0
- package/build/cjs/react/components/AsyncBoundary/index.js +20 -0
- package/build/cjs/react/components/AsyncBoundary/index.js.map +1 -0
- package/build/cjs/react/components/AsyncBoundary/types.d.ts +13 -0
- package/build/cjs/react/components/AsyncBoundary/types.js +6 -0
- package/build/cjs/react/components/AsyncBoundary/types.js.map +1 -0
- package/build/cjs/react/components/AsyncBoundary/withAsyncBoundary.d.ts +3 -0
- package/build/cjs/react/components/AsyncBoundary/withAsyncBoundary.js +26 -0
- package/build/cjs/react/components/AsyncBoundary/withAsyncBoundary.js.map +1 -0
- package/build/cjs/react/components/EmptyView/EmptyView.d.ts +2 -0
- package/build/cjs/react/components/EmptyView/EmptyView.js +10 -0
- package/build/cjs/react/components/EmptyView/EmptyView.js.map +1 -0
- package/build/cjs/react/components/EmptyView/index.d.ts +1 -0
- package/build/cjs/react/components/EmptyView/index.js +13 -0
- package/build/cjs/react/components/EmptyView/index.js.map +1 -0
- package/build/cjs/react/components/types.d.ts +1 -1
- package/build/cjs/react/components/types.js.map +1 -1
- package/build/cjs/react/index.d.ts +5 -3
- package/build/cjs/react/index.js +27 -3
- package/build/cjs/react/index.js.map +1 -1
- package/build/cjs/react-query/components/QueryAsyncBoundary/QueryAsyncBoundary.d.ts +3 -0
- package/build/cjs/react-query/components/QueryAsyncBoundary/QueryAsyncBoundary.js +23 -0
- package/build/cjs/react-query/components/QueryAsyncBoundary/QueryAsyncBoundary.js.map +1 -0
- package/build/cjs/react-query/components/QueryAsyncBoundary/index.d.ts +3 -0
- package/build/cjs/react-query/components/QueryAsyncBoundary/index.js +20 -0
- package/build/cjs/react-query/components/QueryAsyncBoundary/index.js.map +1 -0
- package/build/cjs/react-query/components/QueryAsyncBoundary/types.d.ts +8 -0
- package/build/cjs/react-query/components/QueryAsyncBoundary/types.js +6 -0
- package/build/cjs/react-query/components/QueryAsyncBoundary/types.js.map +1 -0
- package/build/cjs/react-query/components/QueryAsyncBoundary/withQueryAsyncBoundary.d.ts +3 -0
- package/build/cjs/react-query/components/QueryAsyncBoundary/withQueryAsyncBoundary.js +26 -0
- package/build/cjs/react-query/components/QueryAsyncBoundary/withQueryAsyncBoundary.js.map +1 -0
- package/build/cjs/react-query/hooks/useSuspenseQueryData.d.ts +9 -0
- package/build/cjs/react-query/hooks/useSuspenseQueryData.js +22 -0
- package/build/cjs/react-query/hooks/useSuspenseQueryData.js.map +1 -0
- package/build/cjs/react-query/index.d.ts +2 -0
- package/build/cjs/react-query/index.js +35 -0
- package/build/cjs/react-query/index.js.map +1 -1
- package/build/esm/core/types/DataSource.d.ts +8 -8
- package/build/esm/core/types/DataSource.js.map +1 -1
- package/build/esm/react/components/AsyncBoundary/AsyncBoundary.d.ts +3 -0
- package/build/esm/react/components/AsyncBoundary/AsyncBoundary.js +28 -0
- package/build/esm/react/components/AsyncBoundary/AsyncBoundary.js.map +1 -0
- package/build/esm/react/components/AsyncBoundary/index.d.ts +3 -0
- package/build/esm/react/components/AsyncBoundary/index.js +3 -0
- package/build/esm/react/components/AsyncBoundary/index.js.map +1 -0
- package/build/esm/react/components/AsyncBoundary/types.d.ts +13 -0
- package/build/esm/react/components/AsyncBoundary/types.js +2 -0
- package/build/esm/react/components/AsyncBoundary/types.js.map +1 -0
- package/build/esm/react/components/AsyncBoundary/withAsyncBoundary.d.ts +3 -0
- package/build/esm/react/components/AsyncBoundary/withAsyncBoundary.js +19 -0
- package/build/esm/react/components/AsyncBoundary/withAsyncBoundary.js.map +1 -0
- package/build/esm/react/components/EmptyView/EmptyView.d.ts +2 -0
- package/build/esm/react/components/EmptyView/EmptyView.js +4 -0
- package/build/esm/react/components/EmptyView/EmptyView.js.map +1 -0
- package/build/esm/react/components/EmptyView/index.d.ts +1 -0
- package/build/esm/react/components/EmptyView/index.js +2 -0
- package/build/esm/react/components/EmptyView/index.js.map +1 -0
- package/build/esm/react/components/types.d.ts +1 -1
- package/build/esm/react/components/types.js.map +1 -1
- package/build/esm/react/index.d.ts +5 -3
- package/build/esm/react/index.js +4 -2
- package/build/esm/react/index.js.map +1 -1
- package/build/esm/react-query/components/QueryAsyncBoundary/QueryAsyncBoundary.d.ts +3 -0
- package/build/esm/react-query/components/QueryAsyncBoundary/QueryAsyncBoundary.js +16 -0
- package/build/esm/react-query/components/QueryAsyncBoundary/QueryAsyncBoundary.js.map +1 -0
- package/build/esm/react-query/components/QueryAsyncBoundary/index.d.ts +3 -0
- package/build/esm/react-query/components/QueryAsyncBoundary/index.js +3 -0
- package/build/esm/react-query/components/QueryAsyncBoundary/index.js.map +1 -0
- package/build/esm/react-query/components/QueryAsyncBoundary/types.d.ts +8 -0
- package/build/esm/react-query/components/QueryAsyncBoundary/types.js +2 -0
- package/build/esm/react-query/components/QueryAsyncBoundary/types.js.map +1 -0
- package/build/esm/react-query/components/QueryAsyncBoundary/withQueryAsyncBoundary.d.ts +3 -0
- package/build/esm/react-query/components/QueryAsyncBoundary/withQueryAsyncBoundary.js +19 -0
- package/build/esm/react-query/components/QueryAsyncBoundary/withQueryAsyncBoundary.js.map +1 -0
- package/build/esm/react-query/hooks/useSuspenseQueryData.d.ts +9 -0
- package/build/esm/react-query/hooks/useSuspenseQueryData.js +15 -0
- package/build/esm/react-query/hooks/useSuspenseQueryData.js.map +1 -0
- package/build/esm/react-query/index.d.ts +2 -0
- package/build/esm/react-query/index.js +2 -0
- package/build/esm/react-query/index.js.map +1 -1
- package/build/plugin/esbuild.d.mts +7 -0
- package/build/plugin/esbuild.mjs +6 -0
- package/build/plugin/factory-2tSt4Rte.mjs +513 -0
- package/build/plugin/index-mY40Sgl5.d.mts +24 -0
- package/build/plugin/index.d.mts +7 -0
- package/build/plugin/index.mjs +6 -0
- package/build/plugin/rollup.d.mts +6 -0
- package/build/plugin/rollup.mjs +6 -0
- package/build/plugin/rspack.d.mts +7 -0
- package/build/plugin/rspack.mjs +6 -0
- package/build/plugin/typings/client.d.ts +11 -0
- package/build/plugin/vite.d.mts +6 -0
- package/build/plugin/vite.mjs +6 -0
- package/build/plugin/webpack.d.mts +7 -0
- package/build/plugin/webpack.mjs +6 -0
- package/package.json +54 -5
- package/build/cjs/core/utils/__tests__/composeFullKey.test.js +0 -34
- package/build/cjs/core/utils/__tests__/composeFullKey.test.js.map +0 -1
- package/build/cjs/core/utils/__tests__/composeKey.test.js +0 -32
- package/build/cjs/core/utils/__tests__/composeKey.test.js.map +0 -1
- package/build/cjs/core/utils/__tests__/getError.test.js +0 -31
- package/build/cjs/core/utils/__tests__/getError.test.js.map +0 -1
- package/build/cjs/core/utils/__tests__/getStatus.test.js +0 -49
- package/build/cjs/core/utils/__tests__/getStatus.test.js.map +0 -1
- package/build/cjs/core/utils/__tests__/hasTag.test.js +0 -31
- package/build/cjs/core/utils/__tests__/hasTag.test.js.map +0 -1
- package/build/cjs/core/utils/__tests__/mergeStatuses.test.js +0 -25
- package/build/cjs/core/utils/__tests__/mergeStatuses.test.js.map +0 -1
- package/build/cjs/core/utils/__tests__/skipContext.test.js +0 -70
- package/build/cjs/core/utils/__tests__/skipContext.test.js.map +0 -1
- package/build/cjs/core/utils/__tests__/withCancellation.test.js +0 -106
- package/build/cjs/core/utils/__tests__/withCancellation.test.js.map +0 -1
- package/build/cjs/core/utils/__tests__/withCatch.test.js +0 -208
- package/build/cjs/core/utils/__tests__/withCatch.test.js.map +0 -1
- package/build/cjs/react/__tests__/DataManagerContext.test.js +0 -47
- package/build/cjs/react/__tests__/DataManagerContext.test.js.map +0 -1
- package/build/cjs/react/__tests__/withDataManager.test.js +0 -61
- package/build/cjs/react/__tests__/withDataManager.test.js.map +0 -1
- package/build/cjs/react/components/DataInfiniteLoader/__tests__/DataInfiniteLoader.test.js +0 -187
- package/build/cjs/react/components/DataInfiniteLoader/__tests__/DataInfiniteLoader.test.js.map +0 -1
- package/build/cjs/react/components/DataLoader/__tests__/DataLoader.test.js +0 -119
- package/build/cjs/react/components/DataLoader/__tests__/DataLoader.test.js.map +0 -1
- package/build/cjs/react-query/__tests__/createQueryNormalizer.test.js +0 -177
- package/build/cjs/react-query/__tests__/createQueryNormalizer.test.js.map +0 -1
- package/build/cjs/react-query/__tests__/normalizationEdgeCases.test.js +0 -100
- package/build/cjs/react-query/__tests__/normalizationEdgeCases.test.js.map +0 -1
- package/build/cjs/react-query/__tests__/subscriptions.test.js +0 -1180
- package/build/cjs/react-query/__tests__/subscriptions.test.js.map +0 -1
- package/build/cjs/react-query/__tests__/threeLevelIntegration.test.js +0 -659
- package/build/cjs/react-query/__tests__/threeLevelIntegration.test.js.map +0 -1
- package/build/cjs/react-query/__tests__/updateQueriesFromMutationData.test.js +0 -229
- package/build/cjs/react-query/__tests__/updateQueriesFromMutationData.test.js.map +0 -1
- package/build/cjs/react-query/hooks/__tests__/useQueryContext.test.js +0 -55
- package/build/cjs/react-query/hooks/__tests__/useQueryContext.test.js.map +0 -1
- package/build/cjs/react-query/hooks/__tests__/useQueryData.refetch.test.js +0 -230
- package/build/cjs/react-query/hooks/__tests__/useQueryData.refetch.test.js.map +0 -1
- package/build/cjs/react-query/hooks/__tests__/useQueryData.test.js +0 -97
- package/build/cjs/react-query/hooks/__tests__/useQueryData.test.js.map +0 -1
- package/build/cjs/react-query/hooks/__tests__/useQueryResponses.test.js +0 -77
- package/build/cjs/react-query/hooks/__tests__/useQueryResponses.test.js.map +0 -1
- package/build/cjs/react-query/hooks/__tests__/useRefetchAll.test.js +0 -79
- package/build/cjs/react-query/hooks/__tests__/useRefetchAll.test.js.map +0 -1
- package/build/cjs/react-query/hooks/__tests__/useRefetchErrored.test.js +0 -117
- package/build/cjs/react-query/hooks/__tests__/useRefetchErrored.test.js.map +0 -1
- package/build/cjs/react-query/hooks/__tests__/useRefetchInterval.test.js +0 -156
- package/build/cjs/react-query/hooks/__tests__/useRefetchInterval.test.js.map +0 -1
- package/build/cjs/react-query/utils/__tests__/checkMutationObjectsKeys.test.js +0 -295
- package/build/cjs/react-query/utils/__tests__/checkMutationObjectsKeys.test.js.map +0 -1
- package/build/cjs/react-query/utils/__tests__/formatNullableValue.test.js +0 -27
- package/build/cjs/react-query/utils/__tests__/formatNullableValue.test.js.map +0 -1
- package/build/cjs/react-query/utils/__tests__/getProgressiveRefetch.test.js +0 -76
- package/build/cjs/react-query/utils/__tests__/getProgressiveRefetch.test.js.map +0 -1
- package/build/cjs/react-query/utils/__tests__/normalizeStatus.test.js +0 -30
- package/build/cjs/react-query/utils/__tests__/normalizeStatus.test.js.map +0 -1
- package/build/cjs/react-query/utils/__tests__/notReachable.test.js +0 -35
- package/build/cjs/react-query/utils/__tests__/notReachable.test.js.map +0 -1
- package/build/cjs/react-query/utils/__tests__/parseNullableValue.test.js +0 -27
- package/build/cjs/react-query/utils/__tests__/parseNullableValue.test.js.map +0 -1
- package/build/cjs/setupTests.d.ts +0 -1
- package/build/cjs/setupTests.js +0 -4
- package/build/cjs/setupTests.js.map +0 -1
- package/build/esm/core/utils/__tests__/composeFullKey.test.js +0 -32
- package/build/esm/core/utils/__tests__/composeFullKey.test.js.map +0 -1
- package/build/esm/core/utils/__tests__/composeKey.test.js +0 -30
- package/build/esm/core/utils/__tests__/composeKey.test.js.map +0 -1
- package/build/esm/core/utils/__tests__/getError.test.js +0 -29
- package/build/esm/core/utils/__tests__/getError.test.js.map +0 -1
- package/build/esm/core/utils/__tests__/getStatus.test.js +0 -47
- package/build/esm/core/utils/__tests__/getStatus.test.js.map +0 -1
- package/build/esm/core/utils/__tests__/hasTag.test.js +0 -29
- package/build/esm/core/utils/__tests__/hasTag.test.js.map +0 -1
- package/build/esm/core/utils/__tests__/mergeStatuses.test.js +0 -23
- package/build/esm/core/utils/__tests__/mergeStatuses.test.js.map +0 -1
- package/build/esm/core/utils/__tests__/skipContext.test.js +0 -67
- package/build/esm/core/utils/__tests__/skipContext.test.js.map +0 -1
- package/build/esm/core/utils/__tests__/withCancellation.test.js +0 -104
- package/build/esm/core/utils/__tests__/withCancellation.test.js.map +0 -1
- package/build/esm/core/utils/__tests__/withCatch.test.js +0 -205
- package/build/esm/core/utils/__tests__/withCatch.test.js.map +0 -1
- package/build/esm/react/__tests__/DataManagerContext.test.js +0 -44
- package/build/esm/react/__tests__/DataManagerContext.test.js.map +0 -1
- package/build/esm/react/__tests__/withDataManager.test.js +0 -58
- package/build/esm/react/__tests__/withDataManager.test.js.map +0 -1
- package/build/esm/react/components/DataInfiniteLoader/__tests__/DataInfiniteLoader.test.js +0 -184
- package/build/esm/react/components/DataInfiniteLoader/__tests__/DataInfiniteLoader.test.js.map +0 -1
- package/build/esm/react/components/DataLoader/__tests__/DataLoader.test.js +0 -116
- package/build/esm/react/components/DataLoader/__tests__/DataLoader.test.js.map +0 -1
- package/build/esm/react-query/__tests__/createQueryNormalizer.test.js +0 -174
- package/build/esm/react-query/__tests__/createQueryNormalizer.test.js.map +0 -1
- package/build/esm/react-query/__tests__/normalizationEdgeCases.test.js +0 -98
- package/build/esm/react-query/__tests__/normalizationEdgeCases.test.js.map +0 -1
- package/build/esm/react-query/__tests__/subscriptions.test.js +0 -1176
- package/build/esm/react-query/__tests__/subscriptions.test.js.map +0 -1
- package/build/esm/react-query/__tests__/threeLevelIntegration.test.js +0 -656
- package/build/esm/react-query/__tests__/threeLevelIntegration.test.js.map +0 -1
- package/build/esm/react-query/__tests__/updateQueriesFromMutationData.test.js +0 -227
- package/build/esm/react-query/__tests__/updateQueriesFromMutationData.test.js.map +0 -1
- package/build/esm/react-query/hooks/__tests__/useQueryContext.test.js +0 -52
- package/build/esm/react-query/hooks/__tests__/useQueryContext.test.js.map +0 -1
- package/build/esm/react-query/hooks/__tests__/useQueryData.refetch.test.js +0 -227
- package/build/esm/react-query/hooks/__tests__/useQueryData.refetch.test.js.map +0 -1
- package/build/esm/react-query/hooks/__tests__/useQueryData.test.js +0 -95
- package/build/esm/react-query/hooks/__tests__/useQueryData.test.js.map +0 -1
- package/build/esm/react-query/hooks/__tests__/useQueryResponses.test.js +0 -74
- package/build/esm/react-query/hooks/__tests__/useQueryResponses.test.js.map +0 -1
- package/build/esm/react-query/hooks/__tests__/useRefetchAll.test.js +0 -77
- package/build/esm/react-query/hooks/__tests__/useRefetchAll.test.js.map +0 -1
- package/build/esm/react-query/hooks/__tests__/useRefetchErrored.test.js +0 -115
- package/build/esm/react-query/hooks/__tests__/useRefetchErrored.test.js.map +0 -1
- package/build/esm/react-query/hooks/__tests__/useRefetchInterval.test.js +0 -154
- package/build/esm/react-query/hooks/__tests__/useRefetchInterval.test.js.map +0 -1
- package/build/esm/react-query/utils/__tests__/checkMutationObjectsKeys.test.js +0 -292
- package/build/esm/react-query/utils/__tests__/checkMutationObjectsKeys.test.js.map +0 -1
- package/build/esm/react-query/utils/__tests__/formatNullableValue.test.js +0 -25
- package/build/esm/react-query/utils/__tests__/formatNullableValue.test.js.map +0 -1
- package/build/esm/react-query/utils/__tests__/getProgressiveRefetch.test.js +0 -74
- package/build/esm/react-query/utils/__tests__/getProgressiveRefetch.test.js.map +0 -1
- package/build/esm/react-query/utils/__tests__/normalizeStatus.test.js +0 -28
- package/build/esm/react-query/utils/__tests__/normalizeStatus.test.js.map +0 -1
- package/build/esm/react-query/utils/__tests__/notReachable.test.js +0 -33
- package/build/esm/react-query/utils/__tests__/notReachable.test.js.map +0 -1
- package/build/esm/react-query/utils/__tests__/parseNullableValue.test.js +0 -25
- package/build/esm/react-query/utils/__tests__/parseNullableValue.test.js.map +0 -1
- package/build/esm/setupTests.d.ts +0 -1
- package/build/esm/setupTests.js +0 -2
- package/build/esm/setupTests.js.map +0 -1
|
@@ -1,656 +0,0 @@
|
|
|
1
|
-
import _regeneratorRuntime from "@babel/runtime/helpers/regeneratorRuntime";
|
|
2
|
-
import _asyncToGenerator from "@babel/runtime/helpers/asyncToGenerator";
|
|
3
|
-
import React from 'react';
|
|
4
|
-
import { renderHook, waitFor } from '@testing-library/react';
|
|
5
|
-
import { ClientDataManager } from '../ClientDataManager';
|
|
6
|
-
import { DataSourceProvider } from '../DataSourceProvider';
|
|
7
|
-
import { useQueryData } from '../hooks/useQueryData';
|
|
8
|
-
import { makePlainQueryDataSource } from '../impl/plain/factory';
|
|
9
|
-
import { jsx as _jsx } from "react/jsx-runtime";
|
|
10
|
-
describe('Normalization Configuration Integration', function () {
|
|
11
|
-
var queryClient;
|
|
12
|
-
var dataManager;
|
|
13
|
-
beforeEach(function () {
|
|
14
|
-
dataManager = new ClientDataManager({
|
|
15
|
-
normalizerConfig: {
|
|
16
|
-
devLogging: false
|
|
17
|
-
}
|
|
18
|
-
});
|
|
19
|
-
queryClient = dataManager.queryClient;
|
|
20
|
-
});
|
|
21
|
-
afterEach(function () {
|
|
22
|
-
var _dataManager$queryNor;
|
|
23
|
-
(_dataManager$queryNor = dataManager.queryNormalizer) === null || _dataManager$queryNor === void 0 || _dataManager$queryNor.unsubscribe();
|
|
24
|
-
queryClient.clear();
|
|
25
|
-
});
|
|
26
|
-
describe('ClientDataManager configuration', function () {
|
|
27
|
-
it('should use custom getNormalizationObjectKey from config', /*#__PURE__*/_asyncToGenerator(/*#__PURE__*/_regeneratorRuntime().mark(function _callee2() {
|
|
28
|
-
var customGetKey, customDataManager, queryKey, normalized;
|
|
29
|
-
return _regeneratorRuntime().wrap(function _callee2$(_context2) {
|
|
30
|
-
while (1) switch (_context2.prev = _context2.next) {
|
|
31
|
-
case 0:
|
|
32
|
-
customGetKey = jest.fn(function (obj) {
|
|
33
|
-
return "custom:".concat(obj.id);
|
|
34
|
-
});
|
|
35
|
-
customDataManager = new ClientDataManager({
|
|
36
|
-
normalizerConfig: {
|
|
37
|
-
getNormalizationObjectKey: customGetKey,
|
|
38
|
-
devLogging: false
|
|
39
|
-
}
|
|
40
|
-
});
|
|
41
|
-
customDataManager.queryNormalizer.subscribe();
|
|
42
|
-
queryKey = ['users'];
|
|
43
|
-
_context2.next = 6;
|
|
44
|
-
return customDataManager.queryClient.fetchQuery({
|
|
45
|
-
queryKey: queryKey,
|
|
46
|
-
queryFn: function () {
|
|
47
|
-
var _queryFn = _asyncToGenerator(/*#__PURE__*/_regeneratorRuntime().mark(function _callee() {
|
|
48
|
-
return _regeneratorRuntime().wrap(function _callee$(_context) {
|
|
49
|
-
while (1) switch (_context.prev = _context.next) {
|
|
50
|
-
case 0:
|
|
51
|
-
return _context.abrupt("return", [{
|
|
52
|
-
id: '1',
|
|
53
|
-
name: 'User 1'
|
|
54
|
-
}]);
|
|
55
|
-
case 1:
|
|
56
|
-
case "end":
|
|
57
|
-
return _context.stop();
|
|
58
|
-
}
|
|
59
|
-
}, _callee);
|
|
60
|
-
}));
|
|
61
|
-
function queryFn() {
|
|
62
|
-
return _queryFn.apply(this, arguments);
|
|
63
|
-
}
|
|
64
|
-
return queryFn;
|
|
65
|
-
}(),
|
|
66
|
-
normalize: true
|
|
67
|
-
});
|
|
68
|
-
case 6:
|
|
69
|
-
normalized = customDataManager.queryNormalizer.getNormalizedData();
|
|
70
|
-
expect(normalized.objects['@@custom:1']).toBeDefined();
|
|
71
|
-
expect(customGetKey).toHaveBeenCalled();
|
|
72
|
-
customDataManager.queryNormalizer.unsubscribe();
|
|
73
|
-
customDataManager.queryClient.clear();
|
|
74
|
-
case 11:
|
|
75
|
-
case "end":
|
|
76
|
-
return _context2.stop();
|
|
77
|
-
}
|
|
78
|
-
}, _callee2);
|
|
79
|
-
})));
|
|
80
|
-
it('should use custom getArrayType from config', /*#__PURE__*/_asyncToGenerator(/*#__PURE__*/_regeneratorRuntime().mark(function _callee4() {
|
|
81
|
-
var customGetArrayType, customDataManager, queryKey;
|
|
82
|
-
return _regeneratorRuntime().wrap(function _callee4$(_context4) {
|
|
83
|
-
while (1) switch (_context4.prev = _context4.next) {
|
|
84
|
-
case 0:
|
|
85
|
-
customGetArrayType = jest.fn(function (_ref3) {
|
|
86
|
-
var arrayKey = _ref3.arrayKey;
|
|
87
|
-
return "custom:".concat(arrayKey);
|
|
88
|
-
});
|
|
89
|
-
customDataManager = new ClientDataManager({
|
|
90
|
-
normalizerConfig: {
|
|
91
|
-
getArrayType: customGetArrayType,
|
|
92
|
-
devLogging: false
|
|
93
|
-
}
|
|
94
|
-
});
|
|
95
|
-
customDataManager.queryNormalizer.subscribe();
|
|
96
|
-
queryKey = ['items'];
|
|
97
|
-
_context4.next = 6;
|
|
98
|
-
return customDataManager.queryClient.fetchQuery({
|
|
99
|
-
queryKey: queryKey,
|
|
100
|
-
queryFn: function () {
|
|
101
|
-
var _queryFn2 = _asyncToGenerator(/*#__PURE__*/_regeneratorRuntime().mark(function _callee3() {
|
|
102
|
-
return _regeneratorRuntime().wrap(function _callee3$(_context3) {
|
|
103
|
-
while (1) switch (_context3.prev = _context3.next) {
|
|
104
|
-
case 0:
|
|
105
|
-
return _context3.abrupt("return", {
|
|
106
|
-
items: [{
|
|
107
|
-
id: '1',
|
|
108
|
-
name: 'Item 1'
|
|
109
|
-
}]
|
|
110
|
-
});
|
|
111
|
-
case 1:
|
|
112
|
-
case "end":
|
|
113
|
-
return _context3.stop();
|
|
114
|
-
}
|
|
115
|
-
}, _callee3);
|
|
116
|
-
}));
|
|
117
|
-
function queryFn() {
|
|
118
|
-
return _queryFn2.apply(this, arguments);
|
|
119
|
-
}
|
|
120
|
-
return queryFn;
|
|
121
|
-
}(),
|
|
122
|
-
normalize: true
|
|
123
|
-
});
|
|
124
|
-
case 6:
|
|
125
|
-
expect(customGetArrayType).toHaveBeenCalled();
|
|
126
|
-
customDataManager.queryNormalizer.unsubscribe();
|
|
127
|
-
customDataManager.queryClient.clear();
|
|
128
|
-
case 9:
|
|
129
|
-
case "end":
|
|
130
|
-
return _context4.stop();
|
|
131
|
-
}
|
|
132
|
-
}, _callee4);
|
|
133
|
-
})));
|
|
134
|
-
});
|
|
135
|
-
describe('Query-level normalization control', function () {
|
|
136
|
-
it('should normalize when query has normalize: true', /*#__PURE__*/_asyncToGenerator(/*#__PURE__*/_regeneratorRuntime().mark(function _callee6() {
|
|
137
|
-
var queryKey, normalized;
|
|
138
|
-
return _regeneratorRuntime().wrap(function _callee6$(_context6) {
|
|
139
|
-
while (1) switch (_context6.prev = _context6.next) {
|
|
140
|
-
case 0:
|
|
141
|
-
dataManager.queryNormalizer.subscribe();
|
|
142
|
-
queryKey = ['users-normalized'];
|
|
143
|
-
_context6.next = 4;
|
|
144
|
-
return dataManager.queryClient.fetchQuery({
|
|
145
|
-
queryKey: queryKey,
|
|
146
|
-
queryFn: function () {
|
|
147
|
-
var _queryFn3 = _asyncToGenerator(/*#__PURE__*/_regeneratorRuntime().mark(function _callee5() {
|
|
148
|
-
return _regeneratorRuntime().wrap(function _callee5$(_context5) {
|
|
149
|
-
while (1) switch (_context5.prev = _context5.next) {
|
|
150
|
-
case 0:
|
|
151
|
-
return _context5.abrupt("return", [{
|
|
152
|
-
id: '1',
|
|
153
|
-
name: 'User 1'
|
|
154
|
-
}]);
|
|
155
|
-
case 1:
|
|
156
|
-
case "end":
|
|
157
|
-
return _context5.stop();
|
|
158
|
-
}
|
|
159
|
-
}, _callee5);
|
|
160
|
-
}));
|
|
161
|
-
function queryFn() {
|
|
162
|
-
return _queryFn3.apply(this, arguments);
|
|
163
|
-
}
|
|
164
|
-
return queryFn;
|
|
165
|
-
}(),
|
|
166
|
-
normalize: true
|
|
167
|
-
});
|
|
168
|
-
case 4:
|
|
169
|
-
normalized = dataManager.queryNormalizer.getNormalizedData(); // Data SHOULD be normalized
|
|
170
|
-
expect(normalized.objects['@@1']).toBeDefined();
|
|
171
|
-
case 6:
|
|
172
|
-
case "end":
|
|
173
|
-
return _context6.stop();
|
|
174
|
-
}
|
|
175
|
-
}, _callee6);
|
|
176
|
-
})));
|
|
177
|
-
it('should NOT normalize when query has normalize: false', /*#__PURE__*/_asyncToGenerator(/*#__PURE__*/_regeneratorRuntime().mark(function _callee8() {
|
|
178
|
-
var queryKey, normalized;
|
|
179
|
-
return _regeneratorRuntime().wrap(function _callee8$(_context8) {
|
|
180
|
-
while (1) switch (_context8.prev = _context8.next) {
|
|
181
|
-
case 0:
|
|
182
|
-
dataManager.queryNormalizer.subscribe();
|
|
183
|
-
queryKey = ['users-not-normalized'];
|
|
184
|
-
_context8.next = 4;
|
|
185
|
-
return dataManager.queryClient.fetchQuery({
|
|
186
|
-
queryKey: queryKey,
|
|
187
|
-
queryFn: function () {
|
|
188
|
-
var _queryFn4 = _asyncToGenerator(/*#__PURE__*/_regeneratorRuntime().mark(function _callee7() {
|
|
189
|
-
return _regeneratorRuntime().wrap(function _callee7$(_context7) {
|
|
190
|
-
while (1) switch (_context7.prev = _context7.next) {
|
|
191
|
-
case 0:
|
|
192
|
-
return _context7.abrupt("return", [{
|
|
193
|
-
id: '2',
|
|
194
|
-
name: 'User 2'
|
|
195
|
-
}]);
|
|
196
|
-
case 1:
|
|
197
|
-
case "end":
|
|
198
|
-
return _context7.stop();
|
|
199
|
-
}
|
|
200
|
-
}, _callee7);
|
|
201
|
-
}));
|
|
202
|
-
function queryFn() {
|
|
203
|
-
return _queryFn4.apply(this, arguments);
|
|
204
|
-
}
|
|
205
|
-
return queryFn;
|
|
206
|
-
}(),
|
|
207
|
-
normalize: false
|
|
208
|
-
});
|
|
209
|
-
case 4:
|
|
210
|
-
normalized = dataManager.queryNormalizer.getNormalizedData(); // Data should NOT be normalized
|
|
211
|
-
expect(normalized.objects['@@2']).toBeUndefined();
|
|
212
|
-
case 6:
|
|
213
|
-
case "end":
|
|
214
|
-
return _context8.stop();
|
|
215
|
-
}
|
|
216
|
-
}, _callee8);
|
|
217
|
-
})));
|
|
218
|
-
it('should normalize by default when normalize option is not provided', /*#__PURE__*/_asyncToGenerator(/*#__PURE__*/_regeneratorRuntime().mark(function _callee10() {
|
|
219
|
-
var queryKey, normalized;
|
|
220
|
-
return _regeneratorRuntime().wrap(function _callee10$(_context10) {
|
|
221
|
-
while (1) switch (_context10.prev = _context10.next) {
|
|
222
|
-
case 0:
|
|
223
|
-
dataManager.queryNormalizer.subscribe();
|
|
224
|
-
queryKey = ['users-default'];
|
|
225
|
-
_context10.next = 4;
|
|
226
|
-
return dataManager.queryClient.fetchQuery({
|
|
227
|
-
queryKey: queryKey,
|
|
228
|
-
queryFn: function () {
|
|
229
|
-
var _queryFn5 = _asyncToGenerator(/*#__PURE__*/_regeneratorRuntime().mark(function _callee9() {
|
|
230
|
-
return _regeneratorRuntime().wrap(function _callee9$(_context9) {
|
|
231
|
-
while (1) switch (_context9.prev = _context9.next) {
|
|
232
|
-
case 0:
|
|
233
|
-
return _context9.abrupt("return", [{
|
|
234
|
-
id: '3',
|
|
235
|
-
name: 'User 3'
|
|
236
|
-
}]);
|
|
237
|
-
case 1:
|
|
238
|
-
case "end":
|
|
239
|
-
return _context9.stop();
|
|
240
|
-
}
|
|
241
|
-
}, _callee9);
|
|
242
|
-
}));
|
|
243
|
-
function queryFn() {
|
|
244
|
-
return _queryFn5.apply(this, arguments);
|
|
245
|
-
}
|
|
246
|
-
return queryFn;
|
|
247
|
-
}()
|
|
248
|
-
});
|
|
249
|
-
case 4:
|
|
250
|
-
normalized = dataManager.queryNormalizer.getNormalizedData(); // Data SHOULD be normalized (default behavior is now true)
|
|
251
|
-
expect(normalized.objects['@@3']).toBeDefined();
|
|
252
|
-
case 6:
|
|
253
|
-
case "end":
|
|
254
|
-
return _context10.stop();
|
|
255
|
-
}
|
|
256
|
-
}, _callee10);
|
|
257
|
-
})));
|
|
258
|
-
});
|
|
259
|
-
describe('DataSourceProvider integration', function () {
|
|
260
|
-
it('should auto-subscribe queryNormalizer on mount', /*#__PURE__*/_asyncToGenerator(/*#__PURE__*/_regeneratorRuntime().mark(function _callee12() {
|
|
261
|
-
var wrapper, dataSource, _renderHook, result, normalized;
|
|
262
|
-
return _regeneratorRuntime().wrap(function _callee12$(_context12) {
|
|
263
|
-
while (1) switch (_context12.prev = _context12.next) {
|
|
264
|
-
case 0:
|
|
265
|
-
wrapper = function wrapper(_ref8) {
|
|
266
|
-
var children = _ref8.children;
|
|
267
|
-
return /*#__PURE__*/_jsx(DataSourceProvider, {
|
|
268
|
-
dataManager: dataManager,
|
|
269
|
-
children: children
|
|
270
|
-
});
|
|
271
|
-
};
|
|
272
|
-
dataSource = makePlainQueryDataSource({
|
|
273
|
-
name: 'users',
|
|
274
|
-
fetch: function () {
|
|
275
|
-
var _fetch = _asyncToGenerator(/*#__PURE__*/_regeneratorRuntime().mark(function _callee11() {
|
|
276
|
-
return _regeneratorRuntime().wrap(function _callee11$(_context11) {
|
|
277
|
-
while (1) switch (_context11.prev = _context11.next) {
|
|
278
|
-
case 0:
|
|
279
|
-
return _context11.abrupt("return", [{
|
|
280
|
-
id: '1',
|
|
281
|
-
name: 'User 1'
|
|
282
|
-
}]);
|
|
283
|
-
case 1:
|
|
284
|
-
case "end":
|
|
285
|
-
return _context11.stop();
|
|
286
|
-
}
|
|
287
|
-
}, _callee11);
|
|
288
|
-
}));
|
|
289
|
-
function fetch() {
|
|
290
|
-
return _fetch.apply(this, arguments);
|
|
291
|
-
}
|
|
292
|
-
return fetch;
|
|
293
|
-
}(),
|
|
294
|
-
options: {
|
|
295
|
-
normalize: true
|
|
296
|
-
}
|
|
297
|
-
});
|
|
298
|
-
_renderHook = renderHook(function () {
|
|
299
|
-
return useQueryData(dataSource, {});
|
|
300
|
-
}, {
|
|
301
|
-
wrapper: wrapper
|
|
302
|
-
}), result = _renderHook.result;
|
|
303
|
-
_context12.next = 5;
|
|
304
|
-
return waitFor(function () {
|
|
305
|
-
return expect(result.current.status).toBe('success');
|
|
306
|
-
});
|
|
307
|
-
case 5:
|
|
308
|
-
normalized = dataManager.queryNormalizer.getNormalizedData(); // Data should be normalized because DataSourceProvider subscribes automatically
|
|
309
|
-
expect(normalized.objects['@@1']).toBeDefined();
|
|
310
|
-
case 7:
|
|
311
|
-
case "end":
|
|
312
|
-
return _context12.stop();
|
|
313
|
-
}
|
|
314
|
-
}, _callee12);
|
|
315
|
-
})));
|
|
316
|
-
it('should work with multiple queries', /*#__PURE__*/_asyncToGenerator(/*#__PURE__*/_regeneratorRuntime().mark(function _callee15() {
|
|
317
|
-
var wrapper, dataSource1, dataSource2, _renderHook2, result1, _renderHook3, result2, normalized;
|
|
318
|
-
return _regeneratorRuntime().wrap(function _callee15$(_context15) {
|
|
319
|
-
while (1) switch (_context15.prev = _context15.next) {
|
|
320
|
-
case 0:
|
|
321
|
-
wrapper = function wrapper(_ref10) {
|
|
322
|
-
var children = _ref10.children;
|
|
323
|
-
return /*#__PURE__*/_jsx(DataSourceProvider, {
|
|
324
|
-
dataManager: dataManager,
|
|
325
|
-
children: children
|
|
326
|
-
});
|
|
327
|
-
};
|
|
328
|
-
dataSource1 = makePlainQueryDataSource({
|
|
329
|
-
name: 'users',
|
|
330
|
-
fetch: function () {
|
|
331
|
-
var _fetch2 = _asyncToGenerator(/*#__PURE__*/_regeneratorRuntime().mark(function _callee13() {
|
|
332
|
-
return _regeneratorRuntime().wrap(function _callee13$(_context13) {
|
|
333
|
-
while (1) switch (_context13.prev = _context13.next) {
|
|
334
|
-
case 0:
|
|
335
|
-
return _context13.abrupt("return", [{
|
|
336
|
-
id: '1',
|
|
337
|
-
name: 'User 1'
|
|
338
|
-
}]);
|
|
339
|
-
case 1:
|
|
340
|
-
case "end":
|
|
341
|
-
return _context13.stop();
|
|
342
|
-
}
|
|
343
|
-
}, _callee13);
|
|
344
|
-
}));
|
|
345
|
-
function fetch() {
|
|
346
|
-
return _fetch2.apply(this, arguments);
|
|
347
|
-
}
|
|
348
|
-
return fetch;
|
|
349
|
-
}(),
|
|
350
|
-
options: {
|
|
351
|
-
normalize: true
|
|
352
|
-
}
|
|
353
|
-
});
|
|
354
|
-
dataSource2 = makePlainQueryDataSource({
|
|
355
|
-
name: 'posts',
|
|
356
|
-
fetch: function () {
|
|
357
|
-
var _fetch3 = _asyncToGenerator(/*#__PURE__*/_regeneratorRuntime().mark(function _callee14() {
|
|
358
|
-
return _regeneratorRuntime().wrap(function _callee14$(_context14) {
|
|
359
|
-
while (1) switch (_context14.prev = _context14.next) {
|
|
360
|
-
case 0:
|
|
361
|
-
return _context14.abrupt("return", [{
|
|
362
|
-
id: '2',
|
|
363
|
-
title: 'Post 1'
|
|
364
|
-
}]);
|
|
365
|
-
case 1:
|
|
366
|
-
case "end":
|
|
367
|
-
return _context14.stop();
|
|
368
|
-
}
|
|
369
|
-
}, _callee14);
|
|
370
|
-
}));
|
|
371
|
-
function fetch() {
|
|
372
|
-
return _fetch3.apply(this, arguments);
|
|
373
|
-
}
|
|
374
|
-
return fetch;
|
|
375
|
-
}(),
|
|
376
|
-
options: {
|
|
377
|
-
normalize: true
|
|
378
|
-
}
|
|
379
|
-
});
|
|
380
|
-
_renderHook2 = renderHook(function () {
|
|
381
|
-
return useQueryData(dataSource1, {});
|
|
382
|
-
}, {
|
|
383
|
-
wrapper: wrapper
|
|
384
|
-
}), result1 = _renderHook2.result;
|
|
385
|
-
_renderHook3 = renderHook(function () {
|
|
386
|
-
return useQueryData(dataSource2, {});
|
|
387
|
-
}, {
|
|
388
|
-
wrapper: wrapper
|
|
389
|
-
}), result2 = _renderHook3.result;
|
|
390
|
-
_context15.next = 7;
|
|
391
|
-
return waitFor(function () {
|
|
392
|
-
expect(result1.current.status).toBe('success');
|
|
393
|
-
expect(result2.current.status).toBe('success');
|
|
394
|
-
});
|
|
395
|
-
case 7:
|
|
396
|
-
normalized = dataManager.queryNormalizer.getNormalizedData();
|
|
397
|
-
expect(normalized.objects['@@1']).toBeDefined();
|
|
398
|
-
expect(normalized.objects['@@2']).toBeDefined();
|
|
399
|
-
case 10:
|
|
400
|
-
case "end":
|
|
401
|
-
return _context15.stop();
|
|
402
|
-
}
|
|
403
|
-
}, _callee15);
|
|
404
|
-
})));
|
|
405
|
-
});
|
|
406
|
-
describe('Optimistic updates configuration', function () {
|
|
407
|
-
it('should enable optimistic updates when configured', /*#__PURE__*/_asyncToGenerator(/*#__PURE__*/_regeneratorRuntime().mark(function _callee16() {
|
|
408
|
-
var dmWithOptimistic, queryKey, initialData, data;
|
|
409
|
-
return _regeneratorRuntime().wrap(function _callee16$(_context16) {
|
|
410
|
-
while (1) switch (_context16.prev = _context16.next) {
|
|
411
|
-
case 0:
|
|
412
|
-
dmWithOptimistic = new ClientDataManager({
|
|
413
|
-
normalizerConfig: {
|
|
414
|
-
devLogging: false,
|
|
415
|
-
optimistic: true
|
|
416
|
-
}
|
|
417
|
-
});
|
|
418
|
-
expect(dmWithOptimistic.queryNormalizer).toBeDefined();
|
|
419
|
-
dmWithOptimistic.queryNormalizer.subscribe();
|
|
420
|
-
queryKey = ['users'];
|
|
421
|
-
initialData = [{
|
|
422
|
-
id: '1',
|
|
423
|
-
name: 'Old'
|
|
424
|
-
}];
|
|
425
|
-
dmWithOptimistic.queryClient.setQueryData(queryKey, initialData);
|
|
426
|
-
dmWithOptimistic.normalizer.setQuery(JSON.stringify(queryKey), initialData);
|
|
427
|
-
|
|
428
|
-
// Manual optimistic update via setNormalizedData
|
|
429
|
-
dmWithOptimistic.queryNormalizer.setNormalizedData({
|
|
430
|
-
id: '1',
|
|
431
|
-
name: 'New'
|
|
432
|
-
});
|
|
433
|
-
data = dmWithOptimistic.queryClient.getQueryData(queryKey);
|
|
434
|
-
expect(data[0].name).toBe('New');
|
|
435
|
-
dmWithOptimistic.queryNormalizer.unsubscribe();
|
|
436
|
-
dmWithOptimistic.queryClient.clear();
|
|
437
|
-
case 12:
|
|
438
|
-
case "end":
|
|
439
|
-
return _context16.stop();
|
|
440
|
-
}
|
|
441
|
-
}, _callee16);
|
|
442
|
-
})));
|
|
443
|
-
it('should work with optimistic config object', /*#__PURE__*/_asyncToGenerator(/*#__PURE__*/_regeneratorRuntime().mark(function _callee17() {
|
|
444
|
-
var dmWithOptimisticConfig;
|
|
445
|
-
return _regeneratorRuntime().wrap(function _callee17$(_context17) {
|
|
446
|
-
while (1) switch (_context17.prev = _context17.next) {
|
|
447
|
-
case 0:
|
|
448
|
-
dmWithOptimisticConfig = new ClientDataManager({
|
|
449
|
-
normalizerConfig: {
|
|
450
|
-
devLogging: false,
|
|
451
|
-
optimistic: {
|
|
452
|
-
autoCalculateRollback: true,
|
|
453
|
-
devLogging: false
|
|
454
|
-
}
|
|
455
|
-
}
|
|
456
|
-
});
|
|
457
|
-
expect(dmWithOptimisticConfig.queryNormalizer).toBeDefined();
|
|
458
|
-
expect(dmWithOptimisticConfig.normalizer).toBeDefined();
|
|
459
|
-
dmWithOptimisticConfig.queryClient.clear();
|
|
460
|
-
case 4:
|
|
461
|
-
case "end":
|
|
462
|
-
return _context17.stop();
|
|
463
|
-
}
|
|
464
|
-
}, _callee17);
|
|
465
|
-
})));
|
|
466
|
-
});
|
|
467
|
-
describe('Invalidate configuration', function () {
|
|
468
|
-
it('should support invalidate option in global config', /*#__PURE__*/_asyncToGenerator(/*#__PURE__*/_regeneratorRuntime().mark(function _callee18() {
|
|
469
|
-
var dmWithInvalidate;
|
|
470
|
-
return _regeneratorRuntime().wrap(function _callee18$(_context18) {
|
|
471
|
-
while (1) switch (_context18.prev = _context18.next) {
|
|
472
|
-
case 0:
|
|
473
|
-
dmWithInvalidate = new ClientDataManager({
|
|
474
|
-
normalizerConfig: {
|
|
475
|
-
devLogging: false,
|
|
476
|
-
invalidate: true
|
|
477
|
-
}
|
|
478
|
-
});
|
|
479
|
-
expect(dmWithInvalidate.queryNormalizer).toBeDefined();
|
|
480
|
-
expect(dmWithInvalidate.normalizer).toBeDefined();
|
|
481
|
-
dmWithInvalidate.queryClient.clear();
|
|
482
|
-
case 4:
|
|
483
|
-
case "end":
|
|
484
|
-
return _context18.stop();
|
|
485
|
-
}
|
|
486
|
-
}, _callee18);
|
|
487
|
-
})));
|
|
488
|
-
it('should support both optimistic and invalidate options', /*#__PURE__*/_asyncToGenerator(/*#__PURE__*/_regeneratorRuntime().mark(function _callee19() {
|
|
489
|
-
var dmWithBoth;
|
|
490
|
-
return _regeneratorRuntime().wrap(function _callee19$(_context19) {
|
|
491
|
-
while (1) switch (_context19.prev = _context19.next) {
|
|
492
|
-
case 0:
|
|
493
|
-
dmWithBoth = new ClientDataManager({
|
|
494
|
-
normalizerConfig: {
|
|
495
|
-
devLogging: false,
|
|
496
|
-
optimistic: true,
|
|
497
|
-
invalidate: true
|
|
498
|
-
}
|
|
499
|
-
});
|
|
500
|
-
expect(dmWithBoth.queryNormalizer).toBeDefined();
|
|
501
|
-
expect(dmWithBoth.normalizer).toBeDefined();
|
|
502
|
-
dmWithBoth.queryClient.clear();
|
|
503
|
-
case 4:
|
|
504
|
-
case "end":
|
|
505
|
-
return _context19.stop();
|
|
506
|
-
}
|
|
507
|
-
}, _callee19);
|
|
508
|
-
})));
|
|
509
|
-
});
|
|
510
|
-
describe('ClientDataManager.update()', function () {
|
|
511
|
-
it('should work with array of objects for optimistic update', /*#__PURE__*/_asyncToGenerator(/*#__PURE__*/_regeneratorRuntime().mark(function _callee20() {
|
|
512
|
-
var dm, queryKey, initialData, data;
|
|
513
|
-
return _regeneratorRuntime().wrap(function _callee20$(_context20) {
|
|
514
|
-
while (1) switch (_context20.prev = _context20.next) {
|
|
515
|
-
case 0:
|
|
516
|
-
dm = new ClientDataManager({
|
|
517
|
-
normalizerConfig: {
|
|
518
|
-
devLogging: false,
|
|
519
|
-
optimistic: true
|
|
520
|
-
}
|
|
521
|
-
});
|
|
522
|
-
dm.queryNormalizer.subscribe();
|
|
523
|
-
queryKey = ['users'];
|
|
524
|
-
initialData = [{
|
|
525
|
-
id: '1',
|
|
526
|
-
name: 'User 1'
|
|
527
|
-
}, {
|
|
528
|
-
id: '2',
|
|
529
|
-
name: 'User 2'
|
|
530
|
-
}];
|
|
531
|
-
dm.queryClient.setQueryData(queryKey, initialData);
|
|
532
|
-
dm.normalizer.setQuery(JSON.stringify(queryKey), initialData);
|
|
533
|
-
|
|
534
|
-
// Update both objects
|
|
535
|
-
dm.update([{
|
|
536
|
-
id: '1',
|
|
537
|
-
name: 'Updated 1'
|
|
538
|
-
}, {
|
|
539
|
-
id: '2',
|
|
540
|
-
name: 'Updated 2'
|
|
541
|
-
}]);
|
|
542
|
-
data = dm.queryClient.getQueryData(queryKey);
|
|
543
|
-
expect(data[0].name).toBe('Updated 1');
|
|
544
|
-
expect(data[1].name).toBe('Updated 2');
|
|
545
|
-
dm.queryNormalizer.unsubscribe();
|
|
546
|
-
dm.queryClient.clear();
|
|
547
|
-
case 12:
|
|
548
|
-
case "end":
|
|
549
|
-
return _context20.stop();
|
|
550
|
-
}
|
|
551
|
-
}, _callee20);
|
|
552
|
-
})));
|
|
553
|
-
it('should call invalidateData when invalidate option is enabled', /*#__PURE__*/_asyncToGenerator(/*#__PURE__*/_regeneratorRuntime().mark(function _callee21() {
|
|
554
|
-
var dm, queryKey, initialData, cache, invalidateSpy;
|
|
555
|
-
return _regeneratorRuntime().wrap(function _callee21$(_context21) {
|
|
556
|
-
while (1) switch (_context21.prev = _context21.next) {
|
|
557
|
-
case 0:
|
|
558
|
-
dm = new ClientDataManager({
|
|
559
|
-
normalizerConfig: {
|
|
560
|
-
devLogging: false,
|
|
561
|
-
invalidate: true
|
|
562
|
-
}
|
|
563
|
-
});
|
|
564
|
-
dm.queryNormalizer.subscribe();
|
|
565
|
-
queryKey = ['users'];
|
|
566
|
-
initialData = [{
|
|
567
|
-
id: '1',
|
|
568
|
-
name: 'User 1'
|
|
569
|
-
}];
|
|
570
|
-
dm.queryClient.setQueryData(queryKey, initialData);
|
|
571
|
-
dm.normalizer.setQuery(JSON.stringify(queryKey), initialData);
|
|
572
|
-
|
|
573
|
-
// Set query state to success so it can be invalidated
|
|
574
|
-
cache = dm.queryClient.getQueryCache().find({
|
|
575
|
-
queryKey: queryKey
|
|
576
|
-
});
|
|
577
|
-
cache === null || cache === void 0 || cache.setState({
|
|
578
|
-
status: 'success',
|
|
579
|
-
fetchStatus: 'idle',
|
|
580
|
-
isInvalidated: false
|
|
581
|
-
});
|
|
582
|
-
invalidateSpy = jest.spyOn(dm, 'invalidateData');
|
|
583
|
-
dm.update({
|
|
584
|
-
id: '1',
|
|
585
|
-
name: 'Updated'
|
|
586
|
-
});
|
|
587
|
-
expect(invalidateSpy).toHaveBeenCalled();
|
|
588
|
-
invalidateSpy.mockRestore();
|
|
589
|
-
dm.queryNormalizer.unsubscribe();
|
|
590
|
-
dm.queryClient.clear();
|
|
591
|
-
case 14:
|
|
592
|
-
case "end":
|
|
593
|
-
return _context21.stop();
|
|
594
|
-
}
|
|
595
|
-
}, _callee21);
|
|
596
|
-
})));
|
|
597
|
-
it('should trigger refetch when mutation has fewer keys and normy returns empty queriesToUpdate', /*#__PURE__*/_asyncToGenerator(/*#__PURE__*/_regeneratorRuntime().mark(function _callee22() {
|
|
598
|
-
var dm, queryKey, initialData, cache, originalGetQueriesToUpdate, invalidateSpy;
|
|
599
|
-
return _regeneratorRuntime().wrap(function _callee22$(_context22) {
|
|
600
|
-
while (1) switch (_context22.prev = _context22.next) {
|
|
601
|
-
case 0:
|
|
602
|
-
// checkMutationObjectsKeys is called only when getQueriesToUpdate returns []
|
|
603
|
-
// This happens when normy can't compute a diff (e.g., structure mismatch)
|
|
604
|
-
dm = new ClientDataManager({
|
|
605
|
-
normalizerConfig: {
|
|
606
|
-
devLogging: false,
|
|
607
|
-
invalidate: true // Need to enable invalidate for refetch to work
|
|
608
|
-
}
|
|
609
|
-
});
|
|
610
|
-
dm.queryNormalizer.subscribe();
|
|
611
|
-
queryKey = ['users']; // Store data with more keys
|
|
612
|
-
initialData = [{
|
|
613
|
-
id: '1',
|
|
614
|
-
name: 'User 1',
|
|
615
|
-
email: 'user@test.com',
|
|
616
|
-
age: 25
|
|
617
|
-
}];
|
|
618
|
-
dm.queryClient.setQueryData(queryKey, initialData);
|
|
619
|
-
dm.normalizer.setQuery(JSON.stringify(queryKey), initialData);
|
|
620
|
-
|
|
621
|
-
// Set query state to success so it can be invalidated
|
|
622
|
-
cache = dm.queryClient.getQueryCache().find({
|
|
623
|
-
queryKey: queryKey
|
|
624
|
-
});
|
|
625
|
-
cache === null || cache === void 0 || cache.setState({
|
|
626
|
-
status: 'success',
|
|
627
|
-
fetchStatus: 'idle',
|
|
628
|
-
isInvalidated: false
|
|
629
|
-
});
|
|
630
|
-
|
|
631
|
-
// Mock getQueriesToUpdate to return empty array (simulating normy can't compute diff)
|
|
632
|
-
originalGetQueriesToUpdate = dm.normalizer.getQueriesToUpdate;
|
|
633
|
-
dm.normalizer.getQueriesToUpdate = jest.fn().mockReturnValue([]);
|
|
634
|
-
invalidateSpy = jest.spyOn(dm.queryClient, 'invalidateQueries'); // Update with fewer keys - should trigger refetch via checkMutationObjectsKeys
|
|
635
|
-
dm.update({
|
|
636
|
-
id: '1',
|
|
637
|
-
name: 'Updated'
|
|
638
|
-
});
|
|
639
|
-
|
|
640
|
-
// Check if invalidation was triggered due to fewer keys
|
|
641
|
-
expect(invalidateSpy).toHaveBeenCalled();
|
|
642
|
-
|
|
643
|
-
// Restore mocks
|
|
644
|
-
dm.normalizer.getQueriesToUpdate = originalGetQueriesToUpdate;
|
|
645
|
-
invalidateSpy.mockRestore();
|
|
646
|
-
dm.queryNormalizer.unsubscribe();
|
|
647
|
-
dm.queryClient.clear();
|
|
648
|
-
case 17:
|
|
649
|
-
case "end":
|
|
650
|
-
return _context22.stop();
|
|
651
|
-
}
|
|
652
|
-
}, _callee22);
|
|
653
|
-
})));
|
|
654
|
-
});
|
|
655
|
-
});
|
|
656
|
-
// #sourceMappingURL=threeLevelIntegration.test.js.map
|