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