@forgehive/task 0.2.3 → 0.2.5

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 (73) hide show
  1. package/dist/index.d.ts +9 -1
  2. package/dist/index.d.ts.map +1 -1
  3. package/dist/index.js +38 -9
  4. package/dist/index.js.map +1 -1
  5. package/dist/test/add-listener-with-boundaries.test.js +78 -7
  6. package/dist/test/add-listener-with-boundaries.test.js.map +1 -1
  7. package/dist/test/add-listener.test.js +36 -0
  8. package/dist/test/add-listener.test.js.map +1 -1
  9. package/dist/test/boundary-modes.test.js +45 -5
  10. package/dist/test/boundary-modes.test.js.map +1 -1
  11. package/dist/test/execution-record-boundaries.test.js +12 -2
  12. package/dist/test/execution-record-boundaries.test.js.map +1 -1
  13. package/dist/test/integration-enhanced-records.test.d.ts +2 -0
  14. package/dist/test/integration-enhanced-records.test.d.ts.map +1 -0
  15. package/dist/test/integration-enhanced-records.test.js +467 -0
  16. package/dist/test/integration-enhanced-records.test.js.map +1 -0
  17. package/dist/test/metrics-collection.test.d.ts +2 -0
  18. package/dist/test/metrics-collection.test.d.ts.map +1 -0
  19. package/dist/test/metrics-collection.test.js +409 -0
  20. package/dist/test/metrics-collection.test.js.map +1 -0
  21. package/dist/test/performance-edge-cases.test.d.ts +2 -0
  22. package/dist/test/performance-edge-cases.test.d.ts.map +1 -0
  23. package/dist/test/performance-edge-cases.test.js +502 -0
  24. package/dist/test/performance-edge-cases.test.js.map +1 -0
  25. package/dist/test/run-boundary.test.js +27 -3
  26. package/dist/test/run-boundary.test.js.map +1 -1
  27. package/dist/test/safe-replay-complex-boundary.test.js +110 -9
  28. package/dist/test/safe-replay-complex-boundary.test.js.map +1 -1
  29. package/dist/test/safe-replay.test.js +35 -5
  30. package/dist/test/safe-replay.test.js.map +1 -1
  31. package/dist/test/safe-run.test.js +46 -4
  32. package/dist/test/safe-run.test.js.map +1 -1
  33. package/dist/test/setmetrics-boundary.test.d.ts +2 -0
  34. package/dist/test/setmetrics-boundary.test.d.ts.map +1 -0
  35. package/dist/test/setmetrics-boundary.test.js +195 -0
  36. package/dist/test/setmetrics-boundary.test.js.map +1 -0
  37. package/dist/test/task-with-boundaries.test.js +63 -2
  38. package/dist/test/task-with-boundaries.test.js.map +1 -1
  39. package/dist/test/timing-capture.test.d.ts +2 -0
  40. package/dist/test/timing-capture.test.d.ts.map +1 -0
  41. package/dist/test/timing-capture.test.js +304 -0
  42. package/dist/test/timing-capture.test.js.map +1 -0
  43. package/dist/test/timing-utilities.test.d.ts +2 -0
  44. package/dist/test/timing-utilities.test.d.ts.map +1 -0
  45. package/dist/test/timing-utilities.test.js +127 -0
  46. package/dist/test/timing-utilities.test.js.map +1 -0
  47. package/dist/types.d.ts +93 -0
  48. package/dist/types.d.ts.map +1 -0
  49. package/dist/types.js +78 -0
  50. package/dist/types.js.map +1 -0
  51. package/dist/utils/boundary.d.ts +3 -0
  52. package/dist/utils/boundary.d.ts.map +1 -1
  53. package/dist/utils/boundary.js +11 -2
  54. package/dist/utils/boundary.js.map +1 -1
  55. package/package.json +3 -2
  56. package/src/index.ts +63 -8
  57. package/src/test/ToDos.md +79 -0
  58. package/src/test/add-listener-with-boundaries.test.ts +78 -7
  59. package/src/test/add-listener.test.ts +36 -0
  60. package/src/test/boundary-modes.test.ts +45 -5
  61. package/src/test/execution-record-boundaries.test.ts +12 -2
  62. package/src/test/metrics-collection.test.ts +476 -0
  63. package/src/test/performance-edge-cases.test.ts +596 -0
  64. package/src/test/run-boundary.test.ts +27 -3
  65. package/src/test/safe-replay-complex-boundary.test.ts +115 -10
  66. package/src/test/safe-replay.test.ts +35 -5
  67. package/src/test/safe-run.test.ts +46 -4
  68. package/src/test/setmetrics-boundary.test.ts +223 -0
  69. package/src/test/task-with-boundaries.test.ts +71 -5
  70. package/src/test/timing-capture.test.ts +348 -0
  71. package/src/test/timing-utilities.test.ts +145 -0
  72. package/src/types.ts +139 -0
  73. package/src/utils/boundary.ts +15 -2
