@gravity-ui/data-source 0.6.0 → 0.7.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/build/cjs/core/index.d.ts +3 -2
- package/build/cjs/core/index.js +7 -0
- package/build/cjs/core/index.js.map +1 -1
- package/build/cjs/core/types/{DataManger.js → DataManager.js} +1 -1
- package/build/cjs/core/types/DataManager.js.map +1 -0
- package/build/cjs/core/types/DataSource.d.ts +15 -19
- package/build/cjs/core/types/DataSource.js.map +1 -1
- package/build/cjs/core/utils/__tests__/composeFullKey.test.js +34 -0
- package/build/cjs/core/utils/__tests__/composeFullKey.test.js.map +1 -0
- package/build/cjs/core/utils/__tests__/composeKey.test.js +32 -0
- package/build/cjs/core/utils/__tests__/composeKey.test.js.map +1 -0
- package/build/cjs/core/utils/__tests__/getError.test.js +31 -0
- package/build/cjs/core/utils/__tests__/getError.test.js.map +1 -0
- package/build/cjs/core/utils/__tests__/getStatus.test.js +49 -0
- package/build/cjs/core/utils/__tests__/getStatus.test.js.map +1 -0
- package/build/cjs/core/utils/__tests__/hasTag.test.js +31 -0
- package/build/cjs/core/utils/__tests__/hasTag.test.js.map +1 -0
- package/build/cjs/core/utils/__tests__/mergeStatuses.test.js +25 -0
- package/build/cjs/core/utils/__tests__/mergeStatuses.test.js.map +1 -0
- package/build/cjs/core/utils/__tests__/skipContext.test.js +70 -0
- package/build/cjs/core/utils/__tests__/skipContext.test.js.map +1 -0
- package/build/cjs/core/utils/__tests__/withCancellation.test.js +106 -0
- package/build/cjs/core/utils/__tests__/withCancellation.test.js.map +1 -0
- package/build/cjs/core/utils/__tests__/withCatch.test.js +208 -0
- package/build/cjs/core/utils/__tests__/withCatch.test.js.map +1 -0
- package/build/cjs/core/utils/hasTag.js +1 -1
- package/build/cjs/core/utils/hasTag.js.map +1 -1
- package/build/cjs/core/utils/withCatch.d.ts +26 -0
- package/build/cjs/core/utils/withCatch.js +37 -0
- package/build/cjs/core/utils/withCatch.js.map +1 -0
- package/build/cjs/react/DataManagerContext.js +1 -1
- package/build/cjs/react/DataManagerContext.js.map +1 -1
- package/build/cjs/react/__tests__/DataManagerContext.test.js +46 -0
- package/build/cjs/react/__tests__/DataManagerContext.test.js.map +1 -0
- package/build/cjs/react/__tests__/withDataManager.test.js +58 -0
- package/build/cjs/react/__tests__/withDataManager.test.js.map +1 -0
- package/build/cjs/react/components/DataInfiniteLoader/__tests__/DataInfiniteLoader.test.js +187 -0
- package/build/cjs/react/components/DataInfiniteLoader/__tests__/DataInfiniteLoader.test.js.map +1 -0
- package/build/cjs/react/components/DataLoader/__tests__/DataLoader.test.js +119 -0
- package/build/cjs/react/components/DataLoader/__tests__/DataLoader.test.js.map +1 -0
- package/build/cjs/react/withDataManager.d.ts +1 -1
- package/build/cjs/react/withDataManager.js +3 -3
- package/build/cjs/react/withDataManager.js.map +1 -1
- package/build/cjs/react-query/ClientDataManager.d.ts +1 -1
- package/build/cjs/react-query/ClientDataManager.js +6 -6
- package/build/cjs/react-query/ClientDataManager.js.map +1 -1
- package/build/cjs/react-query/constants.d.ts +2 -0
- package/build/cjs/react-query/constants.js +9 -0
- package/build/cjs/react-query/constants.js.map +1 -0
- package/build/cjs/react-query/hooks/__tests__/useQueryContext.test.js +55 -0
- package/build/cjs/react-query/hooks/__tests__/useQueryContext.test.js.map +1 -0
- package/build/cjs/react-query/hooks/__tests__/useQueryData.test.js +97 -0
- package/build/cjs/react-query/hooks/__tests__/useQueryData.test.js.map +1 -0
- package/build/cjs/react-query/hooks/__tests__/useQueryResponses.test.js +77 -0
- package/build/cjs/react-query/hooks/__tests__/useQueryResponses.test.js.map +1 -0
- package/build/cjs/react-query/hooks/__tests__/useRefetchAll.test.js +79 -0
- package/build/cjs/react-query/hooks/__tests__/useRefetchAll.test.js.map +1 -0
- package/build/cjs/react-query/hooks/__tests__/useRefetchErrored.test.js +117 -0
- package/build/cjs/react-query/hooks/__tests__/useRefetchErrored.test.js.map +1 -0
- package/build/cjs/react-query/hooks/__tests__/useRefetchInterval.test.js +156 -0
- package/build/cjs/react-query/hooks/__tests__/useRefetchInterval.test.js.map +1 -0
- package/build/cjs/react-query/hooks/useRefetchInterval.d.ts +1 -1
- package/build/cjs/react-query/impl/infinite/factory.d.ts +1 -1
- package/build/cjs/react-query/impl/infinite/factory.js.map +1 -1
- package/build/cjs/react-query/impl/infinite/types.d.ts +7 -7
- package/build/cjs/react-query/impl/infinite/types.js.map +1 -1
- package/build/cjs/react-query/impl/infinite/utils.js +11 -22
- package/build/cjs/react-query/impl/infinite/utils.js.map +1 -1
- package/build/cjs/react-query/impl/plain/factory.d.ts +1 -1
- package/build/cjs/react-query/impl/plain/factory.js.map +1 -1
- package/build/cjs/react-query/impl/plain/types.d.ts +4 -4
- package/build/cjs/react-query/impl/plain/types.js.map +1 -1
- package/build/cjs/react-query/impl/plain/utils.js +12 -23
- package/build/cjs/react-query/impl/plain/utils.js.map +1 -1
- package/build/cjs/react-query/utils/__tests__/formatNullableValue.test.js +27 -0
- package/build/cjs/react-query/utils/__tests__/formatNullableValue.test.js.map +1 -0
- package/build/cjs/react-query/utils/__tests__/getProgressiveRefetch.test.js +76 -0
- package/build/cjs/react-query/utils/__tests__/getProgressiveRefetch.test.js.map +1 -0
- package/build/cjs/react-query/utils/__tests__/normalizeStatus.test.js +30 -0
- package/build/cjs/react-query/utils/__tests__/normalizeStatus.test.js.map +1 -0
- package/build/cjs/react-query/utils/__tests__/notReachable.test.js +35 -0
- package/build/cjs/react-query/utils/__tests__/notReachable.test.js.map +1 -0
- package/build/cjs/react-query/utils/__tests__/parseNullableValue.test.js +27 -0
- package/build/cjs/react-query/utils/__tests__/parseNullableValue.test.js.map +1 -0
- package/build/cjs/react-query/utils/formatNullableValue.d.ts +2 -0
- package/build/cjs/react-query/utils/formatNullableValue.js +17 -0
- package/build/cjs/react-query/utils/formatNullableValue.js.map +1 -0
- package/build/cjs/react-query/utils/getProgressiveRefetch.d.ts +2 -2
- package/build/cjs/react-query/utils/parseNullableValue.d.ts +2 -0
- package/build/cjs/react-query/utils/parseNullableValue.js +17 -0
- package/build/cjs/react-query/utils/parseNullableValue.js.map +1 -0
- package/build/cjs/setupTests.d.ts +1 -0
- package/build/cjs/setupTests.js +4 -0
- package/build/cjs/setupTests.js.map +1 -0
- package/build/esm/core/index.d.ts +3 -2
- package/build/esm/core/index.js +1 -0
- package/build/esm/core/index.js.map +1 -1
- package/build/esm/core/types/DataManager.js +2 -0
- package/build/esm/core/types/DataManager.js.map +1 -0
- package/build/esm/core/types/DataSource.d.ts +15 -19
- package/build/esm/core/types/DataSource.js.map +1 -1
- package/build/esm/core/utils/__tests__/composeFullKey.test.js +32 -0
- package/build/esm/core/utils/__tests__/composeFullKey.test.js.map +1 -0
- package/build/esm/core/utils/__tests__/composeKey.test.js +30 -0
- package/build/esm/core/utils/__tests__/composeKey.test.js.map +1 -0
- package/build/esm/core/utils/__tests__/getError.test.js +29 -0
- package/build/esm/core/utils/__tests__/getError.test.js.map +1 -0
- package/build/esm/core/utils/__tests__/getStatus.test.js +47 -0
- package/build/esm/core/utils/__tests__/getStatus.test.js.map +1 -0
- package/build/esm/core/utils/__tests__/hasTag.test.js +29 -0
- package/build/esm/core/utils/__tests__/hasTag.test.js.map +1 -0
- package/build/esm/core/utils/__tests__/mergeStatuses.test.js +23 -0
- package/build/esm/core/utils/__tests__/mergeStatuses.test.js.map +1 -0
- package/build/esm/core/utils/__tests__/skipContext.test.js +67 -0
- package/build/esm/core/utils/__tests__/skipContext.test.js.map +1 -0
- package/build/esm/core/utils/__tests__/withCancellation.test.js +104 -0
- package/build/esm/core/utils/__tests__/withCancellation.test.js.map +1 -0
- package/build/esm/core/utils/__tests__/withCatch.test.js +205 -0
- package/build/esm/core/utils/__tests__/withCatch.test.js.map +1 -0
- package/build/esm/core/utils/hasTag.js +1 -1
- package/build/esm/core/utils/hasTag.js.map +1 -1
- package/build/esm/core/utils/withCatch.d.ts +26 -0
- package/build/esm/core/utils/withCatch.js +31 -0
- package/build/esm/core/utils/withCatch.js.map +1 -0
- package/build/esm/react/DataManagerContext.js +1 -1
- package/build/esm/react/DataManagerContext.js.map +1 -1
- package/build/esm/react/__tests__/DataManagerContext.test.js +43 -0
- package/build/esm/react/__tests__/DataManagerContext.test.js.map +1 -0
- package/build/esm/react/__tests__/withDataManager.test.js +55 -0
- package/build/esm/react/__tests__/withDataManager.test.js.map +1 -0
- package/build/esm/react/components/DataInfiniteLoader/__tests__/DataInfiniteLoader.test.js +184 -0
- package/build/esm/react/components/DataInfiniteLoader/__tests__/DataInfiniteLoader.test.js.map +1 -0
- package/build/esm/react/components/DataLoader/__tests__/DataLoader.test.js +116 -0
- package/build/esm/react/components/DataLoader/__tests__/DataLoader.test.js.map +1 -0
- package/build/esm/react/withDataManager.d.ts +1 -1
- package/build/esm/react/withDataManager.js +3 -3
- package/build/esm/react/withDataManager.js.map +1 -1
- package/build/esm/react-query/ClientDataManager.d.ts +1 -1
- package/build/esm/react-query/ClientDataManager.js +6 -6
- package/build/esm/react-query/ClientDataManager.js.map +1 -1
- package/build/esm/react-query/constants.d.ts +2 -0
- package/build/esm/react-query/constants.js +3 -0
- package/build/esm/react-query/constants.js.map +1 -0
- package/build/esm/react-query/hooks/__tests__/useQueryContext.test.js +52 -0
- package/build/esm/react-query/hooks/__tests__/useQueryContext.test.js.map +1 -0
- package/build/esm/react-query/hooks/__tests__/useQueryData.test.js +95 -0
- package/build/esm/react-query/hooks/__tests__/useQueryData.test.js.map +1 -0
- package/build/esm/react-query/hooks/__tests__/useQueryResponses.test.js +74 -0
- package/build/esm/react-query/hooks/__tests__/useQueryResponses.test.js.map +1 -0
- package/build/esm/react-query/hooks/__tests__/useRefetchAll.test.js +77 -0
- package/build/esm/react-query/hooks/__tests__/useRefetchAll.test.js.map +1 -0
- package/build/esm/react-query/hooks/__tests__/useRefetchErrored.test.js +115 -0
- package/build/esm/react-query/hooks/__tests__/useRefetchErrored.test.js.map +1 -0
- package/build/esm/react-query/hooks/__tests__/useRefetchInterval.test.js +154 -0
- package/build/esm/react-query/hooks/__tests__/useRefetchInterval.test.js.map +1 -0
- package/build/esm/react-query/hooks/useRefetchInterval.d.ts +1 -1
- package/build/esm/react-query/impl/infinite/factory.d.ts +1 -1
- package/build/esm/react-query/impl/infinite/factory.js.map +1 -1
- package/build/esm/react-query/impl/infinite/types.d.ts +7 -7
- package/build/esm/react-query/impl/infinite/types.js.map +1 -1
- package/build/esm/react-query/impl/infinite/utils.js +9 -20
- package/build/esm/react-query/impl/infinite/utils.js.map +1 -1
- package/build/esm/react-query/impl/plain/factory.d.ts +1 -1
- package/build/esm/react-query/impl/plain/factory.js.map +1 -1
- package/build/esm/react-query/impl/plain/types.d.ts +4 -4
- package/build/esm/react-query/impl/plain/types.js.map +1 -1
- package/build/esm/react-query/impl/plain/utils.js +10 -21
- package/build/esm/react-query/impl/plain/utils.js.map +1 -1
- package/build/esm/react-query/utils/__tests__/formatNullableValue.test.js +25 -0
- package/build/esm/react-query/utils/__tests__/formatNullableValue.test.js.map +1 -0
- package/build/esm/react-query/utils/__tests__/getProgressiveRefetch.test.js +74 -0
- package/build/esm/react-query/utils/__tests__/getProgressiveRefetch.test.js.map +1 -0
- package/build/esm/react-query/utils/__tests__/normalizeStatus.test.js +28 -0
- package/build/esm/react-query/utils/__tests__/normalizeStatus.test.js.map +1 -0
- package/build/esm/react-query/utils/__tests__/notReachable.test.js +33 -0
- package/build/esm/react-query/utils/__tests__/notReachable.test.js.map +1 -0
- package/build/esm/react-query/utils/__tests__/parseNullableValue.test.js +25 -0
- package/build/esm/react-query/utils/__tests__/parseNullableValue.test.js.map +1 -0
- package/build/esm/react-query/utils/formatNullableValue.d.ts +2 -0
- package/build/esm/react-query/utils/formatNullableValue.js +11 -0
- package/build/esm/react-query/utils/formatNullableValue.js.map +1 -0
- package/build/esm/react-query/utils/getProgressiveRefetch.d.ts +2 -2
- package/build/esm/react-query/utils/parseNullableValue.d.ts +2 -0
- package/build/esm/react-query/utils/parseNullableValue.js +11 -0
- package/build/esm/react-query/utils/parseNullableValue.js.map +1 -0
- package/build/esm/setupTests.d.ts +1 -0
- package/build/esm/setupTests.js +2 -0
- package/build/esm/setupTests.js.map +1 -0
- package/package.json +17 -13
- package/build/cjs/core/types/DataManger.js.map +0 -1
- package/build/cjs/react-query/impl/utils.d.ts +0 -4
- package/build/cjs/react-query/impl/utils.js +0 -27
- package/build/cjs/react-query/impl/utils.js.map +0 -1
- package/build/esm/core/types/DataManger.js +0 -2
- package/build/esm/core/types/DataManger.js.map +0 -1
- package/build/esm/react-query/impl/utils.d.ts +0 -4
- package/build/esm/react-query/impl/utils.js +0 -21
- package/build/esm/react-query/impl/utils.js.map +0 -1
- /package/build/cjs/core/types/{DataManger.d.ts → DataManager.d.ts} +0 -0
- /package/build/esm/core/types/{DataManger.d.ts → DataManager.d.ts} +0 -0
|
@@ -0,0 +1,205 @@
|
|
|
1
|
+
import _typeof from "@babel/runtime/helpers/typeof";
|
|
2
|
+
import _regeneratorRuntime from "@babel/runtime/helpers/regeneratorRuntime";
|
|
3
|
+
import _asyncToGenerator from "@babel/runtime/helpers/asyncToGenerator";
|
|
4
|
+
import { withCatch } from '../withCatch';
|
|
5
|
+
describe('withCatch', function () {
|
|
6
|
+
it('should return the result of the fetch function when it succeeds', /*#__PURE__*/_asyncToGenerator(/*#__PURE__*/_regeneratorRuntime().mark(function _callee() {
|
|
7
|
+
var mockFetch, mockErrorHandler, safeFetch, result;
|
|
8
|
+
return _regeneratorRuntime().wrap(function _callee$(_context) {
|
|
9
|
+
while (1) switch (_context.prev = _context.next) {
|
|
10
|
+
case 0:
|
|
11
|
+
mockFetch = jest.fn().mockResolvedValue({
|
|
12
|
+
data: 'success'
|
|
13
|
+
});
|
|
14
|
+
mockErrorHandler = jest.fn().mockReturnValue({
|
|
15
|
+
error: 'handled'
|
|
16
|
+
});
|
|
17
|
+
safeFetch = withCatch(mockFetch, mockErrorHandler);
|
|
18
|
+
_context.next = 5;
|
|
19
|
+
return safeFetch('arg1', 42);
|
|
20
|
+
case 5:
|
|
21
|
+
result = _context.sent;
|
|
22
|
+
expect(mockFetch).toHaveBeenCalledWith('arg1', 42);
|
|
23
|
+
expect(mockErrorHandler).not.toHaveBeenCalled();
|
|
24
|
+
expect(result).toEqual({
|
|
25
|
+
data: 'success'
|
|
26
|
+
});
|
|
27
|
+
case 9:
|
|
28
|
+
case "end":
|
|
29
|
+
return _context.stop();
|
|
30
|
+
}
|
|
31
|
+
}, _callee);
|
|
32
|
+
})));
|
|
33
|
+
it('should call the error handler when the fetch function fails', /*#__PURE__*/_asyncToGenerator(/*#__PURE__*/_regeneratorRuntime().mark(function _callee2() {
|
|
34
|
+
var error, mockFetch, mockErrorHandler, safeFetch, result;
|
|
35
|
+
return _regeneratorRuntime().wrap(function _callee2$(_context2) {
|
|
36
|
+
while (1) switch (_context2.prev = _context2.next) {
|
|
37
|
+
case 0:
|
|
38
|
+
error = new Error('fetch failed');
|
|
39
|
+
mockFetch = jest.fn().mockRejectedValue(error);
|
|
40
|
+
mockErrorHandler = jest.fn().mockReturnValue({
|
|
41
|
+
error: 'handled'
|
|
42
|
+
});
|
|
43
|
+
safeFetch = withCatch(mockFetch, mockErrorHandler);
|
|
44
|
+
_context2.next = 6;
|
|
45
|
+
return safeFetch('arg1', 42);
|
|
46
|
+
case 6:
|
|
47
|
+
result = _context2.sent;
|
|
48
|
+
expect(mockFetch).toHaveBeenCalledWith('arg1', 42);
|
|
49
|
+
expect(mockErrorHandler).toHaveBeenCalledWith(error);
|
|
50
|
+
expect(result).toEqual({
|
|
51
|
+
error: 'handled'
|
|
52
|
+
});
|
|
53
|
+
case 10:
|
|
54
|
+
case "end":
|
|
55
|
+
return _context2.stop();
|
|
56
|
+
}
|
|
57
|
+
}, _callee2);
|
|
58
|
+
})));
|
|
59
|
+
it('should work with functions that take no parameters', /*#__PURE__*/_asyncToGenerator(/*#__PURE__*/_regeneratorRuntime().mark(function _callee3() {
|
|
60
|
+
var mockFetch, mockErrorHandler, safeFetch, result;
|
|
61
|
+
return _regeneratorRuntime().wrap(function _callee3$(_context3) {
|
|
62
|
+
while (1) switch (_context3.prev = _context3.next) {
|
|
63
|
+
case 0:
|
|
64
|
+
mockFetch = jest.fn().mockResolvedValue({
|
|
65
|
+
data: 'success'
|
|
66
|
+
});
|
|
67
|
+
mockErrorHandler = jest.fn().mockReturnValue({
|
|
68
|
+
error: 'handled'
|
|
69
|
+
});
|
|
70
|
+
safeFetch = withCatch(mockFetch, mockErrorHandler);
|
|
71
|
+
_context3.next = 5;
|
|
72
|
+
return safeFetch();
|
|
73
|
+
case 5:
|
|
74
|
+
result = _context3.sent;
|
|
75
|
+
expect(mockFetch).toHaveBeenCalledWith();
|
|
76
|
+
expect(mockErrorHandler).not.toHaveBeenCalled();
|
|
77
|
+
expect(result).toEqual({
|
|
78
|
+
data: 'success'
|
|
79
|
+
});
|
|
80
|
+
case 9:
|
|
81
|
+
case "end":
|
|
82
|
+
return _context3.stop();
|
|
83
|
+
}
|
|
84
|
+
}, _callee3);
|
|
85
|
+
})));
|
|
86
|
+
it('should work with functions that take multiple parameters', /*#__PURE__*/_asyncToGenerator(/*#__PURE__*/_regeneratorRuntime().mark(function _callee4() {
|
|
87
|
+
var mockFetch, mockErrorHandler, safeFetch, result;
|
|
88
|
+
return _regeneratorRuntime().wrap(function _callee4$(_context4) {
|
|
89
|
+
while (1) switch (_context4.prev = _context4.next) {
|
|
90
|
+
case 0:
|
|
91
|
+
mockFetch = jest.fn().mockResolvedValue({
|
|
92
|
+
data: 'success'
|
|
93
|
+
});
|
|
94
|
+
mockErrorHandler = jest.fn().mockReturnValue({
|
|
95
|
+
error: 'handled'
|
|
96
|
+
});
|
|
97
|
+
safeFetch = withCatch(mockFetch, mockErrorHandler);
|
|
98
|
+
_context4.next = 5;
|
|
99
|
+
return safeFetch('arg1', 42, true, {
|
|
100
|
+
complex: 'object'
|
|
101
|
+
});
|
|
102
|
+
case 5:
|
|
103
|
+
result = _context4.sent;
|
|
104
|
+
expect(mockFetch).toHaveBeenCalledWith('arg1', 42, true, {
|
|
105
|
+
complex: 'object'
|
|
106
|
+
});
|
|
107
|
+
expect(mockErrorHandler).not.toHaveBeenCalled();
|
|
108
|
+
expect(result).toEqual({
|
|
109
|
+
data: 'success'
|
|
110
|
+
});
|
|
111
|
+
case 9:
|
|
112
|
+
case "end":
|
|
113
|
+
return _context4.stop();
|
|
114
|
+
}
|
|
115
|
+
}, _callee4);
|
|
116
|
+
})));
|
|
117
|
+
it('should handle error handlers that return promises', /*#__PURE__*/_asyncToGenerator(/*#__PURE__*/_regeneratorRuntime().mark(function _callee5() {
|
|
118
|
+
var error, mockFetch, mockErrorHandler, safeFetch, result;
|
|
119
|
+
return _regeneratorRuntime().wrap(function _callee5$(_context5) {
|
|
120
|
+
while (1) switch (_context5.prev = _context5.next) {
|
|
121
|
+
case 0:
|
|
122
|
+
error = new Error('fetch failed');
|
|
123
|
+
mockFetch = jest.fn().mockRejectedValue(error);
|
|
124
|
+
mockErrorHandler = jest.fn().mockResolvedValue({
|
|
125
|
+
error: 'async handled'
|
|
126
|
+
});
|
|
127
|
+
safeFetch = withCatch(mockFetch, mockErrorHandler);
|
|
128
|
+
_context5.next = 6;
|
|
129
|
+
return safeFetch('arg1');
|
|
130
|
+
case 6:
|
|
131
|
+
result = _context5.sent;
|
|
132
|
+
expect(mockFetch).toHaveBeenCalledWith('arg1');
|
|
133
|
+
expect(mockErrorHandler).toHaveBeenCalledWith(error);
|
|
134
|
+
expect(result).toEqual({
|
|
135
|
+
error: 'async handled'
|
|
136
|
+
});
|
|
137
|
+
case 10:
|
|
138
|
+
case "end":
|
|
139
|
+
return _context5.stop();
|
|
140
|
+
}
|
|
141
|
+
}, _callee5);
|
|
142
|
+
})));
|
|
143
|
+
it('should preserve the type of the fetch function return value', /*#__PURE__*/_asyncToGenerator(/*#__PURE__*/_regeneratorRuntime().mark(function _callee6() {
|
|
144
|
+
var mockFetch, mockErrorHandler, safeFetch, result, userName;
|
|
145
|
+
return _regeneratorRuntime().wrap(function _callee6$(_context6) {
|
|
146
|
+
while (1) switch (_context6.prev = _context6.next) {
|
|
147
|
+
case 0:
|
|
148
|
+
mockFetch = jest.fn().mockResolvedValue({
|
|
149
|
+
id: 1,
|
|
150
|
+
name: 'John Doe'
|
|
151
|
+
});
|
|
152
|
+
mockErrorHandler = jest.fn().mockReturnValue(null);
|
|
153
|
+
safeFetch = withCatch(mockFetch, mockErrorHandler);
|
|
154
|
+
_context6.next = 5;
|
|
155
|
+
return safeFetch('user1');
|
|
156
|
+
case 5:
|
|
157
|
+
result = _context6.sent;
|
|
158
|
+
expect(result).toEqual({
|
|
159
|
+
id: 1,
|
|
160
|
+
name: 'John Doe'
|
|
161
|
+
});
|
|
162
|
+
// TypeScript should recognize result as User | null
|
|
163
|
+
if (result !== null) {
|
|
164
|
+
// This should compile without errors
|
|
165
|
+
userName = result.name;
|
|
166
|
+
expect(userName).toBe('John Doe');
|
|
167
|
+
}
|
|
168
|
+
case 8:
|
|
169
|
+
case "end":
|
|
170
|
+
return _context6.stop();
|
|
171
|
+
}
|
|
172
|
+
}, _callee6);
|
|
173
|
+
})));
|
|
174
|
+
it('should preserve the type of the error handler return value', /*#__PURE__*/_asyncToGenerator(/*#__PURE__*/_regeneratorRuntime().mark(function _callee7() {
|
|
175
|
+
var error, mockFetch, mockErrorHandler, safeFetch, result, errorCode;
|
|
176
|
+
return _regeneratorRuntime().wrap(function _callee7$(_context7) {
|
|
177
|
+
while (1) switch (_context7.prev = _context7.next) {
|
|
178
|
+
case 0:
|
|
179
|
+
error = new Error('fetch failed');
|
|
180
|
+
mockFetch = jest.fn().mockRejectedValue(error);
|
|
181
|
+
mockErrorHandler = jest.fn().mockReturnValue({
|
|
182
|
+
code: 500,
|
|
183
|
+
message: 'Internal Server Error'
|
|
184
|
+
});
|
|
185
|
+
safeFetch = withCatch(mockFetch, mockErrorHandler);
|
|
186
|
+
_context7.next = 6;
|
|
187
|
+
return safeFetch('user1');
|
|
188
|
+
case 6:
|
|
189
|
+
result = _context7.sent;
|
|
190
|
+
expect(mockErrorHandler).toHaveBeenCalledWith(error);
|
|
191
|
+
|
|
192
|
+
// TypeScript should recognize result as unknown | ErrorResponse
|
|
193
|
+
if (_typeof(result) === 'object' && result !== null && 'code' in result) {
|
|
194
|
+
// This should compile without errors
|
|
195
|
+
errorCode = result.code;
|
|
196
|
+
expect(errorCode).toBe(500);
|
|
197
|
+
}
|
|
198
|
+
case 9:
|
|
199
|
+
case "end":
|
|
200
|
+
return _context7.stop();
|
|
201
|
+
}
|
|
202
|
+
}, _callee7);
|
|
203
|
+
})));
|
|
204
|
+
});
|
|
205
|
+
// #sourceMappingURL=withCatch.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["withCatch","describe","it","_asyncToGenerator","_regeneratorRuntime","mark","_callee","mockFetch","mockErrorHandler","safeFetch","result","wrap","_callee$","_context","prev","next","jest","fn","mockResolvedValue","data","mockReturnValue","error","sent","expect","toHaveBeenCalledWith","not","toHaveBeenCalled","toEqual","stop","_callee2","_callee2$","_context2","Error","mockRejectedValue","_callee3","_callee3$","_context3","_callee4","_callee4$","_context4","complex","_callee5","_callee5$","_context5","_callee6","userName","_callee6$","_context6","id","name","toBe","_callee7","errorCode","_callee7$","_context7","code","message","_typeof"],"sources":["withCatch.test.ts"],"sourcesContent":["import {withCatch} from '../withCatch';\n\ndescribe('withCatch', () => {\n it('should return the result of the fetch function when it succeeds', async () => {\n const mockFetch = jest.fn().mockResolvedValue({data: 'success'});\n const mockErrorHandler = jest.fn().mockReturnValue({error: 'handled'});\n\n const safeFetch = withCatch(mockFetch, mockErrorHandler);\n const result = await safeFetch('arg1', 42);\n\n expect(mockFetch).toHaveBeenCalledWith('arg1', 42);\n expect(mockErrorHandler).not.toHaveBeenCalled();\n expect(result).toEqual({data: 'success'});\n });\n\n it('should call the error handler when the fetch function fails', async () => {\n const error = new Error('fetch failed');\n const mockFetch = jest.fn().mockRejectedValue(error);\n const mockErrorHandler = jest.fn().mockReturnValue({error: 'handled'});\n\n const safeFetch = withCatch(mockFetch, mockErrorHandler);\n const result = await safeFetch('arg1', 42);\n\n expect(mockFetch).toHaveBeenCalledWith('arg1', 42);\n expect(mockErrorHandler).toHaveBeenCalledWith(error);\n expect(result).toEqual({error: 'handled'});\n });\n\n it('should work with functions that take no parameters', async () => {\n const mockFetch = jest.fn().mockResolvedValue({data: 'success'});\n const mockErrorHandler = jest.fn().mockReturnValue({error: 'handled'});\n\n const safeFetch = withCatch(mockFetch, mockErrorHandler);\n const result = await safeFetch();\n\n expect(mockFetch).toHaveBeenCalledWith();\n expect(mockErrorHandler).not.toHaveBeenCalled();\n expect(result).toEqual({data: 'success'});\n });\n\n it('should work with functions that take multiple parameters', async () => {\n const mockFetch = jest.fn().mockResolvedValue({data: 'success'});\n const mockErrorHandler = jest.fn().mockReturnValue({error: 'handled'});\n\n const safeFetch = withCatch(mockFetch, mockErrorHandler);\n const result = await safeFetch('arg1', 42, true, {complex: 'object'});\n\n expect(mockFetch).toHaveBeenCalledWith('arg1', 42, true, {complex: 'object'});\n expect(mockErrorHandler).not.toHaveBeenCalled();\n expect(result).toEqual({data: 'success'});\n });\n\n it('should handle error handlers that return promises', async () => {\n const error = new Error('fetch failed');\n const mockFetch = jest.fn().mockRejectedValue(error);\n const mockErrorHandler = jest.fn().mockResolvedValue({error: 'async handled'});\n\n const safeFetch = withCatch(mockFetch, mockErrorHandler);\n const result = await safeFetch('arg1');\n\n expect(mockFetch).toHaveBeenCalledWith('arg1');\n expect(mockErrorHandler).toHaveBeenCalledWith(error);\n expect(result).toEqual({error: 'async handled'});\n });\n\n it('should preserve the type of the fetch function return value', async () => {\n interface User {\n id: number;\n name: string;\n }\n\n const mockFetch = jest.fn().mockResolvedValue({\n id: 1,\n name: 'John Doe',\n } as User);\n\n const mockErrorHandler = jest.fn().mockReturnValue(null);\n\n const safeFetch = withCatch<[string], User, null>(mockFetch, mockErrorHandler);\n const result = await safeFetch('user1');\n\n expect(result).toEqual({id: 1, name: 'John Doe'});\n // TypeScript should recognize result as User | null\n if (result !== null) {\n // This should compile without errors\n const userName = result.name;\n expect(userName).toBe('John Doe');\n }\n });\n\n it('should preserve the type of the error handler return value', async () => {\n interface ErrorResponse {\n code: number;\n message: string;\n }\n\n const error = new Error('fetch failed');\n const mockFetch = jest.fn<Promise<unknown>, [string]>().mockRejectedValue(error);\n\n const mockErrorHandler = jest.fn().mockReturnValue({\n code: 500,\n message: 'Internal Server Error',\n } as ErrorResponse);\n\n const safeFetch = withCatch<[string], unknown, ErrorResponse>(mockFetch, mockErrorHandler);\n const result = await safeFetch('user1');\n\n expect(mockErrorHandler).toHaveBeenCalledWith(error);\n\n // TypeScript should recognize result as unknown | ErrorResponse\n if (typeof result === 'object' && result !== null && 'code' in result) {\n // This should compile without errors\n const errorCode = (result as ErrorResponse).code;\n expect(errorCode).toBe(500);\n }\n });\n});\n"],"mappings":"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","ignoreList":[]}
|
|
@@ -7,6 +7,6 @@ export var hasTag = function hasTag(key, tag) {
|
|
|
7
7
|
// First element — data source name
|
|
8
8
|
// Last element — full key
|
|
9
9
|
// Skip them for consistency
|
|
10
|
-
return index > 0 && index < key.length -
|
|
10
|
+
return index > 0 && index < key.length - 1;
|
|
11
11
|
};
|
|
12
12
|
// #sourceMappingURL=hasTag.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["hasTag","key","tag","Array","isArray","index","indexOf","length"],"sources":["hasTag.ts"],"sourcesContent":["import type {DataSourceKey, DataSourceTag} from '../types/DataSource';\n\nexport const hasTag = (key: DataSourceKey, tag: DataSourceTag): boolean => {\n if (!Array.isArray(key)) {\n return false;\n }\n\n const index = key.indexOf(tag);\n\n // First element — data source name\n // Last element — full key\n // Skip them for consistency\n return index > 0 && index < key.length -
|
|
1
|
+
{"version":3,"names":["hasTag","key","tag","Array","isArray","index","indexOf","length"],"sources":["hasTag.ts"],"sourcesContent":["import type {DataSourceKey, DataSourceTag} from '../types/DataSource';\n\nexport const hasTag = (key: DataSourceKey, tag: DataSourceTag): boolean => {\n if (!Array.isArray(key)) {\n return false;\n }\n\n const index = key.indexOf(tag);\n\n // First element — data source name\n // Last element — full key\n // Skip them for consistency\n return index > 0 && index < key.length - 1;\n};\n"],"mappings":"AAEA,OAAO,IAAMA,MAAM,GAAG,SAATA,MAAMA,CAAIC,GAAkB,EAAEC,GAAkB,EAAc;EACvE,IAAI,CAACC,KAAK,CAACC,OAAO,CAACH,GAAG,CAAC,EAAE;IACrB,OAAO,KAAK;EAChB;EAEA,IAAMI,KAAK,GAAGJ,GAAG,CAACK,OAAO,CAACJ,GAAG,CAAC;;EAE9B;EACA;EACA;EACA,OAAOG,KAAK,GAAG,CAAC,IAAIA,KAAK,GAAGJ,GAAG,CAACM,MAAM,GAAG,CAAC;AAC9C,CAAC","ignoreList":[]}
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Creates a wrapper around a function that safely handles errors using a provided error handler.
|
|
3
|
+
*
|
|
4
|
+
* This utility function enhances a Promise-returning function by adding standardized error handling.
|
|
5
|
+
* It catches any errors thrown by the original function and processes them through the provided
|
|
6
|
+
* error handler, allowing for consistent error management across the application.
|
|
7
|
+
*
|
|
8
|
+
* @template TArgs - The argument types of the original function
|
|
9
|
+
* @template TFetchReturnType - The return type of the original function's Promise
|
|
10
|
+
* @template TCatchReturnType - The return type of the error handler function
|
|
11
|
+
*
|
|
12
|
+
* @param fetchFn - The original function that returns a Promise
|
|
13
|
+
* @param onCatchFn - The error handler function that processes any caught errors
|
|
14
|
+
*
|
|
15
|
+
* @returns A new function with the same signature as the original function,
|
|
16
|
+
* but with error handling applied. The returned function will resolve to either
|
|
17
|
+
* the successful result of the original function or the result of the error handler.
|
|
18
|
+
*
|
|
19
|
+
* @example
|
|
20
|
+
* // Basic usage with a string parameter
|
|
21
|
+
* const fetchUser = withCatch(
|
|
22
|
+
* someFetchFunction,
|
|
23
|
+
* (error) => ({ error: true, message: error.message })
|
|
24
|
+
* );
|
|
25
|
+
*/
|
|
26
|
+
export declare function withCatch<TArgs extends unknown[], TFetchReturnType, TCatchReturnType>(fetchFn: (...args: TArgs) => Promise<TFetchReturnType>, onCatchFn: (reason: unknown) => TCatchReturnType): (...args: TArgs) => Promise<TFetchReturnType | TCatchReturnType>;
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Creates a wrapper around a function that safely handles errors using a provided error handler.
|
|
3
|
+
*
|
|
4
|
+
* This utility function enhances a Promise-returning function by adding standardized error handling.
|
|
5
|
+
* It catches any errors thrown by the original function and processes them through the provided
|
|
6
|
+
* error handler, allowing for consistent error management across the application.
|
|
7
|
+
*
|
|
8
|
+
* @template TArgs - The argument types of the original function
|
|
9
|
+
* @template TFetchReturnType - The return type of the original function's Promise
|
|
10
|
+
* @template TCatchReturnType - The return type of the error handler function
|
|
11
|
+
*
|
|
12
|
+
* @param fetchFn - The original function that returns a Promise
|
|
13
|
+
* @param onCatchFn - The error handler function that processes any caught errors
|
|
14
|
+
*
|
|
15
|
+
* @returns A new function with the same signature as the original function,
|
|
16
|
+
* but with error handling applied. The returned function will resolve to either
|
|
17
|
+
* the successful result of the original function or the result of the error handler.
|
|
18
|
+
*
|
|
19
|
+
* @example
|
|
20
|
+
* // Basic usage with a string parameter
|
|
21
|
+
* const fetchUser = withCatch(
|
|
22
|
+
* someFetchFunction,
|
|
23
|
+
* (error) => ({ error: true, message: error.message })
|
|
24
|
+
* );
|
|
25
|
+
*/
|
|
26
|
+
export function withCatch(fetchFn, onCatchFn) {
|
|
27
|
+
return function () {
|
|
28
|
+
return fetchFn.apply(void 0, arguments)["catch"](onCatchFn);
|
|
29
|
+
};
|
|
30
|
+
}
|
|
31
|
+
// #sourceMappingURL=withCatch.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["withCatch","fetchFn","onCatchFn","apply","arguments"],"sources":["withCatch.ts"],"sourcesContent":["/**\n * Creates a wrapper around a function that safely handles errors using a provided error handler.\n *\n * This utility function enhances a Promise-returning function by adding standardized error handling.\n * It catches any errors thrown by the original function and processes them through the provided\n * error handler, allowing for consistent error management across the application.\n *\n * @template TArgs - The argument types of the original function\n * @template TFetchReturnType - The return type of the original function's Promise\n * @template TCatchReturnType - The return type of the error handler function\n *\n * @param fetchFn - The original function that returns a Promise\n * @param onCatchFn - The error handler function that processes any caught errors\n *\n * @returns A new function with the same signature as the original function,\n * but with error handling applied. The returned function will resolve to either\n * the successful result of the original function or the result of the error handler.\n *\n * @example\n * // Basic usage with a string parameter\n * const fetchUser = withCatch(\n * someFetchFunction,\n * (error) => ({ error: true, message: error.message })\n * );\n */\nexport function withCatch<TArgs extends unknown[], TFetchReturnType, TCatchReturnType>(\n fetchFn: (...args: TArgs) => Promise<TFetchReturnType>,\n onCatchFn: (reason: unknown) => TCatchReturnType,\n): (...args: TArgs) => Promise<TFetchReturnType | TCatchReturnType> {\n return (...args) => {\n return fetchFn(...args).catch(onCatchFn) as Promise<TFetchReturnType | TCatchReturnType>;\n };\n}\n"],"mappings":"AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO,SAASA,SAASA,CACrBC,OAAsD,EACtDC,SAAgD,EACgB;EAChE,OAAO,YAAa;IAChB,OAAOD,OAAO,CAAAE,KAAA,SAAAC,SAAQ,CAAC,SAAM,CAACF,SAAS,CAAC;EAC5C,CAAC;AACL","ignoreList":[]}
|
|
@@ -3,7 +3,7 @@ export var DataManagerContext = /*#__PURE__*/createContext(null);
|
|
|
3
3
|
export var useDataManager = function useDataManager() {
|
|
4
4
|
var dataManager = useContext(DataManagerContext);
|
|
5
5
|
if (!dataManager) {
|
|
6
|
-
throw new Error('DataManager is not
|
|
6
|
+
throw new Error('DataManager is not provided by context. Use DataManagerContext.Provider to do it');
|
|
7
7
|
}
|
|
8
8
|
return dataManager;
|
|
9
9
|
};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["createContext","useContext","DataManagerContext","useDataManager","dataManager","Error"],"sources":["DataManagerContext.ts"],"sourcesContent":["import {createContext, useContext} from 'react';\n\nimport type {DataManager} from '../core';\n\nexport const DataManagerContext = createContext<DataManager | null>(null);\n\nexport const useDataManager = () => {\n const dataManager = useContext(DataManagerContext);\n\n if (!dataManager) {\n throw new Error(\n 'DataManager is not
|
|
1
|
+
{"version":3,"names":["createContext","useContext","DataManagerContext","useDataManager","dataManager","Error"],"sources":["DataManagerContext.ts"],"sourcesContent":["import {createContext, useContext} from 'react';\n\nimport type {DataManager} from '../core';\n\nexport const DataManagerContext = createContext<DataManager | null>(null);\n\nexport const useDataManager = () => {\n const dataManager = useContext(DataManagerContext);\n\n if (!dataManager) {\n throw new Error(\n 'DataManager is not provided by context. Use DataManagerContext.Provider to do it',\n );\n }\n\n return dataManager;\n};\n"],"mappings":"AAAA,SAAQA,aAAa,EAAEC,UAAU,QAAO,OAAO;AAI/C,OAAO,IAAMC,kBAAkB,gBAAGF,aAAa,CAAqB,IAAI,CAAC;AAEzE,OAAO,IAAMG,cAAc,GAAG,SAAjBA,cAAcA,CAAA,EAAS;EAChC,IAAMC,WAAW,GAAGH,UAAU,CAACC,kBAAkB,CAAC;EAElD,IAAI,CAACE,WAAW,EAAE;IACd,MAAM,IAAIC,KAAK,CACX,kFACJ,CAAC;EACL;EAEA,OAAOD,WAAW;AACtB,CAAC","ignoreList":[]}
|
|
@@ -0,0 +1,43 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
import { renderHook } from '@testing-library/react';
|
|
3
|
+
import { DataManagerContext, useDataManager } from '../DataManagerContext';
|
|
4
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
5
|
+
describe('useDataManager', function () {
|
|
6
|
+
it('should return dataManager from context', function () {
|
|
7
|
+
var mockDataManager = {
|
|
8
|
+
invalidateTag: jest.fn(),
|
|
9
|
+
invalidateTags: jest.fn(),
|
|
10
|
+
invalidateSource: jest.fn(),
|
|
11
|
+
resetSource: jest.fn(),
|
|
12
|
+
invalidateParams: jest.fn(),
|
|
13
|
+
resetParams: jest.fn(),
|
|
14
|
+
invalidateSourceTags: jest.fn()
|
|
15
|
+
};
|
|
16
|
+
var wrapper = function wrapper(_ref) {
|
|
17
|
+
var children = _ref.children;
|
|
18
|
+
return /*#__PURE__*/_jsx(DataManagerContext.Provider, {
|
|
19
|
+
value: mockDataManager,
|
|
20
|
+
children: children
|
|
21
|
+
});
|
|
22
|
+
};
|
|
23
|
+
var _renderHook = renderHook(function () {
|
|
24
|
+
return useDataManager();
|
|
25
|
+
}, {
|
|
26
|
+
wrapper: wrapper
|
|
27
|
+
}),
|
|
28
|
+
result = _renderHook.result;
|
|
29
|
+
expect(result.current).toBe(mockDataManager);
|
|
30
|
+
});
|
|
31
|
+
it('should throw an error when dataManager is not provided', function () {
|
|
32
|
+
try {
|
|
33
|
+
renderHook(function () {
|
|
34
|
+
return useDataManager();
|
|
35
|
+
});
|
|
36
|
+
} catch (error) {
|
|
37
|
+
expect(error).toBeInstanceOf(Error);
|
|
38
|
+
// Just to be sure that the error is from the right place
|
|
39
|
+
expect(error.message).toBe('DataManager is not provided by context. Use DataManagerContext.Provider to do it');
|
|
40
|
+
}
|
|
41
|
+
});
|
|
42
|
+
});
|
|
43
|
+
// #sourceMappingURL=DataManagerContext.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["React","renderHook","DataManagerContext","useDataManager","jsx","_jsx","describe","it","mockDataManager","invalidateTag","jest","fn","invalidateTags","invalidateSource","resetSource","invalidateParams","resetParams","invalidateSourceTags","wrapper","_ref","children","Provider","value","_renderHook","result","expect","current","toBe","error","toBeInstanceOf","Error","message"],"sources":["DataManagerContext.test.tsx"],"sourcesContent":["import React from 'react';\n\nimport {renderHook} from '@testing-library/react';\n\nimport type {DataManager} from '../../core';\nimport {DataManagerContext, useDataManager} from '../DataManagerContext';\n\ndescribe('useDataManager', () => {\n it('should return dataManager from context', () => {\n const mockDataManager: DataManager = {\n invalidateTag: jest.fn(),\n invalidateTags: jest.fn(),\n invalidateSource: jest.fn(),\n resetSource: jest.fn(),\n invalidateParams: jest.fn(),\n resetParams: jest.fn(),\n invalidateSourceTags: jest.fn(),\n };\n\n const wrapper: React.FC<{children: React.ReactNode}> = ({children}) => (\n <DataManagerContext.Provider value={mockDataManager}>\n {children}\n </DataManagerContext.Provider>\n );\n\n const {result} = renderHook(() => useDataManager(), {wrapper});\n\n expect(result.current).toBe(mockDataManager);\n });\n\n it('should throw an error when dataManager is not provided', () => {\n try {\n renderHook(() => useDataManager());\n } catch (error) {\n expect(error).toBeInstanceOf(Error);\n // Just to be sure that the error is from the right place\n expect((error as Error).message).toBe(\n 'DataManager is not provided by context. Use DataManagerContext.Provider to do it',\n );\n }\n });\n});\n"],"mappings":"AAAA,OAAOA,KAAK,MAAM,OAAO;AAEzB,SAAQC,UAAU,QAAO,wBAAwB;AAGjD,SAAQC,kBAAkB,EAAEC,cAAc,QAAO,uBAAuB;AAAC,SAAAC,GAAA,IAAAC,IAAA;AAEzEC,QAAQ,CAAC,gBAAgB,EAAE,YAAM;EAC7BC,EAAE,CAAC,wCAAwC,EAAE,YAAM;IAC/C,IAAMC,eAA4B,GAAG;MACjCC,aAAa,EAAEC,IAAI,CAACC,EAAE,CAAC,CAAC;MACxBC,cAAc,EAAEF,IAAI,CAACC,EAAE,CAAC,CAAC;MACzBE,gBAAgB,EAAEH,IAAI,CAACC,EAAE,CAAC,CAAC;MAC3BG,WAAW,EAAEJ,IAAI,CAACC,EAAE,CAAC,CAAC;MACtBI,gBAAgB,EAAEL,IAAI,CAACC,EAAE,CAAC,CAAC;MAC3BK,WAAW,EAAEN,IAAI,CAACC,EAAE,CAAC,CAAC;MACtBM,oBAAoB,EAAEP,IAAI,CAACC,EAAE,CAAC;IAClC,CAAC;IAED,IAAMO,OAA8C,GAAG,SAAjDA,OAA8CA,CAAAC,IAAA;MAAA,IAAKC,QAAQ,GAAAD,IAAA,CAARC,QAAQ;MAAA,oBAC7Df,IAAA,CAACH,kBAAkB,CAACmB,QAAQ;QAACC,KAAK,EAAEd,eAAgB;QAAAY,QAAA,EAC/CA;MAAQ,CACgB,CAAC;IAAA,CACjC;IAED,IAAAG,WAAA,GAAiBtB,UAAU,CAAC;QAAA,OAAME,cAAc,CAAC,CAAC;MAAA,GAAE;QAACe,OAAO,EAAPA;MAAO,CAAC,CAAC;MAAvDM,MAAM,GAAAD,WAAA,CAANC,MAAM;IAEbC,MAAM,CAACD,MAAM,CAACE,OAAO,CAAC,CAACC,IAAI,CAACnB,eAAe,CAAC;EAChD,CAAC,CAAC;EAEFD,EAAE,CAAC,wDAAwD,EAAE,YAAM;IAC/D,IAAI;MACAN,UAAU,CAAC;QAAA,OAAME,cAAc,CAAC,CAAC;MAAA,EAAC;IACtC,CAAC,CAAC,OAAOyB,KAAK,EAAE;MACZH,MAAM,CAACG,KAAK,CAAC,CAACC,cAAc,CAACC,KAAK,CAAC;MACnC;MACAL,MAAM,CAAEG,KAAK,CAAWG,OAAO,CAAC,CAACJ,IAAI,CACjC,kFACJ,CAAC;IACL;EACJ,CAAC,CAAC;AACN,CAAC,CAAC","ignoreList":[]}
|
|
@@ -0,0 +1,55 @@
|
|
|
1
|
+
import _objectSpread from "@babel/runtime/helpers/objectSpread2";
|
|
2
|
+
import React from 'react';
|
|
3
|
+
import { render, screen } from '@testing-library/react';
|
|
4
|
+
import { useDataManager } from '../DataManagerContext';
|
|
5
|
+
import { withDataManager } from '../withDataManager';
|
|
6
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
7
|
+
jest.mock('../DataManagerContext', function () {
|
|
8
|
+
var originalModule = jest.requireActual('../DataManagerContext');
|
|
9
|
+
return _objectSpread(_objectSpread({}, originalModule), {}, {
|
|
10
|
+
useDataManager: jest.fn()
|
|
11
|
+
});
|
|
12
|
+
});
|
|
13
|
+
describe('withDataManager', function () {
|
|
14
|
+
var mockDataManager = {
|
|
15
|
+
invalidateTag: jest.fn(),
|
|
16
|
+
invalidateTags: jest.fn(),
|
|
17
|
+
invalidateSource: jest.fn(),
|
|
18
|
+
resetSource: jest.fn(),
|
|
19
|
+
invalidateParams: jest.fn(),
|
|
20
|
+
resetParams: jest.fn(),
|
|
21
|
+
invalidateSourceTags: jest.fn()
|
|
22
|
+
};
|
|
23
|
+
beforeEach(function () {
|
|
24
|
+
jest.clearAllMocks();
|
|
25
|
+
useDataManager.mockReturnValue(mockDataManager);
|
|
26
|
+
});
|
|
27
|
+
it('should pass dataManager to wrapped component', function () {
|
|
28
|
+
var TestComponent = function TestComponent(_ref) {
|
|
29
|
+
var dataManager = _ref.dataManager;
|
|
30
|
+
return /*#__PURE__*/_jsx("div", {
|
|
31
|
+
"data-testid": "test-component",
|
|
32
|
+
children: dataManager ? 'DataManager provided' : 'No DataManager'
|
|
33
|
+
});
|
|
34
|
+
};
|
|
35
|
+
var WrappedComponent = withDataManager(TestComponent);
|
|
36
|
+
render(/*#__PURE__*/_jsx(WrappedComponent, {}));
|
|
37
|
+
expect(screen.getByTestId('test-component')).toHaveTextContent('DataManager provided');
|
|
38
|
+
});
|
|
39
|
+
it('should pass through additional props', function () {
|
|
40
|
+
var TestComponent = function TestComponent(_ref2) {
|
|
41
|
+
var dataManager = _ref2.dataManager,
|
|
42
|
+
testProp = _ref2.testProp;
|
|
43
|
+
return /*#__PURE__*/_jsx("div", {
|
|
44
|
+
"data-testid": "test-component",
|
|
45
|
+
children: dataManager ? "DataManager provided, testProp: ".concat(testProp) : 'No DataManager'
|
|
46
|
+
});
|
|
47
|
+
};
|
|
48
|
+
var WrappedComponent = withDataManager(TestComponent);
|
|
49
|
+
render(/*#__PURE__*/_jsx(WrappedComponent, {
|
|
50
|
+
testProp: "test value"
|
|
51
|
+
}));
|
|
52
|
+
expect(screen.getByTestId('test-component')).toHaveTextContent('DataManager provided, testProp: test value');
|
|
53
|
+
});
|
|
54
|
+
});
|
|
55
|
+
// #sourceMappingURL=withDataManager.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["React","render","screen","useDataManager","withDataManager","jsx","_jsx","jest","mock","originalModule","requireActual","_objectSpread","fn","describe","mockDataManager","invalidateTag","invalidateTags","invalidateSource","resetSource","invalidateParams","resetParams","invalidateSourceTags","beforeEach","clearAllMocks","mockReturnValue","it","TestComponent","_ref","dataManager","children","WrappedComponent","expect","getByTestId","toHaveTextContent","_ref2","testProp","concat"],"sources":["withDataManager.test.tsx"],"sourcesContent":["import React from 'react';\n\nimport {render, screen} from '@testing-library/react';\n\nimport type {DataManager} from '../../core';\nimport {useDataManager} from '../DataManagerContext';\nimport type {WithDataManagerProps} from '../withDataManager';\nimport {withDataManager} from '../withDataManager';\n\njest.mock('../DataManagerContext', () => {\n const originalModule = jest.requireActual('../DataManagerContext');\n return {\n ...originalModule,\n useDataManager: jest.fn(),\n };\n});\n\ndescribe('withDataManager', () => {\n const mockDataManager: DataManager = {\n invalidateTag: jest.fn(),\n invalidateTags: jest.fn(),\n invalidateSource: jest.fn(),\n resetSource: jest.fn(),\n invalidateParams: jest.fn(),\n resetParams: jest.fn(),\n invalidateSourceTags: jest.fn(),\n };\n\n beforeEach(() => {\n jest.clearAllMocks();\n\n (useDataManager as jest.Mock).mockReturnValue(mockDataManager);\n });\n\n it('should pass dataManager to wrapped component', () => {\n const TestComponent: React.FC<WithDataManagerProps> = ({dataManager}) => (\n <div data-testid=\"test-component\">\n {dataManager ? 'DataManager provided' : 'No DataManager'}\n </div>\n );\n const WrappedComponent = withDataManager(TestComponent);\n\n render(<WrappedComponent />);\n\n expect(screen.getByTestId('test-component')).toHaveTextContent('DataManager provided');\n });\n\n it('should pass through additional props', () => {\n const TestComponent: React.FC<WithDataManagerProps & {testProp: string}> = ({\n dataManager,\n testProp,\n }) => (\n <div data-testid=\"test-component\">\n {dataManager ? `DataManager provided, testProp: ${testProp}` : 'No DataManager'}\n </div>\n );\n const WrappedComponent = withDataManager(TestComponent);\n\n render(<WrappedComponent testProp=\"test value\" />);\n\n expect(screen.getByTestId('test-component')).toHaveTextContent(\n 'DataManager provided, testProp: test value',\n );\n });\n});\n"],"mappings":";AAAA,OAAOA,KAAK,MAAM,OAAO;AAEzB,SAAQC,MAAM,EAAEC,MAAM,QAAO,wBAAwB;AAGrD,SAAQC,cAAc,QAAO,uBAAuB;AAEpD,SAAQC,eAAe,QAAO,oBAAoB;AAAC,SAAAC,GAAA,IAAAC,IAAA;AAEnDC,IAAI,CAACC,IAAI,CAAC,uBAAuB,EAAE,YAAM;EACrC,IAAMC,cAAc,GAAGF,IAAI,CAACG,aAAa,CAAC,uBAAuB,CAAC;EAClE,OAAAC,aAAA,CAAAA,aAAA,KACOF,cAAc;IACjBN,cAAc,EAAEI,IAAI,CAACK,EAAE,CAAC;EAAC;AAEjC,CAAC,CAAC;AAEFC,QAAQ,CAAC,iBAAiB,EAAE,YAAM;EAC9B,IAAMC,eAA4B,GAAG;IACjCC,aAAa,EAAER,IAAI,CAACK,EAAE,CAAC,CAAC;IACxBI,cAAc,EAAET,IAAI,CAACK,EAAE,CAAC,CAAC;IACzBK,gBAAgB,EAAEV,IAAI,CAACK,EAAE,CAAC,CAAC;IAC3BM,WAAW,EAAEX,IAAI,CAACK,EAAE,CAAC,CAAC;IACtBO,gBAAgB,EAAEZ,IAAI,CAACK,EAAE,CAAC,CAAC;IAC3BQ,WAAW,EAAEb,IAAI,CAACK,EAAE,CAAC,CAAC;IACtBS,oBAAoB,EAAEd,IAAI,CAACK,EAAE,CAAC;EAClC,CAAC;EAEDU,UAAU,CAAC,YAAM;IACbf,IAAI,CAACgB,aAAa,CAAC,CAAC;IAEnBpB,cAAc,CAAeqB,eAAe,CAACV,eAAe,CAAC;EAClE,CAAC,CAAC;EAEFW,EAAE,CAAC,8CAA8C,EAAE,YAAM;IACrD,IAAMC,aAA6C,GAAG,SAAhDA,aAA6CA,CAAAC,IAAA;MAAA,IAAKC,WAAW,GAAAD,IAAA,CAAXC,WAAW;MAAA,oBAC/DtB,IAAA;QAAK,eAAY,gBAAgB;QAAAuB,QAAA,EAC5BD,WAAW,GAAG,sBAAsB,GAAG;MAAgB,CACvD,CAAC;IAAA,CACT;IACD,IAAME,gBAAgB,GAAG1B,eAAe,CAACsB,aAAa,CAAC;IAEvDzB,MAAM,cAACK,IAAA,CAACwB,gBAAgB,IAAE,CAAC,CAAC;IAE5BC,MAAM,CAAC7B,MAAM,CAAC8B,WAAW,CAAC,gBAAgB,CAAC,CAAC,CAACC,iBAAiB,CAAC,sBAAsB,CAAC;EAC1F,CAAC,CAAC;EAEFR,EAAE,CAAC,sCAAsC,EAAE,YAAM;IAC7C,IAAMC,aAAkE,GAAG,SAArEA,aAAkEA,CAAAQ,KAAA;MAAA,IACpEN,WAAW,GAAAM,KAAA,CAAXN,WAAW;QACXO,QAAQ,GAAAD,KAAA,CAARC,QAAQ;MAAA,oBAER7B,IAAA;QAAK,eAAY,gBAAgB;QAAAuB,QAAA,EAC5BD,WAAW,sCAAAQ,MAAA,CAAsCD,QAAQ,IAAK;MAAgB,CAC9E,CAAC;IAAA,CACT;IACD,IAAML,gBAAgB,GAAG1B,eAAe,CAACsB,aAAa,CAAC;IAEvDzB,MAAM,cAACK,IAAA,CAACwB,gBAAgB;MAACK,QAAQ,EAAC;IAAY,CAAE,CAAC,CAAC;IAElDJ,MAAM,CAAC7B,MAAM,CAAC8B,WAAW,CAAC,gBAAgB,CAAC,CAAC,CAACC,iBAAiB,CAC1D,4CACJ,CAAC;EACL,CAAC,CAAC;AACN,CAAC,CAAC","ignoreList":[]}
|
|
@@ -0,0 +1,184 @@
|
|
|
1
|
+
import _objectSpread from "@babel/runtime/helpers/objectSpread2";
|
|
2
|
+
import React from 'react';
|
|
3
|
+
import { fireEvent, render, screen } from '@testing-library/react';
|
|
4
|
+
import { DataInfiniteLoader } from '../DataInfiniteLoader';
|
|
5
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
6
|
+
var MockLoadingView = function MockLoadingView() {
|
|
7
|
+
return /*#__PURE__*/_jsx("div", {
|
|
8
|
+
"data-testid": "loading-view",
|
|
9
|
+
children: "Loading..."
|
|
10
|
+
});
|
|
11
|
+
};
|
|
12
|
+
var MockErrorView = function MockErrorView(_ref) {
|
|
13
|
+
var error = _ref.error,
|
|
14
|
+
action = _ref.action;
|
|
15
|
+
return /*#__PURE__*/_jsxs("div", {
|
|
16
|
+
"data-testid": "error-view",
|
|
17
|
+
children: [error ? "Error: ".concat(error.message) : 'No error', action ? /*#__PURE__*/_jsx("button", {
|
|
18
|
+
"data-testid": "error-action",
|
|
19
|
+
onClick: action.handler,
|
|
20
|
+
children: action.children || 'Retry'
|
|
21
|
+
}) : null]
|
|
22
|
+
});
|
|
23
|
+
};
|
|
24
|
+
var MockMoreView = function MockMoreView(_ref2) {
|
|
25
|
+
var isLoading = _ref2.isLoading,
|
|
26
|
+
onClick = _ref2.onClick;
|
|
27
|
+
return /*#__PURE__*/_jsx("div", {
|
|
28
|
+
"data-testid": "more-view",
|
|
29
|
+
children: isLoading ? /*#__PURE__*/_jsx("span", {
|
|
30
|
+
"data-testid": "more-view-loading",
|
|
31
|
+
children: "Loading more..."
|
|
32
|
+
}) : /*#__PURE__*/_jsx("button", {
|
|
33
|
+
"data-testid": "more-view-button",
|
|
34
|
+
onClick: onClick,
|
|
35
|
+
children: "Load more"
|
|
36
|
+
})
|
|
37
|
+
});
|
|
38
|
+
};
|
|
39
|
+
describe('DataInfiniteLoader', function () {
|
|
40
|
+
var renderDataInfiniteLoader = function renderDataInfiniteLoader() {
|
|
41
|
+
var props = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
|
|
42
|
+
var fetchNextPage = jest.fn();
|
|
43
|
+
var defaultProps = {
|
|
44
|
+
status: 'success',
|
|
45
|
+
error: null,
|
|
46
|
+
hasNextPage: true,
|
|
47
|
+
fetchNextPage: fetchNextPage,
|
|
48
|
+
isFetchingNextPage: false,
|
|
49
|
+
LoadingView: MockLoadingView,
|
|
50
|
+
ErrorView: MockErrorView,
|
|
51
|
+
MoreView: MockMoreView,
|
|
52
|
+
children: /*#__PURE__*/_jsx("div", {
|
|
53
|
+
"data-testid": "content",
|
|
54
|
+
children: "Content"
|
|
55
|
+
})
|
|
56
|
+
};
|
|
57
|
+
return _objectSpread(_objectSpread({}, render(/*#__PURE__*/_jsx(DataInfiniteLoader, _objectSpread(_objectSpread({}, defaultProps), props)))), {}, {
|
|
58
|
+
fetchNextPage: fetchNextPage
|
|
59
|
+
});
|
|
60
|
+
};
|
|
61
|
+
it('should render children and MoreView when status is success and hasNextPage is true', function () {
|
|
62
|
+
renderDataInfiniteLoader({
|
|
63
|
+
status: 'success',
|
|
64
|
+
hasNextPage: true
|
|
65
|
+
});
|
|
66
|
+
expect(screen.getByTestId('content')).toBeInTheDocument();
|
|
67
|
+
expect(screen.getByTestId('more-view')).toBeInTheDocument();
|
|
68
|
+
expect(screen.queryByTestId('loading-view')).not.toBeInTheDocument();
|
|
69
|
+
expect(screen.queryByTestId('error-view')).not.toBeInTheDocument();
|
|
70
|
+
});
|
|
71
|
+
it('should render only children when status is success and hasNextPage is false', function () {
|
|
72
|
+
renderDataInfiniteLoader({
|
|
73
|
+
status: 'success',
|
|
74
|
+
hasNextPage: false
|
|
75
|
+
});
|
|
76
|
+
expect(screen.getByTestId('content')).toBeInTheDocument();
|
|
77
|
+
expect(screen.queryByTestId('more-view')).not.toBeInTheDocument();
|
|
78
|
+
expect(screen.queryByTestId('loading-view')).not.toBeInTheDocument();
|
|
79
|
+
expect(screen.queryByTestId('error-view')).not.toBeInTheDocument();
|
|
80
|
+
});
|
|
81
|
+
it('should render LoadingView when status is loading', function () {
|
|
82
|
+
renderDataInfiniteLoader({
|
|
83
|
+
status: 'loading'
|
|
84
|
+
});
|
|
85
|
+
expect(screen.getByTestId('loading-view')).toBeInTheDocument();
|
|
86
|
+
expect(screen.queryByTestId('content')).not.toBeInTheDocument();
|
|
87
|
+
expect(screen.queryByTestId('more-view')).not.toBeInTheDocument();
|
|
88
|
+
expect(screen.queryByTestId('error-view')).not.toBeInTheDocument();
|
|
89
|
+
});
|
|
90
|
+
it('should render ErrorView when status is error', function () {
|
|
91
|
+
var error = new Error('Test error');
|
|
92
|
+
renderDataInfiniteLoader({
|
|
93
|
+
status: 'error',
|
|
94
|
+
error: error
|
|
95
|
+
});
|
|
96
|
+
expect(screen.getByTestId('error-view')).toBeInTheDocument();
|
|
97
|
+
expect(screen.queryByTestId('content')).not.toBeInTheDocument();
|
|
98
|
+
expect(screen.queryByTestId('more-view')).not.toBeInTheDocument();
|
|
99
|
+
expect(screen.queryByTestId('loading-view')).not.toBeInTheDocument();
|
|
100
|
+
expect(screen.getByText(/Test error/)).toBeInTheDocument();
|
|
101
|
+
});
|
|
102
|
+
it('should call fetchNextPage when clicking on load more button', function () {
|
|
103
|
+
var _renderDataInfiniteLo = renderDataInfiniteLoader({
|
|
104
|
+
status: 'success',
|
|
105
|
+
hasNextPage: true,
|
|
106
|
+
isFetchingNextPage: false
|
|
107
|
+
}),
|
|
108
|
+
fetchNextPage = _renderDataInfiniteLo.fetchNextPage;
|
|
109
|
+
fireEvent.click(screen.getByTestId('more-view-button'));
|
|
110
|
+
expect(fetchNextPage).toHaveBeenCalledTimes(1);
|
|
111
|
+
});
|
|
112
|
+
it('should show loading state in MoreView when isFetchingNextPage is true', function () {
|
|
113
|
+
renderDataInfiniteLoader({
|
|
114
|
+
status: 'success',
|
|
115
|
+
hasNextPage: true,
|
|
116
|
+
isFetchingNextPage: true
|
|
117
|
+
});
|
|
118
|
+
expect(screen.getByTestId('more-view-loading')).toBeInTheDocument();
|
|
119
|
+
expect(screen.queryByTestId('more-view-button')).not.toBeInTheDocument();
|
|
120
|
+
});
|
|
121
|
+
it('should pass errorAction to ErrorView', function () {
|
|
122
|
+
var error = new Error('Test error');
|
|
123
|
+
var errorAction = jest.fn();
|
|
124
|
+
renderDataInfiniteLoader({
|
|
125
|
+
status: 'error',
|
|
126
|
+
error: error,
|
|
127
|
+
errorAction: errorAction
|
|
128
|
+
});
|
|
129
|
+
expect(screen.getByTestId('error-action')).toBeInTheDocument();
|
|
130
|
+
});
|
|
131
|
+
it('should pass errorAction with custom children to ErrorView', function () {
|
|
132
|
+
var error = new Error('Test error');
|
|
133
|
+
var errorAction = {
|
|
134
|
+
handler: jest.fn(),
|
|
135
|
+
children: 'Custom action'
|
|
136
|
+
};
|
|
137
|
+
renderDataInfiniteLoader({
|
|
138
|
+
status: 'error',
|
|
139
|
+
error: error,
|
|
140
|
+
errorAction: errorAction
|
|
141
|
+
});
|
|
142
|
+
expect(screen.getByText('Custom action')).toBeInTheDocument();
|
|
143
|
+
});
|
|
144
|
+
it('should pass loadingViewProps to LoadingView', function () {
|
|
145
|
+
var LoadingView = jest.fn(MockLoadingView);
|
|
146
|
+
var loadingViewProps = {
|
|
147
|
+
customProp: 'test'
|
|
148
|
+
};
|
|
149
|
+
renderDataInfiniteLoader({
|
|
150
|
+
status: 'loading',
|
|
151
|
+
LoadingView: LoadingView,
|
|
152
|
+
loadingViewProps: loadingViewProps
|
|
153
|
+
});
|
|
154
|
+
expect(LoadingView).toHaveBeenCalledWith(expect.objectContaining(loadingViewProps), undefined);
|
|
155
|
+
});
|
|
156
|
+
it('should pass errorViewProps to ErrorView', function () {
|
|
157
|
+
var ErrorView = jest.fn(MockErrorView);
|
|
158
|
+
var errorViewProps = {
|
|
159
|
+
customProp: 'test'
|
|
160
|
+
};
|
|
161
|
+
var error = new Error('Test error');
|
|
162
|
+
renderDataInfiniteLoader({
|
|
163
|
+
status: 'error',
|
|
164
|
+
error: error,
|
|
165
|
+
ErrorView: ErrorView,
|
|
166
|
+
errorViewProps: errorViewProps
|
|
167
|
+
});
|
|
168
|
+
expect(ErrorView).toHaveBeenCalledWith(expect.objectContaining(errorViewProps), undefined);
|
|
169
|
+
});
|
|
170
|
+
it('should pass moreViewProps to MoreView', function () {
|
|
171
|
+
var MoreView = jest.fn(MockMoreView);
|
|
172
|
+
var moreViewProps = {
|
|
173
|
+
customProp: 'test'
|
|
174
|
+
};
|
|
175
|
+
renderDataInfiniteLoader({
|
|
176
|
+
status: 'success',
|
|
177
|
+
hasNextPage: true,
|
|
178
|
+
MoreView: MoreView,
|
|
179
|
+
moreViewProps: moreViewProps
|
|
180
|
+
});
|
|
181
|
+
expect(MoreView).toHaveBeenCalledWith(expect.objectContaining(moreViewProps), undefined);
|
|
182
|
+
});
|
|
183
|
+
});
|
|
184
|
+
// #sourceMappingURL=DataInfiniteLoader.test.js.map
|