@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.
Files changed (232) hide show
  1. package/build/cjs/core/types/DataSource.d.ts +8 -8
  2. package/build/cjs/core/types/DataSource.js.map +1 -1
  3. package/build/cjs/react/components/AsyncBoundary/AsyncBoundary.d.ts +3 -0
  4. package/build/cjs/react/components/AsyncBoundary/AsyncBoundary.js +35 -0
  5. package/build/cjs/react/components/AsyncBoundary/AsyncBoundary.js.map +1 -0
  6. package/build/cjs/react/components/AsyncBoundary/index.d.ts +3 -0
  7. package/build/cjs/react/components/AsyncBoundary/index.js +20 -0
  8. package/build/cjs/react/components/AsyncBoundary/index.js.map +1 -0
  9. package/build/cjs/react/components/AsyncBoundary/types.d.ts +13 -0
  10. package/build/cjs/react/components/AsyncBoundary/types.js +6 -0
  11. package/build/cjs/react/components/AsyncBoundary/types.js.map +1 -0
  12. package/build/cjs/react/components/AsyncBoundary/withAsyncBoundary.d.ts +3 -0
  13. package/build/cjs/react/components/AsyncBoundary/withAsyncBoundary.js +26 -0
  14. package/build/cjs/react/components/AsyncBoundary/withAsyncBoundary.js.map +1 -0
  15. package/build/cjs/react/components/EmptyView/EmptyView.d.ts +2 -0
  16. package/build/cjs/react/components/EmptyView/EmptyView.js +10 -0
  17. package/build/cjs/react/components/EmptyView/EmptyView.js.map +1 -0
  18. package/build/cjs/react/components/EmptyView/index.d.ts +1 -0
  19. package/build/cjs/react/components/EmptyView/index.js +13 -0
  20. package/build/cjs/react/components/EmptyView/index.js.map +1 -0
  21. package/build/cjs/react/components/types.d.ts +1 -1
  22. package/build/cjs/react/components/types.js.map +1 -1
  23. package/build/cjs/react/index.d.ts +5 -3
  24. package/build/cjs/react/index.js +27 -3
  25. package/build/cjs/react/index.js.map +1 -1
  26. package/build/cjs/react-query/components/QueryAsyncBoundary/QueryAsyncBoundary.d.ts +3 -0
  27. package/build/cjs/react-query/components/QueryAsyncBoundary/QueryAsyncBoundary.js +23 -0
  28. package/build/cjs/react-query/components/QueryAsyncBoundary/QueryAsyncBoundary.js.map +1 -0
  29. package/build/cjs/react-query/components/QueryAsyncBoundary/index.d.ts +3 -0
  30. package/build/cjs/react-query/components/QueryAsyncBoundary/index.js +20 -0
  31. package/build/cjs/react-query/components/QueryAsyncBoundary/index.js.map +1 -0
  32. package/build/cjs/react-query/components/QueryAsyncBoundary/types.d.ts +8 -0
  33. package/build/cjs/react-query/components/QueryAsyncBoundary/types.js +6 -0
  34. package/build/cjs/react-query/components/QueryAsyncBoundary/types.js.map +1 -0
  35. package/build/cjs/react-query/components/QueryAsyncBoundary/withQueryAsyncBoundary.d.ts +3 -0
  36. package/build/cjs/react-query/components/QueryAsyncBoundary/withQueryAsyncBoundary.js +26 -0
  37. package/build/cjs/react-query/components/QueryAsyncBoundary/withQueryAsyncBoundary.js.map +1 -0
  38. package/build/cjs/react-query/hooks/useSuspenseQueryData.d.ts +9 -0
  39. package/build/cjs/react-query/hooks/useSuspenseQueryData.js +22 -0
  40. package/build/cjs/react-query/hooks/useSuspenseQueryData.js.map +1 -0
  41. package/build/cjs/react-query/index.d.ts +2 -0
  42. package/build/cjs/react-query/index.js +35 -0
  43. package/build/cjs/react-query/index.js.map +1 -1
  44. package/build/esm/core/types/DataSource.d.ts +8 -8
  45. package/build/esm/core/types/DataSource.js.map +1 -1
  46. package/build/esm/react/components/AsyncBoundary/AsyncBoundary.d.ts +3 -0
  47. package/build/esm/react/components/AsyncBoundary/AsyncBoundary.js +28 -0
  48. package/build/esm/react/components/AsyncBoundary/AsyncBoundary.js.map +1 -0
  49. package/build/esm/react/components/AsyncBoundary/index.d.ts +3 -0
  50. package/build/esm/react/components/AsyncBoundary/index.js +3 -0
  51. package/build/esm/react/components/AsyncBoundary/index.js.map +1 -0
  52. package/build/esm/react/components/AsyncBoundary/types.d.ts +13 -0
  53. package/build/esm/react/components/AsyncBoundary/types.js +2 -0
  54. package/build/esm/react/components/AsyncBoundary/types.js.map +1 -0
  55. package/build/esm/react/components/AsyncBoundary/withAsyncBoundary.d.ts +3 -0
  56. package/build/esm/react/components/AsyncBoundary/withAsyncBoundary.js +19 -0
  57. package/build/esm/react/components/AsyncBoundary/withAsyncBoundary.js.map +1 -0
  58. package/build/esm/react/components/EmptyView/EmptyView.d.ts +2 -0
  59. package/build/esm/react/components/EmptyView/EmptyView.js +4 -0
  60. package/build/esm/react/components/EmptyView/EmptyView.js.map +1 -0
  61. package/build/esm/react/components/EmptyView/index.d.ts +1 -0
  62. package/build/esm/react/components/EmptyView/index.js +2 -0
  63. package/build/esm/react/components/EmptyView/index.js.map +1 -0
  64. package/build/esm/react/components/types.d.ts +1 -1
  65. package/build/esm/react/components/types.js.map +1 -1
  66. package/build/esm/react/index.d.ts +5 -3
  67. package/build/esm/react/index.js +4 -2
  68. package/build/esm/react/index.js.map +1 -1
  69. package/build/esm/react-query/components/QueryAsyncBoundary/QueryAsyncBoundary.d.ts +3 -0
  70. package/build/esm/react-query/components/QueryAsyncBoundary/QueryAsyncBoundary.js +16 -0
  71. package/build/esm/react-query/components/QueryAsyncBoundary/QueryAsyncBoundary.js.map +1 -0
  72. package/build/esm/react-query/components/QueryAsyncBoundary/index.d.ts +3 -0
  73. package/build/esm/react-query/components/QueryAsyncBoundary/index.js +3 -0
  74. package/build/esm/react-query/components/QueryAsyncBoundary/index.js.map +1 -0
  75. package/build/esm/react-query/components/QueryAsyncBoundary/types.d.ts +8 -0
  76. package/build/esm/react-query/components/QueryAsyncBoundary/types.js +2 -0
  77. package/build/esm/react-query/components/QueryAsyncBoundary/types.js.map +1 -0
  78. package/build/esm/react-query/components/QueryAsyncBoundary/withQueryAsyncBoundary.d.ts +3 -0
  79. package/build/esm/react-query/components/QueryAsyncBoundary/withQueryAsyncBoundary.js +19 -0
  80. package/build/esm/react-query/components/QueryAsyncBoundary/withQueryAsyncBoundary.js.map +1 -0
  81. package/build/esm/react-query/hooks/useSuspenseQueryData.d.ts +9 -0
  82. package/build/esm/react-query/hooks/useSuspenseQueryData.js +15 -0
  83. package/build/esm/react-query/hooks/useSuspenseQueryData.js.map +1 -0
  84. package/build/esm/react-query/index.d.ts +2 -0
  85. package/build/esm/react-query/index.js +2 -0
  86. package/build/esm/react-query/index.js.map +1 -1
  87. package/build/plugin/esbuild.d.mts +7 -0
  88. package/build/plugin/esbuild.mjs +6 -0
  89. package/build/plugin/factory-2tSt4Rte.mjs +513 -0
  90. package/build/plugin/index-mY40Sgl5.d.mts +24 -0
  91. package/build/plugin/index.d.mts +7 -0
  92. package/build/plugin/index.mjs +6 -0
  93. package/build/plugin/rollup.d.mts +6 -0
  94. package/build/plugin/rollup.mjs +6 -0
  95. package/build/plugin/rspack.d.mts +7 -0
  96. package/build/plugin/rspack.mjs +6 -0
  97. package/build/plugin/typings/client.d.ts +11 -0
  98. package/build/plugin/vite.d.mts +6 -0
  99. package/build/plugin/vite.mjs +6 -0
  100. package/build/plugin/webpack.d.mts +7 -0
  101. package/build/plugin/webpack.mjs +6 -0
  102. package/package.json +54 -5
  103. package/build/cjs/core/utils/__tests__/composeFullKey.test.js +0 -34
  104. package/build/cjs/core/utils/__tests__/composeFullKey.test.js.map +0 -1
  105. package/build/cjs/core/utils/__tests__/composeKey.test.js +0 -32
  106. package/build/cjs/core/utils/__tests__/composeKey.test.js.map +0 -1
  107. package/build/cjs/core/utils/__tests__/getError.test.js +0 -31
  108. package/build/cjs/core/utils/__tests__/getError.test.js.map +0 -1
  109. package/build/cjs/core/utils/__tests__/getStatus.test.js +0 -49
  110. package/build/cjs/core/utils/__tests__/getStatus.test.js.map +0 -1
  111. package/build/cjs/core/utils/__tests__/hasTag.test.js +0 -31
  112. package/build/cjs/core/utils/__tests__/hasTag.test.js.map +0 -1
  113. package/build/cjs/core/utils/__tests__/mergeStatuses.test.js +0 -25
  114. package/build/cjs/core/utils/__tests__/mergeStatuses.test.js.map +0 -1
  115. package/build/cjs/core/utils/__tests__/skipContext.test.js +0 -70
  116. package/build/cjs/core/utils/__tests__/skipContext.test.js.map +0 -1
  117. package/build/cjs/core/utils/__tests__/withCancellation.test.js +0 -106
  118. package/build/cjs/core/utils/__tests__/withCancellation.test.js.map +0 -1
  119. package/build/cjs/core/utils/__tests__/withCatch.test.js +0 -208
  120. package/build/cjs/core/utils/__tests__/withCatch.test.js.map +0 -1
  121. package/build/cjs/react/__tests__/DataManagerContext.test.js +0 -47
  122. package/build/cjs/react/__tests__/DataManagerContext.test.js.map +0 -1
  123. package/build/cjs/react/__tests__/withDataManager.test.js +0 -61
  124. package/build/cjs/react/__tests__/withDataManager.test.js.map +0 -1
  125. package/build/cjs/react/components/DataInfiniteLoader/__tests__/DataInfiniteLoader.test.js +0 -187
  126. package/build/cjs/react/components/DataInfiniteLoader/__tests__/DataInfiniteLoader.test.js.map +0 -1
  127. package/build/cjs/react/components/DataLoader/__tests__/DataLoader.test.js +0 -119
  128. package/build/cjs/react/components/DataLoader/__tests__/DataLoader.test.js.map +0 -1
  129. package/build/cjs/react-query/__tests__/createQueryNormalizer.test.js +0 -177
  130. package/build/cjs/react-query/__tests__/createQueryNormalizer.test.js.map +0 -1
  131. package/build/cjs/react-query/__tests__/normalizationEdgeCases.test.js +0 -100
  132. package/build/cjs/react-query/__tests__/normalizationEdgeCases.test.js.map +0 -1
  133. package/build/cjs/react-query/__tests__/subscriptions.test.js +0 -1180
  134. package/build/cjs/react-query/__tests__/subscriptions.test.js.map +0 -1
  135. package/build/cjs/react-query/__tests__/threeLevelIntegration.test.js +0 -659
  136. package/build/cjs/react-query/__tests__/threeLevelIntegration.test.js.map +0 -1
  137. package/build/cjs/react-query/__tests__/updateQueriesFromMutationData.test.js +0 -229
  138. package/build/cjs/react-query/__tests__/updateQueriesFromMutationData.test.js.map +0 -1
  139. package/build/cjs/react-query/hooks/__tests__/useQueryContext.test.js +0 -55
  140. package/build/cjs/react-query/hooks/__tests__/useQueryContext.test.js.map +0 -1
  141. package/build/cjs/react-query/hooks/__tests__/useQueryData.refetch.test.js +0 -230
  142. package/build/cjs/react-query/hooks/__tests__/useQueryData.refetch.test.js.map +0 -1
  143. package/build/cjs/react-query/hooks/__tests__/useQueryData.test.js +0 -97
  144. package/build/cjs/react-query/hooks/__tests__/useQueryData.test.js.map +0 -1
  145. package/build/cjs/react-query/hooks/__tests__/useQueryResponses.test.js +0 -77
  146. package/build/cjs/react-query/hooks/__tests__/useQueryResponses.test.js.map +0 -1
  147. package/build/cjs/react-query/hooks/__tests__/useRefetchAll.test.js +0 -79
  148. package/build/cjs/react-query/hooks/__tests__/useRefetchAll.test.js.map +0 -1
  149. package/build/cjs/react-query/hooks/__tests__/useRefetchErrored.test.js +0 -117
  150. package/build/cjs/react-query/hooks/__tests__/useRefetchErrored.test.js.map +0 -1
  151. package/build/cjs/react-query/hooks/__tests__/useRefetchInterval.test.js +0 -156
  152. package/build/cjs/react-query/hooks/__tests__/useRefetchInterval.test.js.map +0 -1
  153. package/build/cjs/react-query/utils/__tests__/checkMutationObjectsKeys.test.js +0 -295
  154. package/build/cjs/react-query/utils/__tests__/checkMutationObjectsKeys.test.js.map +0 -1
  155. package/build/cjs/react-query/utils/__tests__/formatNullableValue.test.js +0 -27
  156. package/build/cjs/react-query/utils/__tests__/formatNullableValue.test.js.map +0 -1
  157. package/build/cjs/react-query/utils/__tests__/getProgressiveRefetch.test.js +0 -76
  158. package/build/cjs/react-query/utils/__tests__/getProgressiveRefetch.test.js.map +0 -1
  159. package/build/cjs/react-query/utils/__tests__/normalizeStatus.test.js +0 -30
  160. package/build/cjs/react-query/utils/__tests__/normalizeStatus.test.js.map +0 -1
  161. package/build/cjs/react-query/utils/__tests__/notReachable.test.js +0 -35
  162. package/build/cjs/react-query/utils/__tests__/notReachable.test.js.map +0 -1
  163. package/build/cjs/react-query/utils/__tests__/parseNullableValue.test.js +0 -27
  164. package/build/cjs/react-query/utils/__tests__/parseNullableValue.test.js.map +0 -1
  165. package/build/cjs/setupTests.d.ts +0 -1
  166. package/build/cjs/setupTests.js +0 -4
  167. package/build/cjs/setupTests.js.map +0 -1
  168. package/build/esm/core/utils/__tests__/composeFullKey.test.js +0 -32
  169. package/build/esm/core/utils/__tests__/composeFullKey.test.js.map +0 -1
  170. package/build/esm/core/utils/__tests__/composeKey.test.js +0 -30
  171. package/build/esm/core/utils/__tests__/composeKey.test.js.map +0 -1
  172. package/build/esm/core/utils/__tests__/getError.test.js +0 -29
  173. package/build/esm/core/utils/__tests__/getError.test.js.map +0 -1
  174. package/build/esm/core/utils/__tests__/getStatus.test.js +0 -47
  175. package/build/esm/core/utils/__tests__/getStatus.test.js.map +0 -1
  176. package/build/esm/core/utils/__tests__/hasTag.test.js +0 -29
  177. package/build/esm/core/utils/__tests__/hasTag.test.js.map +0 -1
  178. package/build/esm/core/utils/__tests__/mergeStatuses.test.js +0 -23
  179. package/build/esm/core/utils/__tests__/mergeStatuses.test.js.map +0 -1
  180. package/build/esm/core/utils/__tests__/skipContext.test.js +0 -67
  181. package/build/esm/core/utils/__tests__/skipContext.test.js.map +0 -1
  182. package/build/esm/core/utils/__tests__/withCancellation.test.js +0 -104
  183. package/build/esm/core/utils/__tests__/withCancellation.test.js.map +0 -1
  184. package/build/esm/core/utils/__tests__/withCatch.test.js +0 -205
  185. package/build/esm/core/utils/__tests__/withCatch.test.js.map +0 -1
  186. package/build/esm/react/__tests__/DataManagerContext.test.js +0 -44
  187. package/build/esm/react/__tests__/DataManagerContext.test.js.map +0 -1
  188. package/build/esm/react/__tests__/withDataManager.test.js +0 -58
  189. package/build/esm/react/__tests__/withDataManager.test.js.map +0 -1
  190. package/build/esm/react/components/DataInfiniteLoader/__tests__/DataInfiniteLoader.test.js +0 -184
  191. package/build/esm/react/components/DataInfiniteLoader/__tests__/DataInfiniteLoader.test.js.map +0 -1
  192. package/build/esm/react/components/DataLoader/__tests__/DataLoader.test.js +0 -116
  193. package/build/esm/react/components/DataLoader/__tests__/DataLoader.test.js.map +0 -1
  194. package/build/esm/react-query/__tests__/createQueryNormalizer.test.js +0 -174
  195. package/build/esm/react-query/__tests__/createQueryNormalizer.test.js.map +0 -1
  196. package/build/esm/react-query/__tests__/normalizationEdgeCases.test.js +0 -98
  197. package/build/esm/react-query/__tests__/normalizationEdgeCases.test.js.map +0 -1
  198. package/build/esm/react-query/__tests__/subscriptions.test.js +0 -1176
  199. package/build/esm/react-query/__tests__/subscriptions.test.js.map +0 -1
  200. package/build/esm/react-query/__tests__/threeLevelIntegration.test.js +0 -656
  201. package/build/esm/react-query/__tests__/threeLevelIntegration.test.js.map +0 -1
  202. package/build/esm/react-query/__tests__/updateQueriesFromMutationData.test.js +0 -227
  203. package/build/esm/react-query/__tests__/updateQueriesFromMutationData.test.js.map +0 -1
  204. package/build/esm/react-query/hooks/__tests__/useQueryContext.test.js +0 -52
  205. package/build/esm/react-query/hooks/__tests__/useQueryContext.test.js.map +0 -1
  206. package/build/esm/react-query/hooks/__tests__/useQueryData.refetch.test.js +0 -227
  207. package/build/esm/react-query/hooks/__tests__/useQueryData.refetch.test.js.map +0 -1
  208. package/build/esm/react-query/hooks/__tests__/useQueryData.test.js +0 -95
  209. package/build/esm/react-query/hooks/__tests__/useQueryData.test.js.map +0 -1
  210. package/build/esm/react-query/hooks/__tests__/useQueryResponses.test.js +0 -74
  211. package/build/esm/react-query/hooks/__tests__/useQueryResponses.test.js.map +0 -1
  212. package/build/esm/react-query/hooks/__tests__/useRefetchAll.test.js +0 -77
  213. package/build/esm/react-query/hooks/__tests__/useRefetchAll.test.js.map +0 -1
  214. package/build/esm/react-query/hooks/__tests__/useRefetchErrored.test.js +0 -115
  215. package/build/esm/react-query/hooks/__tests__/useRefetchErrored.test.js.map +0 -1
  216. package/build/esm/react-query/hooks/__tests__/useRefetchInterval.test.js +0 -154
  217. package/build/esm/react-query/hooks/__tests__/useRefetchInterval.test.js.map +0 -1
  218. package/build/esm/react-query/utils/__tests__/checkMutationObjectsKeys.test.js +0 -292
  219. package/build/esm/react-query/utils/__tests__/checkMutationObjectsKeys.test.js.map +0 -1
  220. package/build/esm/react-query/utils/__tests__/formatNullableValue.test.js +0 -25
  221. package/build/esm/react-query/utils/__tests__/formatNullableValue.test.js.map +0 -1
  222. package/build/esm/react-query/utils/__tests__/getProgressiveRefetch.test.js +0 -74
  223. package/build/esm/react-query/utils/__tests__/getProgressiveRefetch.test.js.map +0 -1
  224. package/build/esm/react-query/utils/__tests__/normalizeStatus.test.js +0 -28
  225. package/build/esm/react-query/utils/__tests__/normalizeStatus.test.js.map +0 -1
  226. package/build/esm/react-query/utils/__tests__/notReachable.test.js +0 -33
  227. package/build/esm/react-query/utils/__tests__/notReachable.test.js.map +0 -1
  228. package/build/esm/react-query/utils/__tests__/parseNullableValue.test.js +0 -25
  229. package/build/esm/react-query/utils/__tests__/parseNullableValue.test.js.map +0 -1
  230. package/build/esm/setupTests.d.ts +0 -1
  231. package/build/esm/setupTests.js +0 -2
  232. 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