@@ -37,7 +37,15 @@ describe('Proxy pass mode', function () {
37
37
  },
38
38
  boundariesData: {
39
39
  fetchIncrement: [
40
- { input: [{ value: 5 }], output: 5 }
40
+ {
41
+ input: [{ value: 5 }],
42
+ output: 5,
43
+ timing: {
44
+ startTime: 1000,
45
+ endTime: 1100,
46
+ duration: 100
47
+ }
48
+ }
41
49
  ]
42
50
  },
43
51
  mode: 'proxy-pass'
@@ -62,7 +70,15 @@ describe('Proxy pass mode', function () {
62
70
  },
63
71
  boundariesData: {
64
72
  fetchIncrement: [
65
- { input: [{ value: 6 }], output: 5 }
73
+ {
74
+ input: [{ value: 6 }],
75
+ output: 5,
76
+ timing: {
77
+ startTime: 1000,
78
+ endTime: 1100,
79
+ duration: 100
80
+ }
81
+ }
66
82
  ]
67
83
  },
68
84
  mode: 'proxy-pass'
@@ -90,7 +106,15 @@ describe('Proxy catch mode', function () {
90
106
  },
91
107
  boundariesData: {
92
108
  fetchIncrement: [
93
- { input: [{ value: 5 }], output: 5 }
109
+ {
110
+ input: [{ value: 5 }],
111
+ output: 5,
112
+ timing: {
113
+ startTime: 1000,
114
+ endTime: 1100,
115
+ duration: 100
116
+ }
117
+ }
94
118
  ]
95
119
  },
96
120
  mode: 'proxy-catch'
@@ -115,7 +139,15 @@ describe('Proxy catch mode', function () {
115
139
  },
116
140
  boundariesData: {
117
141
  fetchIncrement: [
118
- { input: [{ value: 5 }], output: 5 }
142
+ {
143
+ input: [{ value: 5 }],
144
+ output: 5,
145
+ timing: {
146
+ startTime: 1000,
147
+ endTime: 1100,
148
+ duration: 100
149
+ }
150
+ }
119
151
  ]
120
152
  },
121
153
  mode: 'proxy-catch'
@@ -143,7 +175,15 @@ describe('Replay mode', function () {
143
175
  },
144
176
  boundariesData: {
145
177
  fetchIncrement: [
146
- { input: [{ value: 5 }], output: 5 }
178
+ {
179
+ input: [{ value: 5 }],
180
+ output: 5,
181
+ timing: {
182
+ startTime: 1000,
183
+ endTime: 1100,
184
+ duration: 100
185
+ }
186
+ }
147
187
  ]
148
188
  },
149
189
  mode: 'replay'
@@ -1 +1 @@
1
- {"version":3,"file":"boundary-modes.test.js","sourceRoot":"","sources":["../../src/test/boundary-modes.test.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"boundary-modes.test.js","sourceRoot":"","sources":["../../src/test/boundary-modes.test.ts"],"names":[],"mappings":"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"}
@@ -77,12 +77,22 @@ describe('execution-record-boundaries', () => {
77
77
  expect(record.boundaries.multiply).toHaveLength(1);
78
78
  expect(record.boundaries.multiply[0]).toEqual({
79
79
  input: [3],
80
- output: 6
80
+ output: 6,
81
+ timing: expect.objectContaining({
82
+ startTime: expect.any(Number),
83
+ endTime: expect.any(Number),
84
+ duration: expect.any(Number)
85
+ })
81
86
  });
82
87
  expect(record.boundaries.fetchData).toHaveLength(1);
83
88
  expect(record.boundaries.fetchData[0]).toEqual({
84
89
  input: ['test'],
85
- output: 'fetched-test'
90
+ output: 'fetched-test',
91
+ timing: expect.objectContaining({
92
+ startTime: expect.any(Number),
93
+ endTime: expect.any(Number),
94
+ duration: expect.any(Number)
95
+ })
86
96
  });
87
97
  });
88
98
  it('should preserve metadata in error scenarios', async () => {
@@ -1 +1 @@
1
- {"version":3,"file":"execution-record-boundaries.test.js","sourceRoot":"","sources":["../../src/test/execution-record-boundaries.test.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"execution-record-boundaries.test.js","sourceRoot":"","sources":["../../src/test/execution-record-boundaries.test.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=integration-enhanced-records.test.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"integration-enhanced-records.test.d.ts","sourceRoot":"","sources":["../../src/test/integration-enhanced-records.test.ts"],"names":[],"mappings":""}
@@ -0,0 +1,467 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ const index_1 = require("../index");
4
+ const schema_1 = require("@forgehive/schema");
5
+ describe('Integration Tests for Enhanced Execution Records', () => {
6
+ describe('Complete task execution with timing and metrics', () => {
7
+ it('should create comprehensive execution record with all enhanced fields', async () => {
8
+ var _a, _b;
9
+ const task = (0, index_1.createTask)({
10
+ name: 'comprehensive-integration-test',
11
+ description: 'Test task for comprehensive execution record validation',
12
+ schema: new schema_1.Schema({
13
+ userId: schema_1.Schema.string(),
14
+ operations: schema_1.Schema.array(schema_1.Schema.string()),
15
+ enableMetrics: schema_1.Schema.boolean().optional()
16
+ }),
17
+ boundaries: {
18
+ fetchUser: async (userId) => {
19
+ // Simulate API delay
20
+ await new Promise(resolve => setTimeout(resolve, 50));
21
+ return { id: userId, name: `User-${userId}`, active: true };
22
+ },
23
+ processData: async (data) => {
24
+ // Simulate processing delay
25
+ await new Promise(resolve => setTimeout(resolve, 30));
26
+ return data.toUpperCase();
27
+ },
28
+ saveResult: async (_result) => {
29
+ // Simulate save delay
30
+ await new Promise(resolve => setTimeout(resolve, 20));
31
+ return { saved: true, id: `result-${Date.now()}` };
32
+ }
33
+ },
34
+ fn: async ({ userId, operations, enableMetrics = true }, { fetchUser, processData, saveResult, setMetrics, setMetadata }) => {
35
+ const startTime = Date.now();
36
+ // Set metadata
37
+ await setMetadata('userId', userId);
38
+ await setMetadata('operationCount', operations.length.toString());
39
+ await setMetadata('environment', 'integration-test');
40
+ if (enableMetrics) {
41
+ await setMetrics({ type: 'business', name: 'requests', value: 1 });
42
+ await setMetrics({ type: 'business', name: 'input_operations', value: operations.length });
43
+ }
44
+ // Fetch user data
45
+ const user = await fetchUser(userId);
46
+ if (enableMetrics) {
47
+ await setMetrics({ type: 'performance', name: 'user_fetch_time', value: 50 });
48
+ }
49
+ // Process each operation
50
+ const processedResults = [];
51
+ for (const operation of operations) {
52
+ const processed = await processData(operation);
53
+ processedResults.push(processed);
54
+ if (enableMetrics) {
55
+ await setMetrics({ type: 'business', name: 'operations_processed', value: 1 });
56
+ }
57
+ }
58
+ // Save results
59
+ const saveResult_ = await saveResult({ user, processed: processedResults });
60
+ const totalTime = Date.now() - startTime;
61
+ if (enableMetrics) {
62
+ await setMetrics({ type: 'performance', name: 'total_execution_time', value: totalTime });
63
+ await setMetrics({ type: 'error', name: 'errors_encountered', value: 0 });
64
+ }
65
+ return {
66
+ user,
67
+ processedOperations: processedResults,
68
+ saveResult: saveResult_,
69
+ executionTime: totalTime
70
+ };
71
+ }
72
+ });
73
+ const [result, error, record] = await task.safeRun({
74
+ userId: 'test-user-123',
75
+ operations: ['operation1', 'operation2', 'operation3'],
76
+ enableMetrics: true
77
+ });
78
+ // Validate successful execution
79
+ expect(error).toBeNull();
80
+ expect(result).not.toBeNull();
81
+ expect(result === null || result === void 0 ? void 0 : result.user).toEqual({ id: 'test-user-123', name: 'User-test-user-123', active: true });
82
+ expect(result === null || result === void 0 ? void 0 : result.processedOperations).toEqual(['OPERATION1', 'OPERATION2', 'OPERATION3']);
83
+ expect(result === null || result === void 0 ? void 0 : result.saveResult.saved).toBe(true);
84
+ // Validate enhanced execution record structure
85
+ expect(record).toEqual(expect.objectContaining({
86
+ input: expect.any(Object),
87
+ output: expect.any(Object),
88
+ boundaries: expect.any(Object),
89
+ taskName: 'comprehensive-integration-test',
90
+ metadata: expect.any(Object),
91
+ metrics: expect.any(Array),
92
+ timing: expect.any(Object),
93
+ type: 'success'
94
+ }));
95
+ // Validate timing information
96
+ expect(record.timing).toEqual(expect.objectContaining({
97
+ startTime: expect.any(Number),
98
+ endTime: expect.any(Number),
99
+ duration: expect.any(Number)
100
+ }));
101
+ expect((_a = record.timing) === null || _a === void 0 ? void 0 : _a.duration).toBeGreaterThanOrEqual(100); // Should take at least 100ms total
102
+ expect((_b = record.timing) === null || _b === void 0 ? void 0 : _b.duration).toBeLessThan(300); // But not too long
103
+ // Validate metrics collection
104
+ expect(record.metrics).toHaveLength(8); // 2 + 3 + 3 = 8 metrics
105
+ expect(record.metrics).toEqual(expect.arrayContaining([
106
+ { type: 'business', name: 'requests', value: 1 },
107
+ { type: 'business', name: 'input_operations', value: 3 },
108
+ { type: 'performance', name: 'user_fetch_time', value: 50 },
109
+ { type: 'business', name: 'operations_processed', value: 1 },
110
+ { type: 'performance', name: 'total_execution_time', value: expect.any(Number) },
111
+ { type: 'error', name: 'errors_encountered', value: 0 }
112
+ ]));
113
+ // Validate metadata
114
+ expect(record.metadata).toEqual(expect.objectContaining({
115
+ userId: 'test-user-123',
116
+ operationCount: '3',
117
+ environment: 'integration-test'
118
+ }));
119
+ // Validate boundary timing
120
+ expect(record.boundaries.fetchUser).toHaveLength(1);
121
+ expect(record.boundaries.fetchUser[0]).toEqual(expect.objectContaining({
122
+ input: ['test-user-123'],
123
+ output: { id: 'test-user-123', name: 'User-test-user-123', active: true },
124
+ timing: expect.objectContaining({
125
+ startTime: expect.any(Number),
126
+ endTime: expect.any(Number),
127
+ duration: expect.any(Number)
128
+ })
129
+ }));
130
+ expect(record.boundaries.processData).toHaveLength(3);
131
+ record.boundaries.processData.forEach((call, index) => {
132
+ expect(call).toEqual(expect.objectContaining({
133
+ input: [['operation1', 'operation2', 'operation3'][index]],
134
+ output: ['OPERATION1', 'OPERATION2', 'OPERATION3'][index],
135
+ timing: expect.objectContaining({
136
+ startTime: expect.any(Number),
137
+ endTime: expect.any(Number),
138
+ duration: expect.any(Number)
139
+ })
140
+ }));
141
+ });
142
+ expect(record.boundaries.saveResult).toHaveLength(1);
143
+ expect(record.boundaries.saveResult[0]).toEqual(expect.objectContaining({
144
+ input: expect.any(Array),
145
+ output: expect.objectContaining({ saved: true }),
146
+ timing: expect.objectContaining({
147
+ startTime: expect.any(Number),
148
+ endTime: expect.any(Number),
149
+ duration: expect.any(Number)
150
+ })
151
+ }));
152
+ });
153
+ it('should handle error scenarios with complete execution record', async () => {
154
+ const task = (0, index_1.createTask)({
155
+ name: 'error-integration-test',
156
+ schema: new schema_1.Schema({ shouldFail: schema_1.Schema.boolean(), failAt: schema_1.Schema.string() }),
157
+ boundaries: {
158
+ operation1: async () => {
159
+ await new Promise(resolve => setTimeout(resolve, 20));
160
+ return 'op1-success';
161
+ },
162
+ operation2: async (shouldFail) => {
163
+ await new Promise(resolve => setTimeout(resolve, 30));
164
+ if (shouldFail) {
165
+ throw new Error('Operation 2 failed');
166
+ }
167
+ return 'op2-success';
168
+ }
169
+ },
170
+ fn: async ({ shouldFail, failAt }, { operation1, operation2, setMetrics, setMetadata }) => {
171
+ await setMetadata('testType', 'error-handling');
172
+ await setMetrics({ type: 'business', name: 'test_runs', value: 1 });
173
+ const result1 = await operation1();
174
+ await setMetrics({ type: 'business', name: 'op1_completed', value: 1 });
175
+ if (failAt === 'main') {
176
+ await setMetrics({ type: 'error', name: 'main_function_errors', value: 1 });
177
+ throw new Error('Main function error');
178
+ }
179
+ const result2 = await operation2(shouldFail);
180
+ await setMetrics({ type: 'business', name: 'op2_completed', value: 1 });
181
+ return { result1, result2 };
182
+ }
183
+ });
184
+ // Test boundary error
185
+ const [result1, error1, record1] = await task.safeRun({ shouldFail: true, failAt: 'boundary' });
186
+ expect(result1).toBeNull();
187
+ expect(error1).not.toBeNull();
188
+ expect(record1.type).toBe('error');
189
+ expect(record1.timing).toBeDefined(); // Should have timing even on error
190
+ expect(record1.metrics).toEqual(expect.arrayContaining([
191
+ { type: 'business', name: 'test_runs', value: 1 },
192
+ { type: 'business', name: 'op1_completed', value: 1 }
193
+ ]));
194
+ expect(record1.boundaries.operation1).toHaveLength(1);
195
+ expect(record1.boundaries.operation2).toHaveLength(1);
196
+ expect('error' in record1.boundaries.operation2[0]).toBe(true);
197
+ // Test main function error
198
+ const [result2, error2, record2] = await task.safeRun({ shouldFail: false, failAt: 'main' });
199
+ expect(result2).toBeNull();
200
+ expect(error2).not.toBeNull();
201
+ expect(record2.type).toBe('error');
202
+ expect(record2.timing).toBeDefined();
203
+ expect(record2.metrics).toEqual(expect.arrayContaining([
204
+ { type: 'business', name: 'test_runs', value: 1 },
205
+ { type: 'business', name: 'op1_completed', value: 1 },
206
+ { type: 'error', name: 'main_function_errors', value: 1 }
207
+ ]));
208
+ });
209
+ });
210
+ describe('Cross-package compatibility between task and hive-sdk', () => {
211
+ it('should maintain type compatibility with hive-sdk ExecutionRecord', async () => {
212
+ // This test ensures that ExecutionRecord from task package is compatible with hive-sdk
213
+ const task = (0, index_1.createTask)({
214
+ name: 'hive-sdk-compatibility-test',
215
+ schema: new schema_1.Schema({ testData: schema_1.Schema.string() }),
216
+ boundaries: {
217
+ mockApi: async (data) => {
218
+ await new Promise(resolve => setTimeout(resolve, 25));
219
+ return { processed: data, timestamp: Date.now() };
220
+ }
221
+ },
222
+ fn: async ({ testData }, { mockApi, setMetrics, setMetadata }) => {
223
+ await setMetadata('source', 'compatibility-test');
224
+ await setMetadata('version', '1.0.0');
225
+ await setMetrics({ type: 'business', name: 'api_calls', value: 1 });
226
+ const result = await mockApi(testData);
227
+ await setMetrics({ type: 'performance', name: 'api_response_time', value: 25 });
228
+ return { result, completed: true };
229
+ }
230
+ });
231
+ const [result, error, record] = await task.safeRun({ testData: 'compatibility-test-data' });
232
+ expect(error).toBeNull();
233
+ expect(result).not.toBeNull();
234
+ // Verify the record has all the fields expected by hive-sdk
235
+ expect(record).toEqual(expect.objectContaining({
236
+ input: expect.any(Object),
237
+ output: expect.any(Object),
238
+ boundaries: expect.any(Object),
239
+ taskName: expect.any(String),
240
+ metadata: expect.any(Object),
241
+ type: expect.stringMatching(/^(success|error|pending)$/)
242
+ }));
243
+ // Verify enhanced fields are present
244
+ expect(record.timing).toBeDefined();
245
+ expect(record.metrics).toBeDefined();
246
+ expect(Array.isArray(record.metrics)).toBe(true);
247
+ // Simulate what hive-sdk would do - serialize and parse the record
248
+ const serialized = JSON.stringify(record);
249
+ const parsed = JSON.parse(serialized);
250
+ // Verify serialization preserves all fields
251
+ expect(parsed.input).toEqual(record.input);
252
+ expect(parsed.output).toEqual(record.output);
253
+ expect(parsed.boundaries).toEqual(record.boundaries);
254
+ expect(parsed.taskName).toBe(record.taskName);
255
+ expect(parsed.metadata).toEqual(record.metadata);
256
+ expect(parsed.metrics).toEqual(record.metrics);
257
+ expect(parsed.timing).toEqual(record.timing);
258
+ expect(parsed.type).toBe(record.type);
259
+ });
260
+ it('should work with hive-sdk style metadata merging', async () => {
261
+ const task = (0, index_1.createTask)({
262
+ name: 'metadata-merging-test',
263
+ schema: new schema_1.Schema({ input: schema_1.Schema.string() }),
264
+ boundaries: {},
265
+ fn: async ({ input }, { setMetadata, setMetrics }) => {
266
+ await setMetadata('taskLevel', 'metadata');
267
+ await setMetadata('priority', 'high');
268
+ await setMetrics({ type: 'business', name: 'executions', value: 1 });
269
+ return { processed: input };
270
+ }
271
+ });
272
+ const [result, error, record] = await task.safeRun({ input: 'test' });
273
+ expect(error).toBeNull();
274
+ expect(result).toEqual({ processed: 'test' });
275
+ // Simulate hive-sdk metadata merging behavior
276
+ const clientMetadata = { environment: 'test', version: '1.0' };
277
+ const sendLogMetadata = { requestId: 'req-123', userId: 'user-456' };
278
+ const mergedMetadata = Object.assign(Object.assign(Object.assign({}, clientMetadata), record.metadata), sendLogMetadata);
279
+ expect(mergedMetadata).toEqual({
280
+ environment: 'test',
281
+ version: '1.0',
282
+ taskLevel: 'metadata',
283
+ priority: 'high',
284
+ requestId: 'req-123',
285
+ userId: 'user-456'
286
+ });
287
+ // Verify the complete record structure that would be sent to hive-sdk
288
+ const hiveRecord = Object.assign(Object.assign({}, record), { metadata: mergedMetadata });
289
+ expect(hiveRecord).toEqual(expect.objectContaining({
290
+ input: { input: 'test' },
291
+ output: { processed: 'test' },
292
+ taskName: 'metadata-merging-test',
293
+ metadata: mergedMetadata,
294
+ metrics: [{ type: 'business', name: 'executions', value: 1 }],
295
+ timing: expect.any(Object),
296
+ type: 'success'
297
+ }));
298
+ });
299
+ });
300
+ describe('Serialization and deserialization of enhanced execution records', () => {
301
+ it('should properly serialize and deserialize complete execution records', async () => {
302
+ const task = (0, index_1.createTask)({
303
+ name: 'serialization-test',
304
+ schema: new schema_1.Schema({
305
+ values: schema_1.Schema.array(schema_1.Schema.number()),
306
+ metadataType: schema_1.Schema.string()
307
+ }),
308
+ boundaries: {
309
+ processArray: async (values) => {
310
+ await new Promise(resolve => setTimeout(resolve, 40));
311
+ return values.map(v => v * 2);
312
+ },
313
+ validateData: async (data) => {
314
+ await new Promise(resolve => setTimeout(resolve, 20));
315
+ return data.values.every((v) => v > 0);
316
+ }
317
+ },
318
+ fn: async ({ values, metadataType }, { processArray, validateData, setMetrics, setMetadata }) => {
319
+ await setMetadata('dataType', metadataType);
320
+ await setMetadata('arrayLength', values.length.toString());
321
+ await setMetrics({ type: 'business', name: 'data_processed', value: 1 });
322
+ await setMetrics({ type: 'business', name: 'array_size', value: values.length });
323
+ const data = { values, metadata: { type: metadataType } };
324
+ const isValid = await validateData(data);
325
+ await setMetrics({ type: 'business', name: 'validation_result', value: isValid ? 1 : 0 });
326
+ const processed = await processArray(values);
327
+ await setMetrics({ type: 'performance', name: 'processing_time', value: 40 });
328
+ return { processed, valid: isValid, originalData: data };
329
+ }
330
+ });
331
+ const inputData = {
332
+ values: [1, 2, 3, 4, 5],
333
+ metadataType: 'numeric-array'
334
+ };
335
+ const [result, error, record] = await task.safeRun(inputData);
336
+ expect(error).toBeNull();
337
+ expect(result).not.toBeNull();
338
+ // Serialize the complete record
339
+ const serialized = JSON.stringify(record);
340
+ expect(typeof serialized).toBe('string');
341
+ expect(serialized.length).toBeGreaterThan(0);
342
+ // Deserialize and verify all fields are preserved
343
+ const deserialized = JSON.parse(serialized);
344
+ // Verify basic structure
345
+ expect(deserialized.input).toEqual(inputData);
346
+ expect(deserialized.output).toEqual(result);
347
+ expect(deserialized.type).toBe('success');
348
+ expect(deserialized.taskName).toBe('serialization-test');
349
+ // Verify metadata
350
+ expect(deserialized.metadata).toEqual({
351
+ dataType: 'numeric-array',
352
+ arrayLength: '5'
353
+ });
354
+ // Verify metrics
355
+ expect(deserialized.metrics).toHaveLength(4);
356
+ expect(deserialized.metrics).toEqual(expect.arrayContaining([
357
+ { type: 'business', name: 'data_processed', value: 1 },
358
+ { type: 'business', name: 'array_size', value: 5 },
359
+ { type: 'business', name: 'validation_result', value: 1 },
360
+ { type: 'performance', name: 'processing_time', value: 40 }
361
+ ]));
362
+ // Verify timing
363
+ expect(deserialized.timing).toEqual(expect.objectContaining({
364
+ startTime: expect.any(Number),
365
+ endTime: expect.any(Number),
366
+ duration: expect.any(Number)
367
+ }));
368
+ // Verify boundary data with timing
369
+ expect(deserialized.boundaries.processArray).toHaveLength(1);
370
+ expect(deserialized.boundaries.processArray[0]).toEqual(expect.objectContaining({
371
+ input: [[1, 2, 3, 4, 5]],
372
+ output: [2, 4, 6, 8, 10],
373
+ timing: expect.objectContaining({
374
+ startTime: expect.any(Number),
375
+ endTime: expect.any(Number),
376
+ duration: expect.any(Number)
377
+ })
378
+ }));
379
+ expect(deserialized.boundaries.validateData).toHaveLength(1);
380
+ expect(deserialized.boundaries.validateData[0]).toEqual(expect.objectContaining({
381
+ input: [{ values: inputData.values, metadata: { type: inputData.metadataType } }],
382
+ output: true,
383
+ timing: expect.objectContaining({
384
+ startTime: expect.any(Number),
385
+ endTime: expect.any(Number),
386
+ duration: expect.any(Number)
387
+ })
388
+ }));
389
+ });
390
+ it('should handle serialization of records with complex boundary data', async () => {
391
+ const task = (0, index_1.createTask)({
392
+ name: 'complex-serialization-test',
393
+ schema: new schema_1.Schema({ requests: schema_1.Schema.array(schema_1.Schema.string()) }),
394
+ boundaries: {
395
+ fetchData: async (request) => {
396
+ await new Promise(resolve => setTimeout(resolve, 15));
397
+ return {
398
+ id: request,
399
+ data: { items: [1, 2, 3], nested: { value: request.length } },
400
+ timestamp: Date.now()
401
+ };
402
+ },
403
+ aggregateResults: async (results) => {
404
+ await new Promise(resolve => setTimeout(resolve, 25));
405
+ return {
406
+ totalItems: results.reduce((sum, r) => sum + r.data.items.length, 0),
407
+ resultCount: results.length,
408
+ summary: { processed: true, avgValue: 2 }
409
+ };
410
+ }
411
+ },
412
+ fn: async ({ requests }, { fetchData, aggregateResults, setMetrics }) => {
413
+ await setMetrics({ type: 'business', name: 'batch_size', value: requests.length });
414
+ const results = [];
415
+ for (const request of requests) {
416
+ const data = await fetchData(request);
417
+ results.push(data);
418
+ await setMetrics({ type: 'business', name: 'items_fetched', value: data.data.items.length });
419
+ }
420
+ const aggregated = await aggregateResults(results);
421
+ await setMetrics({ type: 'performance', name: 'aggregation_score', value: aggregated.summary.avgValue });
422
+ return { results, aggregated };
423
+ }
424
+ });
425
+ const [result, error, record] = await task.safeRun({
426
+ requests: ['req1', 'req2', 'req3']
427
+ });
428
+ expect(error).toBeNull();
429
+ expect(result).not.toBeNull();
430
+ // Serialize and deserialize
431
+ const serialized = JSON.stringify(record);
432
+ const deserialized = JSON.parse(serialized);
433
+ // Verify complex nested data structures are preserved
434
+ expect(deserialized.boundaries.fetchData).toHaveLength(3);
435
+ deserialized.boundaries.fetchData.forEach((call, index) => {
436
+ expect(call.output).toEqual(expect.objectContaining({
437
+ id: `req${index + 1}`,
438
+ data: { items: [1, 2, 3], nested: { value: 4 } },
439
+ timestamp: expect.any(Number)
440
+ }));
441
+ expect(call.timing).toEqual(expect.objectContaining({
442
+ startTime: expect.any(Number),
443
+ endTime: expect.any(Number),
444
+ duration: expect.any(Number)
445
+ }));
446
+ });
447
+ expect(deserialized.boundaries.aggregateResults).toHaveLength(1);
448
+ expect(deserialized.boundaries.aggregateResults[0].output).toEqual({
449
+ totalItems: 9,
450
+ resultCount: 3,
451
+ summary: { processed: true, avgValue: 2 }
452
+ });
453
+ // Verify that the deserialized record could be used for replay
454
+ expect(deserialized).toEqual(expect.objectContaining({
455
+ input: expect.any(Object),
456
+ output: expect.any(Object),
457
+ boundaries: expect.any(Object),
458
+ taskName: expect.any(String),
459
+ metadata: expect.any(Object),
460
+ metrics: expect.any(Array),
461
+ timing: expect.any(Object),
462
+ type: 'success'
463
+ }));
464
+ });
465
+ });
466
+ });
467
+ //# sourceMappingURL=integration-enhanced-records.test.js.map