@rivetkit/workflow-engine 0.0.0-pr.4600.08e570f
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/dist/schemas/v1.ts +781 -0
- package/dist/tsup/chunk-4SWXLWKL.cjs +4180 -0
- package/dist/tsup/chunk-4SWXLWKL.cjs.map +1 -0
- package/dist/tsup/chunk-UMFB2AR3.js +4180 -0
- package/dist/tsup/chunk-UMFB2AR3.js.map +1 -0
- package/dist/tsup/index.cjs +93 -0
- package/dist/tsup/index.cjs.map +1 -0
- package/dist/tsup/index.d.cts +1009 -0
- package/dist/tsup/index.d.ts +1009 -0
- package/dist/tsup/index.js +93 -0
- package/dist/tsup/index.js.map +1 -0
- package/dist/tsup/testing.cjs +328 -0
- package/dist/tsup/testing.cjs.map +1 -0
- package/dist/tsup/testing.d.cts +53 -0
- package/dist/tsup/testing.d.ts +53 -0
- package/dist/tsup/testing.js +328 -0
- package/dist/tsup/testing.js.map +1 -0
- package/package.json +70 -0
- package/schemas/serde.ts +609 -0
- package/schemas/v1.bare +203 -0
- package/schemas/versioned.ts +107 -0
- package/src/context.ts +2585 -0
- package/src/driver.ts +108 -0
- package/src/error-utils.ts +87 -0
- package/src/errors.ts +171 -0
- package/src/index.ts +1075 -0
- package/src/keys.ts +303 -0
- package/src/location.ts +171 -0
- package/src/storage.ts +417 -0
- package/src/testing.ts +313 -0
- package/src/types.ts +623 -0
- package/src/utils.ts +48 -0
|
@@ -0,0 +1,93 @@
|
|
|
1
|
+
import {
|
|
2
|
+
CancelledError,
|
|
3
|
+
CriticalError,
|
|
4
|
+
DEFAULT_LOOP_HISTORY_PRUNE_INTERVAL,
|
|
5
|
+
DEFAULT_MAX_RETRIES,
|
|
6
|
+
DEFAULT_RETRY_BACKOFF_BASE,
|
|
7
|
+
DEFAULT_RETRY_BACKOFF_MAX,
|
|
8
|
+
DEFAULT_STEP_TIMEOUT,
|
|
9
|
+
EntryInProgressError,
|
|
10
|
+
EvictedError,
|
|
11
|
+
HistoryDivergedError,
|
|
12
|
+
JoinError,
|
|
13
|
+
Loop,
|
|
14
|
+
MessageWaitError,
|
|
15
|
+
RaceError,
|
|
16
|
+
RollbackCheckpointError,
|
|
17
|
+
RollbackError,
|
|
18
|
+
SleepError,
|
|
19
|
+
StepExhaustedError,
|
|
20
|
+
StepFailedError,
|
|
21
|
+
WorkflowContextImpl,
|
|
22
|
+
appendLoopIteration,
|
|
23
|
+
appendName,
|
|
24
|
+
createEntry,
|
|
25
|
+
createHistorySnapshot,
|
|
26
|
+
createStorage,
|
|
27
|
+
deleteEntriesWithPrefix,
|
|
28
|
+
emptyLocation,
|
|
29
|
+
extractErrorInfo,
|
|
30
|
+
flush,
|
|
31
|
+
generateId,
|
|
32
|
+
getEntry,
|
|
33
|
+
getOrCreateMetadata,
|
|
34
|
+
isLocationPrefix,
|
|
35
|
+
isLoopIterationMarker,
|
|
36
|
+
loadMetadata,
|
|
37
|
+
loadStorage,
|
|
38
|
+
locationToKey,
|
|
39
|
+
locationsEqual,
|
|
40
|
+
parentLocation,
|
|
41
|
+
registerName,
|
|
42
|
+
replayWorkflowFromStep,
|
|
43
|
+
resolveName,
|
|
44
|
+
runWorkflow,
|
|
45
|
+
setEntry
|
|
46
|
+
} from "./chunk-UMFB2AR3.js";
|
|
47
|
+
export {
|
|
48
|
+
CancelledError,
|
|
49
|
+
CriticalError,
|
|
50
|
+
DEFAULT_LOOP_HISTORY_PRUNE_INTERVAL,
|
|
51
|
+
DEFAULT_MAX_RETRIES,
|
|
52
|
+
DEFAULT_RETRY_BACKOFF_BASE,
|
|
53
|
+
DEFAULT_RETRY_BACKOFF_MAX,
|
|
54
|
+
DEFAULT_STEP_TIMEOUT,
|
|
55
|
+
EntryInProgressError,
|
|
56
|
+
EvictedError,
|
|
57
|
+
HistoryDivergedError,
|
|
58
|
+
JoinError,
|
|
59
|
+
Loop,
|
|
60
|
+
MessageWaitError,
|
|
61
|
+
RaceError,
|
|
62
|
+
RollbackCheckpointError,
|
|
63
|
+
RollbackError,
|
|
64
|
+
SleepError,
|
|
65
|
+
StepExhaustedError,
|
|
66
|
+
StepFailedError,
|
|
67
|
+
WorkflowContextImpl,
|
|
68
|
+
appendLoopIteration,
|
|
69
|
+
appendName,
|
|
70
|
+
createEntry,
|
|
71
|
+
createHistorySnapshot,
|
|
72
|
+
createStorage,
|
|
73
|
+
deleteEntriesWithPrefix,
|
|
74
|
+
emptyLocation,
|
|
75
|
+
extractErrorInfo,
|
|
76
|
+
flush,
|
|
77
|
+
generateId,
|
|
78
|
+
getEntry,
|
|
79
|
+
getOrCreateMetadata,
|
|
80
|
+
isLocationPrefix,
|
|
81
|
+
isLoopIterationMarker,
|
|
82
|
+
loadMetadata,
|
|
83
|
+
loadStorage,
|
|
84
|
+
locationToKey,
|
|
85
|
+
locationsEqual,
|
|
86
|
+
parentLocation,
|
|
87
|
+
registerName,
|
|
88
|
+
replayWorkflowFromStep,
|
|
89
|
+
resolveName,
|
|
90
|
+
runWorkflow,
|
|
91
|
+
setEntry
|
|
92
|
+
};
|
|
93
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":[],"sourcesContent":[],"mappings":"","names":[]}
|
|
@@ -0,0 +1,328 @@
|
|
|
1
|
+
"use strict";Object.defineProperty(exports, "__esModule", {value: true}); function _nullishCoalesce(lhs, rhsFn) { if (lhs != null) { return lhs; } else { return rhsFn(); } } var _class;
|
|
2
|
+
|
|
3
|
+
|
|
4
|
+
|
|
5
|
+
|
|
6
|
+
|
|
7
|
+
|
|
8
|
+
|
|
9
|
+
|
|
10
|
+
|
|
11
|
+
|
|
12
|
+
|
|
13
|
+
|
|
14
|
+
|
|
15
|
+
|
|
16
|
+
|
|
17
|
+
|
|
18
|
+
|
|
19
|
+
|
|
20
|
+
|
|
21
|
+
|
|
22
|
+
|
|
23
|
+
|
|
24
|
+
|
|
25
|
+
|
|
26
|
+
|
|
27
|
+
|
|
28
|
+
|
|
29
|
+
|
|
30
|
+
|
|
31
|
+
|
|
32
|
+
|
|
33
|
+
|
|
34
|
+
|
|
35
|
+
|
|
36
|
+
|
|
37
|
+
|
|
38
|
+
|
|
39
|
+
|
|
40
|
+
|
|
41
|
+
|
|
42
|
+
|
|
43
|
+
|
|
44
|
+
|
|
45
|
+
|
|
46
|
+
|
|
47
|
+
|
|
48
|
+
|
|
49
|
+
|
|
50
|
+
var _chunk4SWXLWKLcjs = require('./chunk-4SWXLWKL.cjs');
|
|
51
|
+
|
|
52
|
+
// src/testing.ts
|
|
53
|
+
var InMemoryWorkflowMessageDriver = class {
|
|
54
|
+
#messages = [];
|
|
55
|
+
#waiters = /* @__PURE__ */ new Set();
|
|
56
|
+
async addMessage(message) {
|
|
57
|
+
this.#messages.push(message);
|
|
58
|
+
this.#notifyWaiters(message.name);
|
|
59
|
+
}
|
|
60
|
+
async receiveMessages(opts) {
|
|
61
|
+
const limitedCount = Math.max(1, opts.count);
|
|
62
|
+
const nameSet = opts.names && opts.names.length > 0 ? new Set(opts.names) : void 0;
|
|
63
|
+
const selected = [];
|
|
64
|
+
for (let i = 0; i < this.#messages.length && selected.length < limitedCount; i++) {
|
|
65
|
+
const message = this.#messages[i];
|
|
66
|
+
if (nameSet && !nameSet.has(message.name)) {
|
|
67
|
+
continue;
|
|
68
|
+
}
|
|
69
|
+
selected.push({ message, index: i });
|
|
70
|
+
}
|
|
71
|
+
if (selected.length === 0) {
|
|
72
|
+
return [];
|
|
73
|
+
}
|
|
74
|
+
if (!opts.completable) {
|
|
75
|
+
for (let i = selected.length - 1; i >= 0; i--) {
|
|
76
|
+
this.#messages.splice(selected[i].index, 1);
|
|
77
|
+
}
|
|
78
|
+
return selected.map((entry) => entry.message);
|
|
79
|
+
}
|
|
80
|
+
return selected.map((entry) => {
|
|
81
|
+
const { message } = entry;
|
|
82
|
+
return {
|
|
83
|
+
...message,
|
|
84
|
+
complete: async () => {
|
|
85
|
+
await this.completeMessage(message.id);
|
|
86
|
+
}
|
|
87
|
+
};
|
|
88
|
+
});
|
|
89
|
+
}
|
|
90
|
+
async completeMessage(messageId) {
|
|
91
|
+
const index = this.#messages.findIndex(
|
|
92
|
+
(message) => message.id === messageId
|
|
93
|
+
);
|
|
94
|
+
if (index !== -1) {
|
|
95
|
+
this.#messages.splice(index, 1);
|
|
96
|
+
}
|
|
97
|
+
}
|
|
98
|
+
async waitForMessages(messageNames, abortSignal) {
|
|
99
|
+
if (abortSignal.aborted) {
|
|
100
|
+
throw new (0, _chunk4SWXLWKLcjs.EvictedError)();
|
|
101
|
+
}
|
|
102
|
+
const nameSet = messageNames.length > 0 ? new Set(messageNames) : void 0;
|
|
103
|
+
if (this.#messages.some(
|
|
104
|
+
(message) => nameSet ? nameSet.has(message.name) : true
|
|
105
|
+
)) {
|
|
106
|
+
return;
|
|
107
|
+
}
|
|
108
|
+
await new Promise((resolve, reject) => {
|
|
109
|
+
const waiter = {
|
|
110
|
+
nameSet,
|
|
111
|
+
resolve: () => {
|
|
112
|
+
this.#removeWaiter(waiter);
|
|
113
|
+
resolve();
|
|
114
|
+
},
|
|
115
|
+
reject: (error) => {
|
|
116
|
+
this.#removeWaiter(waiter);
|
|
117
|
+
reject(error);
|
|
118
|
+
},
|
|
119
|
+
abortSignal,
|
|
120
|
+
onAbort: () => {
|
|
121
|
+
waiter.reject(new (0, _chunk4SWXLWKLcjs.EvictedError)());
|
|
122
|
+
}
|
|
123
|
+
};
|
|
124
|
+
abortSignal.addEventListener("abort", waiter.onAbort, {
|
|
125
|
+
once: true
|
|
126
|
+
});
|
|
127
|
+
this.#waiters.add(waiter);
|
|
128
|
+
});
|
|
129
|
+
}
|
|
130
|
+
#removeWaiter(waiter) {
|
|
131
|
+
if (this.#waiters.delete(waiter)) {
|
|
132
|
+
waiter.abortSignal.removeEventListener("abort", waiter.onAbort);
|
|
133
|
+
}
|
|
134
|
+
}
|
|
135
|
+
#notifyWaiters(name) {
|
|
136
|
+
for (const waiter of [...this.#waiters]) {
|
|
137
|
+
if (waiter.nameSet && !waiter.nameSet.has(name)) {
|
|
138
|
+
continue;
|
|
139
|
+
}
|
|
140
|
+
waiter.resolve();
|
|
141
|
+
}
|
|
142
|
+
}
|
|
143
|
+
clear() {
|
|
144
|
+
this.#messages = [];
|
|
145
|
+
for (const waiter of [...this.#waiters]) {
|
|
146
|
+
waiter.reject(new Error("cleared"));
|
|
147
|
+
}
|
|
148
|
+
}
|
|
149
|
+
};
|
|
150
|
+
var InMemoryDriver = (_class = class {constructor() { _class.prototype.__init.call(this);_class.prototype.__init2.call(this);_class.prototype.__init3.call(this);_class.prototype.__init4.call(this);_class.prototype.__init5.call(this); }
|
|
151
|
+
// Map from hex-encoded key to { originalKey, value }
|
|
152
|
+
__init() {this.kv = /* @__PURE__ */ new Map()}
|
|
153
|
+
__init2() {this.alarms = /* @__PURE__ */ new Map()}
|
|
154
|
+
#inMemoryMessageDriver = new InMemoryWorkflowMessageDriver();
|
|
155
|
+
/** Simulated latency per operation (ms) */
|
|
156
|
+
__init3() {this.latency = 10}
|
|
157
|
+
/** How often the worker polls for work */
|
|
158
|
+
__init4() {this.workerPollInterval = 100}
|
|
159
|
+
__init5() {this.messageDriver = this.#inMemoryMessageDriver}
|
|
160
|
+
async get(key) {
|
|
161
|
+
await _chunk4SWXLWKLcjs.sleep.call(void 0, this.latency);
|
|
162
|
+
const entry = this.kv.get(_chunk4SWXLWKLcjs.keyToHex.call(void 0, key));
|
|
163
|
+
return _nullishCoalesce((entry == null ? void 0 : entry.value), () => ( null));
|
|
164
|
+
}
|
|
165
|
+
async set(key, value) {
|
|
166
|
+
await _chunk4SWXLWKLcjs.sleep.call(void 0, this.latency);
|
|
167
|
+
this.kv.set(_chunk4SWXLWKLcjs.keyToHex.call(void 0, key), { key, value });
|
|
168
|
+
}
|
|
169
|
+
async delete(key) {
|
|
170
|
+
await _chunk4SWXLWKLcjs.sleep.call(void 0, this.latency);
|
|
171
|
+
this.kv.delete(_chunk4SWXLWKLcjs.keyToHex.call(void 0, key));
|
|
172
|
+
}
|
|
173
|
+
async deletePrefix(prefix) {
|
|
174
|
+
await _chunk4SWXLWKLcjs.sleep.call(void 0, this.latency);
|
|
175
|
+
for (const [hexKey, entry] of this.kv) {
|
|
176
|
+
if (_chunk4SWXLWKLcjs.keyStartsWith.call(void 0, entry.key, prefix)) {
|
|
177
|
+
this.kv.delete(hexKey);
|
|
178
|
+
}
|
|
179
|
+
}
|
|
180
|
+
}
|
|
181
|
+
async deleteRange(start, end) {
|
|
182
|
+
await _chunk4SWXLWKLcjs.sleep.call(void 0, this.latency);
|
|
183
|
+
for (const [hexKey, entry] of this.kv) {
|
|
184
|
+
if (_chunk4SWXLWKLcjs.compareKeys.call(void 0, entry.key, start) >= 0 && _chunk4SWXLWKLcjs.compareKeys.call(void 0, entry.key, end) < 0) {
|
|
185
|
+
this.kv.delete(hexKey);
|
|
186
|
+
}
|
|
187
|
+
}
|
|
188
|
+
}
|
|
189
|
+
async list(prefix) {
|
|
190
|
+
await _chunk4SWXLWKLcjs.sleep.call(void 0, this.latency);
|
|
191
|
+
const results = [];
|
|
192
|
+
for (const entry of this.kv.values()) {
|
|
193
|
+
if (_chunk4SWXLWKLcjs.keyStartsWith.call(void 0, entry.key, prefix)) {
|
|
194
|
+
results.push({ key: entry.key, value: entry.value });
|
|
195
|
+
}
|
|
196
|
+
}
|
|
197
|
+
return results.sort((a, b) => _chunk4SWXLWKLcjs.compareKeys.call(void 0, a.key, b.key));
|
|
198
|
+
}
|
|
199
|
+
async batch(writes) {
|
|
200
|
+
await _chunk4SWXLWKLcjs.sleep.call(void 0, this.latency);
|
|
201
|
+
for (const { key, value } of writes) {
|
|
202
|
+
this.kv.set(_chunk4SWXLWKLcjs.keyToHex.call(void 0, key), { key, value });
|
|
203
|
+
}
|
|
204
|
+
}
|
|
205
|
+
async setAlarm(workflowId, wakeAt) {
|
|
206
|
+
await _chunk4SWXLWKLcjs.sleep.call(void 0, this.latency);
|
|
207
|
+
this.alarms.set(workflowId, wakeAt);
|
|
208
|
+
}
|
|
209
|
+
async clearAlarm(workflowId) {
|
|
210
|
+
await _chunk4SWXLWKLcjs.sleep.call(void 0, this.latency);
|
|
211
|
+
this.alarms.delete(workflowId);
|
|
212
|
+
}
|
|
213
|
+
async waitForMessages(messageNames, abortSignal) {
|
|
214
|
+
const driver = this.messageDriver;
|
|
215
|
+
if (driver.waitForMessages) {
|
|
216
|
+
await driver.waitForMessages(messageNames, abortSignal);
|
|
217
|
+
return;
|
|
218
|
+
}
|
|
219
|
+
while (true) {
|
|
220
|
+
if (abortSignal.aborted) {
|
|
221
|
+
throw new (0, _chunk4SWXLWKLcjs.EvictedError)();
|
|
222
|
+
}
|
|
223
|
+
const messages = await this.messageDriver.receiveMessages({
|
|
224
|
+
names: messageNames.length > 0 ? messageNames : void 0,
|
|
225
|
+
count: 1,
|
|
226
|
+
completable: true
|
|
227
|
+
});
|
|
228
|
+
if (messages.length > 0) {
|
|
229
|
+
return;
|
|
230
|
+
}
|
|
231
|
+
await _chunk4SWXLWKLcjs.sleep.call(void 0, Math.max(1, this.latency));
|
|
232
|
+
}
|
|
233
|
+
}
|
|
234
|
+
/**
|
|
235
|
+
* Get the alarm time for a workflow (for testing).
|
|
236
|
+
*/
|
|
237
|
+
getAlarm(workflowId) {
|
|
238
|
+
return this.alarms.get(workflowId);
|
|
239
|
+
}
|
|
240
|
+
/**
|
|
241
|
+
* Check if any alarms are due and return their workflow IDs.
|
|
242
|
+
*/
|
|
243
|
+
getDueAlarms() {
|
|
244
|
+
const now = Date.now();
|
|
245
|
+
const due = [];
|
|
246
|
+
for (const [workflowId, wakeAt] of this.alarms) {
|
|
247
|
+
if (wakeAt <= now) {
|
|
248
|
+
due.push(workflowId);
|
|
249
|
+
}
|
|
250
|
+
}
|
|
251
|
+
return due;
|
|
252
|
+
}
|
|
253
|
+
/**
|
|
254
|
+
* Clear all data (for testing).
|
|
255
|
+
*/
|
|
256
|
+
clear() {
|
|
257
|
+
this.kv.clear();
|
|
258
|
+
this.alarms.clear();
|
|
259
|
+
this.#inMemoryMessageDriver.clear();
|
|
260
|
+
}
|
|
261
|
+
/**
|
|
262
|
+
* Get a snapshot of all data (for testing/debugging).
|
|
263
|
+
*/
|
|
264
|
+
snapshot() {
|
|
265
|
+
const kvSnapshot = {};
|
|
266
|
+
for (const [hexKey, entry] of this.kv) {
|
|
267
|
+
kvSnapshot[hexKey] = entry.value;
|
|
268
|
+
}
|
|
269
|
+
return {
|
|
270
|
+
kv: kvSnapshot,
|
|
271
|
+
alarms: Object.fromEntries(this.alarms)
|
|
272
|
+
};
|
|
273
|
+
}
|
|
274
|
+
/**
|
|
275
|
+
* Get all hex-encoded keys (for testing).
|
|
276
|
+
*/
|
|
277
|
+
keys() {
|
|
278
|
+
return [...this.kv.keys()];
|
|
279
|
+
}
|
|
280
|
+
}, _class);
|
|
281
|
+
|
|
282
|
+
|
|
283
|
+
|
|
284
|
+
|
|
285
|
+
|
|
286
|
+
|
|
287
|
+
|
|
288
|
+
|
|
289
|
+
|
|
290
|
+
|
|
291
|
+
|
|
292
|
+
|
|
293
|
+
|
|
294
|
+
|
|
295
|
+
|
|
296
|
+
|
|
297
|
+
|
|
298
|
+
|
|
299
|
+
|
|
300
|
+
|
|
301
|
+
|
|
302
|
+
|
|
303
|
+
|
|
304
|
+
|
|
305
|
+
|
|
306
|
+
|
|
307
|
+
|
|
308
|
+
|
|
309
|
+
|
|
310
|
+
|
|
311
|
+
|
|
312
|
+
|
|
313
|
+
|
|
314
|
+
|
|
315
|
+
|
|
316
|
+
|
|
317
|
+
|
|
318
|
+
|
|
319
|
+
|
|
320
|
+
|
|
321
|
+
|
|
322
|
+
|
|
323
|
+
|
|
324
|
+
|
|
325
|
+
|
|
326
|
+
|
|
327
|
+
exports.CancelledError = _chunk4SWXLWKLcjs.CancelledError; exports.CriticalError = _chunk4SWXLWKLcjs.CriticalError; exports.DEFAULT_LOOP_HISTORY_PRUNE_INTERVAL = _chunk4SWXLWKLcjs.DEFAULT_LOOP_HISTORY_PRUNE_INTERVAL; exports.DEFAULT_MAX_RETRIES = _chunk4SWXLWKLcjs.DEFAULT_MAX_RETRIES; exports.DEFAULT_RETRY_BACKOFF_BASE = _chunk4SWXLWKLcjs.DEFAULT_RETRY_BACKOFF_BASE; exports.DEFAULT_RETRY_BACKOFF_MAX = _chunk4SWXLWKLcjs.DEFAULT_RETRY_BACKOFF_MAX; exports.DEFAULT_STEP_TIMEOUT = _chunk4SWXLWKLcjs.DEFAULT_STEP_TIMEOUT; exports.EntryInProgressError = _chunk4SWXLWKLcjs.EntryInProgressError; exports.EvictedError = _chunk4SWXLWKLcjs.EvictedError; exports.HistoryDivergedError = _chunk4SWXLWKLcjs.HistoryDivergedError; exports.InMemoryDriver = InMemoryDriver; exports.JoinError = _chunk4SWXLWKLcjs.JoinError; exports.Loop = _chunk4SWXLWKLcjs.Loop; exports.MessageWaitError = _chunk4SWXLWKLcjs.MessageWaitError; exports.RaceError = _chunk4SWXLWKLcjs.RaceError; exports.RollbackCheckpointError = _chunk4SWXLWKLcjs.RollbackCheckpointError; exports.RollbackError = _chunk4SWXLWKLcjs.RollbackError; exports.SleepError = _chunk4SWXLWKLcjs.SleepError; exports.StepExhaustedError = _chunk4SWXLWKLcjs.StepExhaustedError; exports.StepFailedError = _chunk4SWXLWKLcjs.StepFailedError; exports.WorkflowContextImpl = _chunk4SWXLWKLcjs.WorkflowContextImpl; exports.appendLoopIteration = _chunk4SWXLWKLcjs.appendLoopIteration; exports.appendName = _chunk4SWXLWKLcjs.appendName; exports.createEntry = _chunk4SWXLWKLcjs.createEntry; exports.createHistorySnapshot = _chunk4SWXLWKLcjs.createHistorySnapshot; exports.createStorage = _chunk4SWXLWKLcjs.createStorage; exports.deleteEntriesWithPrefix = _chunk4SWXLWKLcjs.deleteEntriesWithPrefix; exports.emptyLocation = _chunk4SWXLWKLcjs.emptyLocation; exports.extractErrorInfo = _chunk4SWXLWKLcjs.extractErrorInfo; exports.flush = _chunk4SWXLWKLcjs.flush; exports.generateId = _chunk4SWXLWKLcjs.generateId; exports.getEntry = _chunk4SWXLWKLcjs.getEntry; exports.getOrCreateMetadata = _chunk4SWXLWKLcjs.getOrCreateMetadata; exports.isLocationPrefix = _chunk4SWXLWKLcjs.isLocationPrefix; exports.isLoopIterationMarker = _chunk4SWXLWKLcjs.isLoopIterationMarker; exports.loadMetadata = _chunk4SWXLWKLcjs.loadMetadata; exports.loadStorage = _chunk4SWXLWKLcjs.loadStorage; exports.locationToKey = _chunk4SWXLWKLcjs.locationToKey; exports.locationsEqual = _chunk4SWXLWKLcjs.locationsEqual; exports.parentLocation = _chunk4SWXLWKLcjs.parentLocation; exports.registerName = _chunk4SWXLWKLcjs.registerName; exports.replayWorkflowFromStep = _chunk4SWXLWKLcjs.replayWorkflowFromStep; exports.resolveName = _chunk4SWXLWKLcjs.resolveName; exports.runWorkflow = _chunk4SWXLWKLcjs.runWorkflow; exports.setEntry = _chunk4SWXLWKLcjs.setEntry;
|
|
328
|
+
//# sourceMappingURL=testing.cjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["/home/runner/work/rivet/rivet/rivetkit-typescript/packages/workflow-engine/dist/tsup/testing.cjs","../../src/testing.ts"],"names":[],"mappings":"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","file":"/home/runner/work/rivet/rivet/rivetkit-typescript/packages/workflow-engine/dist/tsup/testing.cjs","sourcesContent":[null,"import type { EngineDriver, KVEntry, KVWrite } from \"./driver.js\";\nimport { EvictedError } from \"./errors.js\";\nimport { compareKeys, keyStartsWith, keyToHex } from \"./keys.js\";\nimport type { Message, WorkflowMessageDriver } from \"./types.js\";\nimport { sleep } from \"./utils.js\";\n\ninterface Waiter {\n\tnameSet?: Set<string>;\n\tresolve: () => void;\n\treject: (error: Error) => void;\n\tabortSignal: AbortSignal;\n\tonAbort: () => void;\n}\n\nclass InMemoryWorkflowMessageDriver implements WorkflowMessageDriver {\n\t#messages: Message[] = [];\n\t#waiters = new Set<Waiter>();\n\n\tasync addMessage(message: Message): Promise<void> {\n\t\tthis.#messages.push(message);\n\t\tthis.#notifyWaiters(message.name);\n\t}\n\n\tasync receiveMessages(opts: {\n\t\tnames?: readonly string[];\n\t\tcount: number;\n\t\tcompletable: boolean;\n\t}): Promise<Message[]> {\n\t\tconst limitedCount = Math.max(1, opts.count);\n\t\tconst nameSet =\n\t\t\topts.names && opts.names.length > 0\n\t\t\t\t? new Set(opts.names)\n\t\t\t\t: undefined;\n\t\tconst selected: Array<{ message: Message; index: number }> = [];\n\n\t\tfor (\n\t\t\tlet i = 0;\n\t\t\ti < this.#messages.length && selected.length < limitedCount;\n\t\t\ti++\n\t\t) {\n\t\t\tconst message = this.#messages[i];\n\t\t\tif (nameSet && !nameSet.has(message.name)) {\n\t\t\t\tcontinue;\n\t\t\t}\n\t\t\tselected.push({ message, index: i });\n\t\t}\n\n\t\tif (selected.length === 0) {\n\t\t\treturn [];\n\t\t}\n\n\t\tif (!opts.completable) {\n\t\t\tfor (let i = selected.length - 1; i >= 0; i--) {\n\t\t\t\tthis.#messages.splice(selected[i].index, 1);\n\t\t\t}\n\t\t\treturn selected.map((entry) => entry.message);\n\t\t}\n\n\t\treturn selected.map((entry) => {\n\t\t\tconst { message } = entry;\n\t\t\treturn {\n\t\t\t\t...message,\n\t\t\t\tcomplete: async () => {\n\t\t\t\t\tawait this.completeMessage(message.id);\n\t\t\t\t},\n\t\t\t};\n\t\t});\n\t}\n\n\tasync completeMessage(messageId: string): Promise<void> {\n\t\tconst index = this.#messages.findIndex(\n\t\t\t(message) => message.id === messageId,\n\t\t);\n\t\tif (index !== -1) {\n\t\t\tthis.#messages.splice(index, 1);\n\t\t}\n\t}\n\n\tasync waitForMessages(\n\t\tmessageNames: string[],\n\t\tabortSignal: AbortSignal,\n\t): Promise<void> {\n\t\tif (abortSignal.aborted) {\n\t\t\tthrow new EvictedError();\n\t\t}\n\n\t\tconst nameSet =\n\t\t\tmessageNames.length > 0 ? new Set(messageNames) : undefined;\n\t\tif (\n\t\t\tthis.#messages.some((message) =>\n\t\t\t\tnameSet ? nameSet.has(message.name) : true,\n\t\t\t)\n\t\t) {\n\t\t\treturn;\n\t\t}\n\n\t\tawait new Promise<void>((resolve, reject) => {\n\t\t\tconst waiter: Waiter = {\n\t\t\t\tnameSet,\n\t\t\t\tresolve: () => {\n\t\t\t\t\tthis.#removeWaiter(waiter);\n\t\t\t\t\tresolve();\n\t\t\t\t},\n\t\t\t\treject: (error) => {\n\t\t\t\t\tthis.#removeWaiter(waiter);\n\t\t\t\t\treject(error);\n\t\t\t\t},\n\t\t\t\tabortSignal,\n\t\t\t\tonAbort: () => {\n\t\t\t\t\twaiter.reject(new EvictedError());\n\t\t\t\t},\n\t\t\t};\n\t\t\tabortSignal.addEventListener(\"abort\", waiter.onAbort, {\n\t\t\t\tonce: true,\n\t\t\t});\n\t\t\tthis.#waiters.add(waiter);\n\t\t});\n\t}\n\n\t#removeWaiter(waiter: Waiter): void {\n\t\tif (this.#waiters.delete(waiter)) {\n\t\t\twaiter.abortSignal.removeEventListener(\"abort\", waiter.onAbort);\n\t\t}\n\t}\n\n\t#notifyWaiters(name: string): void {\n\t\tfor (const waiter of [...this.#waiters]) {\n\t\t\tif (waiter.nameSet && !waiter.nameSet.has(name)) {\n\t\t\t\tcontinue;\n\t\t\t}\n\t\t\twaiter.resolve();\n\t\t}\n\t}\n\n\tclear(): void {\n\t\tthis.#messages = [];\n\t\tfor (const waiter of [...this.#waiters]) {\n\t\t\twaiter.reject(new Error(\"cleared\"));\n\t\t}\n\t}\n}\n\n/**\n * In-memory implementation of EngineDriver for testing.\n * Uses binary keys (Uint8Array) with hex encoding for internal Map storage.\n */\nexport class InMemoryDriver implements EngineDriver {\n\t// Map from hex-encoded key to { originalKey, value }\n\tprivate kv = new Map<string, { key: Uint8Array; value: Uint8Array }>();\n\tprivate alarms = new Map<string, number>();\n\t#inMemoryMessageDriver = new InMemoryWorkflowMessageDriver();\n\n\t/** Simulated latency per operation (ms) */\n\tlatency = 10;\n\n\t/** How often the worker polls for work */\n\tworkerPollInterval = 100;\n\tmessageDriver: WorkflowMessageDriver = this.#inMemoryMessageDriver;\n\n\tasync get(key: Uint8Array): Promise<Uint8Array | null> {\n\t\tawait sleep(this.latency);\n\t\tconst entry = this.kv.get(keyToHex(key));\n\t\treturn entry?.value ?? null;\n\t}\n\n\tasync set(key: Uint8Array, value: Uint8Array): Promise<void> {\n\t\tawait sleep(this.latency);\n\t\tthis.kv.set(keyToHex(key), { key, value });\n\t}\n\n\tasync delete(key: Uint8Array): Promise<void> {\n\t\tawait sleep(this.latency);\n\t\tthis.kv.delete(keyToHex(key));\n\t}\n\n\tasync deletePrefix(prefix: Uint8Array): Promise<void> {\n\t\tawait sleep(this.latency);\n\t\tfor (const [hexKey, entry] of this.kv) {\n\t\t\tif (keyStartsWith(entry.key, prefix)) {\n\t\t\t\tthis.kv.delete(hexKey);\n\t\t\t}\n\t\t}\n\t}\n\n\tasync deleteRange(start: Uint8Array, end: Uint8Array): Promise<void> {\n\t\tawait sleep(this.latency);\n\t\tfor (const [hexKey, entry] of this.kv) {\n\t\t\tif (\n\t\t\t\tcompareKeys(entry.key, start) >= 0 &&\n\t\t\t\tcompareKeys(entry.key, end) < 0\n\t\t\t) {\n\t\t\t\tthis.kv.delete(hexKey);\n\t\t\t}\n\t\t}\n\t}\n\n\tasync list(prefix: Uint8Array): Promise<KVEntry[]> {\n\t\tawait sleep(this.latency);\n\t\tconst results: KVEntry[] = [];\n\t\tfor (const entry of this.kv.values()) {\n\t\t\tif (keyStartsWith(entry.key, prefix)) {\n\t\t\t\tresults.push({ key: entry.key, value: entry.value });\n\t\t\t}\n\t\t}\n\t\t// Sort by key lexicographically\n\t\treturn results.sort((a, b) => compareKeys(a.key, b.key));\n\t}\n\n\tasync batch(writes: KVWrite[]): Promise<void> {\n\t\tawait sleep(this.latency);\n\t\tfor (const { key, value } of writes) {\n\t\t\tthis.kv.set(keyToHex(key), { key, value });\n\t\t}\n\t}\n\n\tasync setAlarm(workflowId: string, wakeAt: number): Promise<void> {\n\t\tawait sleep(this.latency);\n\t\tthis.alarms.set(workflowId, wakeAt);\n\t}\n\n\tasync clearAlarm(workflowId: string): Promise<void> {\n\t\tawait sleep(this.latency);\n\t\tthis.alarms.delete(workflowId);\n\t}\n\n\tasync waitForMessages(\n\t\tmessageNames: string[],\n\t\tabortSignal: AbortSignal,\n\t): Promise<void> {\n\t\tconst driver = this.messageDriver as WorkflowMessageDriver & {\n\t\t\twaitForMessages?: (\n\t\t\t\tmessageNames: string[],\n\t\t\t\tabortSignal: AbortSignal,\n\t\t\t) => Promise<void>;\n\t\t};\n\t\tif (driver.waitForMessages) {\n\t\t\tawait driver.waitForMessages(messageNames, abortSignal);\n\t\t\treturn;\n\t\t}\n\n\t\twhile (true) {\n\t\t\tif (abortSignal.aborted) {\n\t\t\t\tthrow new EvictedError();\n\t\t\t}\n\t\t\tconst messages = await this.messageDriver.receiveMessages({\n\t\t\t\tnames: messageNames.length > 0 ? messageNames : undefined,\n\t\t\t\tcount: 1,\n\t\t\t\tcompletable: true,\n\t\t\t});\n\t\t\tif (messages.length > 0) {\n\t\t\t\treturn;\n\t\t\t}\n\t\t\tawait sleep(Math.max(1, this.latency));\n\t\t}\n\t}\n\n\t/**\n\t * Get the alarm time for a workflow (for testing).\n\t */\n\tgetAlarm(workflowId: string): number | undefined {\n\t\treturn this.alarms.get(workflowId);\n\t}\n\n\t/**\n\t * Check if any alarms are due and return their workflow IDs.\n\t */\n\tgetDueAlarms(): string[] {\n\t\tconst now = Date.now();\n\t\tconst due: string[] = [];\n\t\tfor (const [workflowId, wakeAt] of this.alarms) {\n\t\t\tif (wakeAt <= now) {\n\t\t\t\tdue.push(workflowId);\n\t\t\t}\n\t\t}\n\t\treturn due;\n\t}\n\n\t/**\n\t * Clear all data (for testing).\n\t */\n\tclear(): void {\n\t\tthis.kv.clear();\n\t\tthis.alarms.clear();\n\t\tthis.#inMemoryMessageDriver.clear();\n\t}\n\n\t/**\n\t * Get a snapshot of all data (for testing/debugging).\n\t */\n\tsnapshot(): {\n\t\tkv: Record<string, Uint8Array>;\n\t\talarms: Record<string, number>;\n\t} {\n\t\tconst kvSnapshot: Record<string, Uint8Array> = {};\n\t\tfor (const [hexKey, entry] of this.kv) {\n\t\t\tkvSnapshot[hexKey] = entry.value;\n\t\t}\n\t\treturn {\n\t\t\tkv: kvSnapshot,\n\t\t\talarms: Object.fromEntries(this.alarms),\n\t\t};\n\t}\n\n\t/**\n\t * Get all hex-encoded keys (for testing).\n\t */\n\tkeys(): string[] {\n\t\treturn [...this.kv.keys()];\n\t}\n}\n\n// Re-export main exports for convenience\nexport * from \"./index.js\";\n"]}
|
|
@@ -0,0 +1,53 @@
|
|
|
1
|
+
import { EngineDriver, WorkflowMessageDriver, KVEntry, KVWrite } from './index.cjs';
|
|
2
|
+
export { BranchConfig, BranchOutput, BranchStatus, BranchStatusType, CancelledError, CriticalError, DEFAULT_LOOP_HISTORY_PRUNE_INTERVAL, DEFAULT_MAX_RETRIES, DEFAULT_RETRY_BACKOFF_BASE, DEFAULT_RETRY_BACKOFF_MAX, DEFAULT_STEP_TIMEOUT, Entry, EntryInProgressError, EntryKind, EntryKindType, EntryMetadata, EntryStatus, EvictedError, History, HistoryDivergedError, JoinEntry, JoinError, Location, Loop, LoopConfig, LoopEntry, LoopIterationMarker, LoopResult, Message, MessageEntry, MessageWaitError, NameIndex, PathSegment, RaceEntry, RaceError, RemovedEntry, RollbackCheckpointEntry, RollbackCheckpointError, RollbackContextInterface, RollbackError, RunWorkflowOptions, SleepEntry, SleepError, SleepState, StepConfig, StepEntry, StepExhaustedError, StepFailedError, Storage, TryBlockCatchKind, TryBlockConfig, TryBlockFailure, TryBlockResult, TryStepCatchKind, TryStepConfig, TryStepFailure, TryStepResult, WorkflowContextImpl, WorkflowContextInterface, WorkflowEntryMetadataSnapshot, WorkflowError, WorkflowErrorEvent, WorkflowErrorHandler, WorkflowFunction, WorkflowHandle, WorkflowHistoryEntry, WorkflowHistorySnapshot, WorkflowQueue, WorkflowQueueMessage, WorkflowQueueNextBatchOptions, WorkflowQueueNextOptions, WorkflowResult, WorkflowRollbackErrorEvent, WorkflowRunErrorEvent, WorkflowRunMode, WorkflowState, WorkflowStepErrorEvent, appendLoopIteration, appendName, createEntry, createHistorySnapshot, createStorage, deleteEntriesWithPrefix, emptyLocation, extractErrorInfo, flush, generateId, getEntry, getOrCreateMetadata, isLocationPrefix, isLoopIterationMarker, loadMetadata, loadStorage, locationToKey, locationsEqual, parentLocation, registerName, replayWorkflowFromStep, resolveName, runWorkflow, setEntry } from './index.cjs';
|
|
3
|
+
import 'pino';
|
|
4
|
+
|
|
5
|
+
/**
|
|
6
|
+
* In-memory implementation of EngineDriver for testing.
|
|
7
|
+
* Uses binary keys (Uint8Array) with hex encoding for internal Map storage.
|
|
8
|
+
*/
|
|
9
|
+
declare class InMemoryDriver implements EngineDriver {
|
|
10
|
+
#private;
|
|
11
|
+
private kv;
|
|
12
|
+
private alarms;
|
|
13
|
+
/** Simulated latency per operation (ms) */
|
|
14
|
+
latency: number;
|
|
15
|
+
/** How often the worker polls for work */
|
|
16
|
+
workerPollInterval: number;
|
|
17
|
+
messageDriver: WorkflowMessageDriver;
|
|
18
|
+
get(key: Uint8Array): Promise<Uint8Array | null>;
|
|
19
|
+
set(key: Uint8Array, value: Uint8Array): Promise<void>;
|
|
20
|
+
delete(key: Uint8Array): Promise<void>;
|
|
21
|
+
deletePrefix(prefix: Uint8Array): Promise<void>;
|
|
22
|
+
deleteRange(start: Uint8Array, end: Uint8Array): Promise<void>;
|
|
23
|
+
list(prefix: Uint8Array): Promise<KVEntry[]>;
|
|
24
|
+
batch(writes: KVWrite[]): Promise<void>;
|
|
25
|
+
setAlarm(workflowId: string, wakeAt: number): Promise<void>;
|
|
26
|
+
clearAlarm(workflowId: string): Promise<void>;
|
|
27
|
+
waitForMessages(messageNames: string[], abortSignal: AbortSignal): Promise<void>;
|
|
28
|
+
/**
|
|
29
|
+
* Get the alarm time for a workflow (for testing).
|
|
30
|
+
*/
|
|
31
|
+
getAlarm(workflowId: string): number | undefined;
|
|
32
|
+
/**
|
|
33
|
+
* Check if any alarms are due and return their workflow IDs.
|
|
34
|
+
*/
|
|
35
|
+
getDueAlarms(): string[];
|
|
36
|
+
/**
|
|
37
|
+
* Clear all data (for testing).
|
|
38
|
+
*/
|
|
39
|
+
clear(): void;
|
|
40
|
+
/**
|
|
41
|
+
* Get a snapshot of all data (for testing/debugging).
|
|
42
|
+
*/
|
|
43
|
+
snapshot(): {
|
|
44
|
+
kv: Record<string, Uint8Array>;
|
|
45
|
+
alarms: Record<string, number>;
|
|
46
|
+
};
|
|
47
|
+
/**
|
|
48
|
+
* Get all hex-encoded keys (for testing).
|
|
49
|
+
*/
|
|
50
|
+
keys(): string[];
|
|
51
|
+
}
|
|
52
|
+
|
|
53
|
+
export { EngineDriver, InMemoryDriver, KVEntry, KVWrite, WorkflowMessageDriver };
|
|
@@ -0,0 +1,53 @@
|
|
|
1
|
+
import { EngineDriver, WorkflowMessageDriver, KVEntry, KVWrite } from './index.js';
|
|
2
|
+
export { BranchConfig, BranchOutput, BranchStatus, BranchStatusType, CancelledError, CriticalError, DEFAULT_LOOP_HISTORY_PRUNE_INTERVAL, DEFAULT_MAX_RETRIES, DEFAULT_RETRY_BACKOFF_BASE, DEFAULT_RETRY_BACKOFF_MAX, DEFAULT_STEP_TIMEOUT, Entry, EntryInProgressError, EntryKind, EntryKindType, EntryMetadata, EntryStatus, EvictedError, History, HistoryDivergedError, JoinEntry, JoinError, Location, Loop, LoopConfig, LoopEntry, LoopIterationMarker, LoopResult, Message, MessageEntry, MessageWaitError, NameIndex, PathSegment, RaceEntry, RaceError, RemovedEntry, RollbackCheckpointEntry, RollbackCheckpointError, RollbackContextInterface, RollbackError, RunWorkflowOptions, SleepEntry, SleepError, SleepState, StepConfig, StepEntry, StepExhaustedError, StepFailedError, Storage, TryBlockCatchKind, TryBlockConfig, TryBlockFailure, TryBlockResult, TryStepCatchKind, TryStepConfig, TryStepFailure, TryStepResult, WorkflowContextImpl, WorkflowContextInterface, WorkflowEntryMetadataSnapshot, WorkflowError, WorkflowErrorEvent, WorkflowErrorHandler, WorkflowFunction, WorkflowHandle, WorkflowHistoryEntry, WorkflowHistorySnapshot, WorkflowQueue, WorkflowQueueMessage, WorkflowQueueNextBatchOptions, WorkflowQueueNextOptions, WorkflowResult, WorkflowRollbackErrorEvent, WorkflowRunErrorEvent, WorkflowRunMode, WorkflowState, WorkflowStepErrorEvent, appendLoopIteration, appendName, createEntry, createHistorySnapshot, createStorage, deleteEntriesWithPrefix, emptyLocation, extractErrorInfo, flush, generateId, getEntry, getOrCreateMetadata, isLocationPrefix, isLoopIterationMarker, loadMetadata, loadStorage, locationToKey, locationsEqual, parentLocation, registerName, replayWorkflowFromStep, resolveName, runWorkflow, setEntry } from './index.js';
|
|
3
|
+
import 'pino';
|
|
4
|
+
|
|
5
|
+
/**
|
|
6
|
+
* In-memory implementation of EngineDriver for testing.
|
|
7
|
+
* Uses binary keys (Uint8Array) with hex encoding for internal Map storage.
|
|
8
|
+
*/
|
|
9
|
+
declare class InMemoryDriver implements EngineDriver {
|
|
10
|
+
#private;
|
|
11
|
+
private kv;
|
|
12
|
+
private alarms;
|
|
13
|
+
/** Simulated latency per operation (ms) */
|
|
14
|
+
latency: number;
|
|
15
|
+
/** How often the worker polls for work */
|
|
16
|
+
workerPollInterval: number;
|
|
17
|
+
messageDriver: WorkflowMessageDriver;
|
|
18
|
+
get(key: Uint8Array): Promise<Uint8Array | null>;
|
|
19
|
+
set(key: Uint8Array, value: Uint8Array): Promise<void>;
|
|
20
|
+
delete(key: Uint8Array): Promise<void>;
|
|
21
|
+
deletePrefix(prefix: Uint8Array): Promise<void>;
|
|
22
|
+
deleteRange(start: Uint8Array, end: Uint8Array): Promise<void>;
|
|
23
|
+
list(prefix: Uint8Array): Promise<KVEntry[]>;
|
|
24
|
+
batch(writes: KVWrite[]): Promise<void>;
|
|
25
|
+
setAlarm(workflowId: string, wakeAt: number): Promise<void>;
|
|
26
|
+
clearAlarm(workflowId: string): Promise<void>;
|
|
27
|
+
waitForMessages(messageNames: string[], abortSignal: AbortSignal): Promise<void>;
|
|
28
|
+
/**
|
|
29
|
+
* Get the alarm time for a workflow (for testing).
|
|
30
|
+
*/
|
|
31
|
+
getAlarm(workflowId: string): number | undefined;
|
|
32
|
+
/**
|
|
33
|
+
* Check if any alarms are due and return their workflow IDs.
|
|
34
|
+
*/
|
|
35
|
+
getDueAlarms(): string[];
|
|
36
|
+
/**
|
|
37
|
+
* Clear all data (for testing).
|
|
38
|
+
*/
|
|
39
|
+
clear(): void;
|
|
40
|
+
/**
|
|
41
|
+
* Get a snapshot of all data (for testing/debugging).
|
|
42
|
+
*/
|
|
43
|
+
snapshot(): {
|
|
44
|
+
kv: Record<string, Uint8Array>;
|
|
45
|
+
alarms: Record<string, number>;
|
|
46
|
+
};
|
|
47
|
+
/**
|
|
48
|
+
* Get all hex-encoded keys (for testing).
|
|
49
|
+
*/
|
|
50
|
+
keys(): string[];
|
|
51
|
+
}
|
|
52
|
+
|
|
53
|
+
export { EngineDriver, InMemoryDriver, KVEntry, KVWrite, WorkflowMessageDriver };
|