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