@livestore/utils 0.4.0-dev.1 → 0.4.0-dev.11
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/.tsbuildinfo.json +1 -1
- package/dist/NoopTracer.d.ts.map +1 -1
- package/dist/NoopTracer.js +1 -0
- package/dist/NoopTracer.js.map +1 -1
- package/dist/effect/Effect.d.ts +9 -3
- package/dist/effect/Effect.d.ts.map +1 -1
- package/dist/effect/Effect.js +4 -2
- package/dist/effect/Effect.js.map +1 -1
- package/dist/effect/Error.d.ts +1 -1
- package/dist/effect/Error.js.map +1 -1
- package/dist/effect/Logger.d.ts +4 -1
- package/dist/effect/Logger.d.ts.map +1 -1
- package/dist/effect/Logger.js +12 -3
- package/dist/effect/Logger.js.map +1 -1
- package/dist/effect/OtelTracer.d.ts +5 -0
- package/dist/effect/OtelTracer.d.ts.map +1 -0
- package/dist/effect/OtelTracer.js +8 -0
- package/dist/effect/OtelTracer.js.map +1 -0
- package/dist/effect/RpcClient.d.ts +32 -0
- package/dist/effect/RpcClient.d.ts.map +1 -0
- package/dist/effect/RpcClient.js +149 -0
- package/dist/effect/RpcClient.js.map +1 -0
- package/dist/effect/Schema/index.d.ts +2 -2
- package/dist/effect/Schema/index.d.ts.map +1 -1
- package/dist/effect/Schema/index.js +12 -2
- package/dist/effect/Schema/index.js.map +1 -1
- package/dist/effect/Stream.d.ts +73 -2
- package/dist/effect/Stream.d.ts.map +1 -1
- package/dist/effect/Stream.js +68 -1
- package/dist/effect/Stream.js.map +1 -1
- package/dist/effect/Stream.test.d.ts +2 -0
- package/dist/effect/Stream.test.d.ts.map +1 -0
- package/dist/effect/Stream.test.js +84 -0
- package/dist/effect/Stream.test.js.map +1 -0
- package/dist/effect/SubscriptionRef.d.ts +2 -2
- package/dist/effect/SubscriptionRef.d.ts.map +1 -1
- package/dist/effect/SubscriptionRef.js +6 -1
- package/dist/effect/SubscriptionRef.js.map +1 -1
- package/dist/effect/WebChannel/common.d.ts +1 -1
- package/dist/effect/WebChannel/common.d.ts.map +1 -1
- package/dist/effect/WebSocket.js +1 -1
- package/dist/effect/WebSocket.js.map +1 -1
- package/dist/effect/index.d.ts +17 -11
- package/dist/effect/index.d.ts.map +1 -1
- package/dist/effect/index.js +20 -15
- package/dist/effect/index.js.map +1 -1
- package/dist/global.d.ts +1 -0
- package/dist/global.d.ts.map +1 -1
- package/dist/global.js.map +1 -1
- package/dist/misc.js +1 -1
- package/dist/misc.js.map +1 -1
- package/dist/mod.d.ts +2 -0
- package/dist/mod.d.ts.map +1 -1
- package/dist/mod.js +4 -0
- package/dist/mod.js.map +1 -1
- package/dist/node/ChildProcessRunner/ChildProcessRunner.d.ts.map +1 -1
- package/dist/node/ChildProcessRunner/ChildProcessRunner.js +66 -10
- package/dist/node/ChildProcessRunner/ChildProcessRunner.js.map +1 -1
- package/dist/node/ChildProcessRunner/ChildProcessRunnerTest/ChildProcessRunner.test.js +177 -3
- package/dist/node/ChildProcessRunner/ChildProcessRunnerTest/ChildProcessRunner.test.js.map +1 -1
- package/dist/node/ChildProcessRunner/ChildProcessRunnerTest/schema.d.ts +10 -1
- package/dist/node/ChildProcessRunner/ChildProcessRunnerTest/schema.d.ts.map +1 -1
- package/dist/node/ChildProcessRunner/ChildProcessRunnerTest/schema.js +7 -1
- package/dist/node/ChildProcessRunner/ChildProcessRunnerTest/schema.js.map +1 -1
- package/dist/node/ChildProcessRunner/ChildProcessRunnerTest/serializedWorker.js +13 -3
- package/dist/node/ChildProcessRunner/ChildProcessRunnerTest/serializedWorker.js.map +1 -1
- package/dist/node/ChildProcessRunner/ChildProcessWorker.d.ts +16 -0
- package/dist/node/ChildProcessRunner/ChildProcessWorker.d.ts.map +1 -1
- package/dist/node/ChildProcessRunner/ChildProcessWorker.js +98 -2
- package/dist/node/ChildProcessRunner/ChildProcessWorker.js.map +1 -1
- package/dist/node/mod.d.ts +7 -1
- package/dist/node/mod.d.ts.map +1 -1
- package/dist/node/mod.js +10 -2
- package/dist/node/mod.js.map +1 -1
- package/package.json +42 -41
- package/src/NoopTracer.ts +1 -0
- package/src/effect/Effect.ts +31 -4
- package/src/effect/Error.ts +1 -1
- package/src/effect/Logger.ts +14 -4
- package/src/effect/OtelTracer.ts +11 -0
- package/src/effect/RpcClient.ts +212 -0
- package/src/effect/Schema/index.ts +17 -3
- package/src/effect/Stream.test.ts +127 -0
- package/src/effect/Stream.ts +111 -2
- package/src/effect/SubscriptionRef.ts +14 -2
- package/src/effect/WebChannel/common.ts +1 -1
- package/src/effect/WebSocket.ts +1 -1
- package/src/effect/index.ts +40 -14
- package/src/global.ts +1 -0
- package/src/misc.ts +1 -1
- package/src/mod.ts +9 -0
- package/src/node/ChildProcessRunner/ChildProcessRunner.ts +71 -10
- package/src/node/ChildProcessRunner/ChildProcessRunnerTest/ChildProcessRunner.test.ts +258 -3
- package/src/node/ChildProcessRunner/ChildProcessRunnerTest/schema.ts +14 -1
- package/src/node/ChildProcessRunner/ChildProcessRunnerTest/serializedWorker.ts +16 -3
- package/src/node/ChildProcessRunner/ChildProcessWorker.ts +111 -3
- package/src/node/mod.ts +12 -5
- package/dist/effect/Schema/msgpack.d.ts +0 -3
- package/dist/effect/Schema/msgpack.d.ts.map +0 -1
- package/dist/effect/Schema/msgpack.js +0 -7
- package/dist/effect/Schema/msgpack.js.map +0 -1
- package/src/effect/Schema/msgpack.ts +0 -8
|
@@ -10,6 +10,50 @@ import * as FiberSet from 'effect/FiberSet';
|
|
|
10
10
|
import * as Layer from 'effect/Layer';
|
|
11
11
|
import * as Runtime from 'effect/Runtime';
|
|
12
12
|
import * as Scope from 'effect/Scope';
|
|
13
|
+
// Parent death monitoring setup
|
|
14
|
+
let parentDeathDetectionEnabled = false;
|
|
15
|
+
let parentDeathTimer = null;
|
|
16
|
+
const stopParentDeathMonitoring = () => {
|
|
17
|
+
parentDeathDetectionEnabled = false;
|
|
18
|
+
if (parentDeathTimer) {
|
|
19
|
+
clearTimeout(parentDeathTimer);
|
|
20
|
+
parentDeathTimer = null;
|
|
21
|
+
}
|
|
22
|
+
};
|
|
23
|
+
const setupParentDeathMonitoring = (parentPid) => {
|
|
24
|
+
if (parentDeathDetectionEnabled)
|
|
25
|
+
return;
|
|
26
|
+
parentDeathDetectionEnabled = true;
|
|
27
|
+
let consecutiveFailures = 0;
|
|
28
|
+
const maxFailures = 3; // Require 3 consecutive failures before self-terminating
|
|
29
|
+
// Check if parent is still alive every 2 seconds (more conservative)
|
|
30
|
+
const checkParentAlive = () => {
|
|
31
|
+
if (!parentDeathDetectionEnabled)
|
|
32
|
+
return;
|
|
33
|
+
try {
|
|
34
|
+
// Send signal 0 to check if process exists (doesn't actually send signal)
|
|
35
|
+
process.kill(parentPid, 0);
|
|
36
|
+
// If we reach here, parent is still alive, reset failure counter and check again later
|
|
37
|
+
consecutiveFailures = 0;
|
|
38
|
+
parentDeathTimer = setTimeout(checkParentAlive, 2000);
|
|
39
|
+
}
|
|
40
|
+
catch {
|
|
41
|
+
consecutiveFailures++;
|
|
42
|
+
console.warn(`[Worker ${process.pid}] Parent check failed (${consecutiveFailures}/${maxFailures})`);
|
|
43
|
+
if (consecutiveFailures >= maxFailures) {
|
|
44
|
+
// Parent process has been gone for multiple checks, self-terminate
|
|
45
|
+
console.error(`[Worker ${process.pid}] Parent process ${parentPid} confirmed dead, self-terminating`);
|
|
46
|
+
process.exit(0);
|
|
47
|
+
}
|
|
48
|
+
else {
|
|
49
|
+
// Try again sooner on failure
|
|
50
|
+
parentDeathTimer = setTimeout(checkParentAlive, 1000);
|
|
51
|
+
}
|
|
52
|
+
}
|
|
53
|
+
};
|
|
54
|
+
// Start monitoring after a longer initial delay to let things settle
|
|
55
|
+
parentDeathTimer = setTimeout(checkParentAlive, 5000);
|
|
56
|
+
};
|
|
13
57
|
const platformRunnerImpl = Runner.PlatformRunner.of({
|
|
14
58
|
[Runner.PlatformRunnerTypeId]: Runner.PlatformRunnerTypeId,
|
|
15
59
|
start(closeLatch) {
|
|
@@ -37,17 +81,29 @@ const platformRunnerImpl = Runner.PlatformRunner.of({
|
|
|
37
81
|
};
|
|
38
82
|
port.on('message', (message) => {
|
|
39
83
|
// console.log('message', message)
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
}
|
|
84
|
+
// Handle parent death detection setup messages
|
|
85
|
+
if (Array.isArray(message) && message[0] === 'setup-parent-death-detection' && message[1]?.parentPid) {
|
|
86
|
+
const parentPid = message[1].parentPid;
|
|
87
|
+
// console.log(`[Worker ${process.pid}] Setting up parent death detection for parent ${parentPid}`)
|
|
88
|
+
setupParentDeathMonitoring(parentPid);
|
|
89
|
+
return;
|
|
47
90
|
}
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
91
|
+
// Handle normal Effect worker messages
|
|
92
|
+
if (Array.isArray(message) && typeof message[0] === 'number') {
|
|
93
|
+
if (message[0] === 0) {
|
|
94
|
+
const result = handler(0, message[1]);
|
|
95
|
+
if (Effect.isEffect(result)) {
|
|
96
|
+
const fiber = runFork(result);
|
|
97
|
+
fiber.addObserver(onExit);
|
|
98
|
+
FiberSet.unsafeAdd(fiberSet, fiber);
|
|
99
|
+
}
|
|
100
|
+
}
|
|
101
|
+
else {
|
|
102
|
+
// Graceful shutdown requested by parent: stop monitoring and close port
|
|
103
|
+
stopParentDeathMonitoring();
|
|
104
|
+
Deferred.unsafeDone(closeLatch, Exit.void);
|
|
105
|
+
port.close();
|
|
106
|
+
}
|
|
51
107
|
}
|
|
52
108
|
});
|
|
53
109
|
port.on('messageerror', (cause) => {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ChildProcessRunner.js","sourceRoot":"","sources":["../../../src/node/ChildProcessRunner/ChildProcessRunner.ts"],"names":[],"mappings":"AAAA,OAAO,OAAO,MAAM,cAAc,CAAA;AAElC,OAAO,EAAE,WAAW,EAAE,MAAM,8BAA8B,CAAA;AAE1D,OAAO,KAAK,MAAM,MAAM,+BAA+B,CAAA;AACvD,OAAO,KAAK,KAAK,MAAM,cAAc,CAAA;AACrC,OAAO,KAAK,OAAO,MAAM,gBAAgB,CAAA;AACzC,OAAO,KAAK,QAAQ,MAAM,iBAAiB,CAAA;AAC3C,OAAO,KAAK,MAAM,MAAM,eAAe,CAAA;AACvC,OAAO,KAAK,IAAI,MAAM,aAAa,CAAA;AACnC,OAAO,KAAK,QAAQ,MAAM,iBAAiB,CAAA;AAC3C,OAAO,KAAK,KAAK,MAAM,cAAc,CAAA;AACrC,OAAO,KAAK,OAAO,MAAM,gBAAgB,CAAA;AACzC,OAAO,KAAK,KAAK,MAAM,cAAc,CAAA;AAErC,MAAM,kBAAkB,GAAG,MAAM,CAAC,cAAc,CAAC,EAAE,CAAC;IAClD,CAAC,MAAM,CAAC,oBAAoB,CAAC,EAAE,MAAM,CAAC,oBAAoB;IAC1D,KAAK,CAAO,UAAqC;QAC/C,OAAO,MAAM,CAAC,GAAG,CAAC,QAAQ,CAAC;YACzB,IAAI,CAAC,OAAO,CAAC,IAAI,EAAE,CAAC;gBAClB,OAAO,KAAK,CAAC,CAAC,IAAI,WAAW,CAAC,EAAE,MAAM,EAAE,OAAO,EAAE,KAAK,EAAE,IAAI,KAAK,CAAC,wBAAwB,CAAC,EAAE,CAAC,CAAA;YAChG,CAAC;YACD,MAAM,IAAI,GAAG;gBACX,WAAW,EAAE,CAAC,OAAY,EAAE,EAAE,CAAC,OAAO,CAAC,IAAK,CAAC,OAAO,CAAC;gBACrD,EAAE,EAAE,CAAC,KAAa,EAAE,OAA+B,EAAE,EAAE,CAAC,OAAO,CAAC,EAAE,CAAC,KAAK,EAAE,OAAO,CAAC;gBAClF,KAAK,EAAE,GAAG,EAAE,CAAC,OAAO,CAAC,UAAU,EAAE;aAClC,CAAA;YACD,MAAM,IAAI,GAAG,CAAC,OAAe,EAAE,OAAU,EAAE,UAAmC,EAAE,EAAE,CAChF,MAAM,CAAC,IAAI,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,EAAE,OAAO,CAAC,CAAC,sBAAsB,CAAC,CAAC,CAAA;YAE1E,MAAM,GAAG,GAAG,MAAM,CAAC,UAAU,CAAC,QAAQ,CAAC;YACrC,yEAAyE;YACzE,OAAsE;gBAEtE,MAAM,OAAO,GAAG,CAAC,KAAK,CAAC,CAAC,MAAM,CAAC,aAAa,CAAC,MAAM,CAAC,OAAO,EAAmB,CAAC,CAAC,CAAC,IAAI,CACnF,OAAO,CAAC,aAAa,CAAC,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,CAC3B,CAAA;gBACvB,MAAM,QAAQ,GAAG,KAAK,CAAC,CAAC,QAAQ,CAAC,IAAI,EAAwB,CAAA;gBAC7D,MAAM,OAAO,GAAG,OAAO,CAAC,OAAO,CAAC,OAAO,CAAC,CAAA;gBACxC,MAAM,MAAM,GAAG,CAAC,IAAuB,EAAE,EAAE;oBACzC,IAAI,IAAI,CAAC,IAAI,KAAK,SAAS,IAAI,CAAC,KAAK,CAAC,iBAAiB,CAAC,IAAI,CAAC,KAAK,CAAC,EAAE,CAAC;wBACpE,sEAAsE;wBACtE,QAAQ,CAAC,UAAU,CAAC,UAAU,EAAE,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAA;oBACvD,CAAC;gBACH,CAAC,CAAA;gBACD,IAAI,CAAC,EAAE,CAAC,SAAS,EAAE,CAAC,
|
|
1
|
+
{"version":3,"file":"ChildProcessRunner.js","sourceRoot":"","sources":["../../../src/node/ChildProcessRunner/ChildProcessRunner.ts"],"names":[],"mappings":"AAAA,OAAO,OAAO,MAAM,cAAc,CAAA;AAElC,OAAO,EAAE,WAAW,EAAE,MAAM,8BAA8B,CAAA;AAE1D,OAAO,KAAK,MAAM,MAAM,+BAA+B,CAAA;AACvD,OAAO,KAAK,KAAK,MAAM,cAAc,CAAA;AACrC,OAAO,KAAK,OAAO,MAAM,gBAAgB,CAAA;AACzC,OAAO,KAAK,QAAQ,MAAM,iBAAiB,CAAA;AAC3C,OAAO,KAAK,MAAM,MAAM,eAAe,CAAA;AACvC,OAAO,KAAK,IAAI,MAAM,aAAa,CAAA;AACnC,OAAO,KAAK,QAAQ,MAAM,iBAAiB,CAAA;AAC3C,OAAO,KAAK,KAAK,MAAM,cAAc,CAAA;AACrC,OAAO,KAAK,OAAO,MAAM,gBAAgB,CAAA;AACzC,OAAO,KAAK,KAAK,MAAM,cAAc,CAAA;AAErC,gCAAgC;AAChC,IAAI,2BAA2B,GAAG,KAAK,CAAA;AACvC,IAAI,gBAAgB,GAA0B,IAAI,CAAA;AAElD,MAAM,yBAAyB,GAAG,GAAG,EAAE;IACrC,2BAA2B,GAAG,KAAK,CAAA;IACnC,IAAI,gBAAgB,EAAE,CAAC;QACrB,YAAY,CAAC,gBAAgB,CAAC,CAAA;QAC9B,gBAAgB,GAAG,IAAI,CAAA;IACzB,CAAC;AACH,CAAC,CAAA;AAED,MAAM,0BAA0B,GAAG,CAAC,SAAiB,EAAE,EAAE;IACvD,IAAI,2BAA2B;QAAE,OAAM;IACvC,2BAA2B,GAAG,IAAI,CAAA;IAElC,IAAI,mBAAmB,GAAG,CAAC,CAAA;IAC3B,MAAM,WAAW,GAAG,CAAC,CAAA,CAAC,yDAAyD;IAE/E,qEAAqE;IACrE,MAAM,gBAAgB,GAAG,GAAG,EAAE;QAC5B,IAAI,CAAC,2BAA2B;YAAE,OAAM;QACxC,IAAI,CAAC;YACH,0EAA0E;YAC1E,OAAO,CAAC,IAAI,CAAC,SAAS,EAAE,CAAC,CAAC,CAAA;YAC1B,uFAAuF;YACvF,mBAAmB,GAAG,CAAC,CAAA;YACvB,gBAAgB,GAAG,UAAU,CAAC,gBAAgB,EAAE,IAAI,CAAC,CAAA;QACvD,CAAC;QAAC,MAAM,CAAC;YACP,mBAAmB,EAAE,CAAA;YACrB,OAAO,CAAC,IAAI,CAAC,WAAW,OAAO,CAAC,GAAG,0BAA0B,mBAAmB,IAAI,WAAW,GAAG,CAAC,CAAA;YAEnG,IAAI,mBAAmB,IAAI,WAAW,EAAE,CAAC;gBACvC,mEAAmE;gBACnE,OAAO,CAAC,KAAK,CAAC,WAAW,OAAO,CAAC,GAAG,oBAAoB,SAAS,mCAAmC,CAAC,CAAA;gBACrG,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAA;YACjB,CAAC;iBAAM,CAAC;gBACN,8BAA8B;gBAC9B,gBAAgB,GAAG,UAAU,CAAC,gBAAgB,EAAE,IAAI,CAAC,CAAA;YACvD,CAAC;QACH,CAAC;IACH,CAAC,CAAA;IAED,qEAAqE;IACrE,gBAAgB,GAAG,UAAU,CAAC,gBAAgB,EAAE,IAAI,CAAC,CAAA;AACvD,CAAC,CAAA;AAED,MAAM,kBAAkB,GAAG,MAAM,CAAC,cAAc,CAAC,EAAE,CAAC;IAClD,CAAC,MAAM,CAAC,oBAAoB,CAAC,EAAE,MAAM,CAAC,oBAAoB;IAC1D,KAAK,CAAO,UAAqC;QAC/C,OAAO,MAAM,CAAC,GAAG,CAAC,QAAQ,CAAC;YACzB,IAAI,CAAC,OAAO,CAAC,IAAI,EAAE,CAAC;gBAClB,OAAO,KAAK,CAAC,CAAC,IAAI,WAAW,CAAC,EAAE,MAAM,EAAE,OAAO,EAAE,KAAK,EAAE,IAAI,KAAK,CAAC,wBAAwB,CAAC,EAAE,CAAC,CAAA;YAChG,CAAC;YACD,MAAM,IAAI,GAAG;gBACX,WAAW,EAAE,CAAC,OAAY,EAAE,EAAE,CAAC,OAAO,CAAC,IAAK,CAAC,OAAO,CAAC;gBACrD,EAAE,EAAE,CAAC,KAAa,EAAE,OAA+B,EAAE,EAAE,CAAC,OAAO,CAAC,EAAE,CAAC,KAAK,EAAE,OAAO,CAAC;gBAClF,KAAK,EAAE,GAAG,EAAE,CAAC,OAAO,CAAC,UAAU,EAAE;aAClC,CAAA;YACD,MAAM,IAAI,GAAG,CAAC,OAAe,EAAE,OAAU,EAAE,UAAmC,EAAE,EAAE,CAChF,MAAM,CAAC,IAAI,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,EAAE,OAAO,CAAC,CAAC,sBAAsB,CAAC,CAAC,CAAA;YAE1E,MAAM,GAAG,GAAG,MAAM,CAAC,UAAU,CAAC,QAAQ,CAAC;YACrC,yEAAyE;YACzE,OAAsE;gBAEtE,MAAM,OAAO,GAAG,CAAC,KAAK,CAAC,CAAC,MAAM,CAAC,aAAa,CAAC,MAAM,CAAC,OAAO,EAAmB,CAAC,CAAC,CAAC,IAAI,CACnF,OAAO,CAAC,aAAa,CAAC,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,CAC3B,CAAA;gBACvB,MAAM,QAAQ,GAAG,KAAK,CAAC,CAAC,QAAQ,CAAC,IAAI,EAAwB,CAAA;gBAC7D,MAAM,OAAO,GAAG,OAAO,CAAC,OAAO,CAAC,OAAO,CAAC,CAAA;gBACxC,MAAM,MAAM,GAAG,CAAC,IAAuB,EAAE,EAAE;oBACzC,IAAI,IAAI,CAAC,IAAI,KAAK,SAAS,IAAI,CAAC,KAAK,CAAC,iBAAiB,CAAC,IAAI,CAAC,KAAK,CAAC,EAAE,CAAC;wBACpE,sEAAsE;wBACtE,QAAQ,CAAC,UAAU,CAAC,UAAU,EAAE,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAA;oBACvD,CAAC;gBACH,CAAC,CAAA;gBACD,IAAI,CAAC,EAAE,CAAC,SAAS,EAAE,CAAC,OAA8C,EAAE,EAAE;oBACpE,kCAAkC;oBAElC,+CAA+C;oBAC/C,IAAI,KAAK,CAAC,OAAO,CAAC,OAAO,CAAC,IAAI,OAAO,CAAC,CAAC,CAAC,KAAK,8BAA8B,IAAI,OAAO,CAAC,CAAC,CAAC,EAAE,SAAS,EAAE,CAAC;wBACrG,MAAM,SAAS,GAAG,OAAO,CAAC,CAAC,CAAC,CAAC,SAAS,CAAA;wBACtC,mGAAmG;wBACnG,0BAA0B,CAAC,SAAS,CAAC,CAAA;wBACrC,OAAM;oBACR,CAAC;oBAED,uCAAuC;oBACvC,IAAI,KAAK,CAAC,OAAO,CAAC,OAAO,CAAC,IAAI,OAAO,OAAO,CAAC,CAAC,CAAC,KAAK,QAAQ,EAAE,CAAC;wBAC7D,IAAI,OAAO,CAAC,CAAC,CAAC,KAAK,CAAC,EAAE,CAAC;4BACrB,MAAM,MAAM,GAAG,OAAO,CAAC,CAAC,EAAE,OAAO,CAAC,CAAC,CAAC,CAAC,CAAA;4BACrC,IAAI,MAAM,CAAC,QAAQ,CAAC,MAAM,CAAC,EAAE,CAAC;gCAC5B,MAAM,KAAK,GAAG,OAAO,CAAC,MAAM,CAAC,CAAA;gCAC7B,KAAK,CAAC,WAAW,CAAC,MAAM,CAAC,CAAA;gCACzB,QAAQ,CAAC,SAAS,CAAC,QAAQ,EAAE,KAAK,CAAC,CAAA;4BACrC,CAAC;wBACH,CAAC;6BAAM,CAAC;4BACN,wEAAwE;4BACxE,yBAAyB,EAAE,CAAA;4BAC3B,QAAQ,CAAC,UAAU,CAAC,UAAU,EAAE,IAAI,CAAC,IAAI,CAAC,CAAA;4BAC1C,IAAI,CAAC,KAAK,EAAE,CAAA;wBACd,CAAC;oBACH,CAAC;gBACH,CAAC,CAAC,CAAA;gBACF,IAAI,CAAC,EAAE,CAAC,cAAc,EAAE,CAAC,KAAK,EAAE,EAAE;oBAChC,QAAQ,CAAC,UAAU,CAAC,UAAU,EAAE,IAAI,WAAW,CAAC,EAAE,MAAM,EAAE,QAAQ,EAAE,KAAK,EAAE,CAAC,CAAC,CAAA;gBAC/E,CAAC,CAAC,CAAA;gBACF,IAAI,CAAC,EAAE,CAAC,OAAO,EAAE,CAAC,KAAK,EAAE,EAAE;oBACzB,QAAQ,CAAC,UAAU,CAAC,UAAU,EAAE,IAAI,WAAW,CAAC,EAAE,MAAM,EAAE,SAAS,EAAE,KAAK,EAAE,CAAC,CAAC,CAAA;gBAChF,CAAC,CAAC,CAAA;gBACF,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC,CAAC,CAAA;YACvB,CAAC,CAAC,CAAA;YAEF,OAAO,EAAE,GAAG,EAAE,IAAI,EAAE,CAAA;QACtB,CAAC,CAAC,CAAA;IACJ,CAAC;CACF,CAAC,CAAA;AAEF,MAAM,CAAC,MAAM,KAAK,GAAG,KAAK,CAAC,OAAO,CAAC,MAAM,CAAC,cAAc,EAAE,kBAAkB,CAAC,CAAA"}
|
|
@@ -1,10 +1,9 @@
|
|
|
1
|
-
// import * as WorkerThreads from 'node:worker_threads'
|
|
2
1
|
import * as ChildProcess from 'node:child_process';
|
|
3
2
|
import * as EffectWorker from '@effect/platform/Worker';
|
|
4
3
|
import { assert, describe, it } from '@effect/vitest';
|
|
5
|
-
import { Chunk, Effect, Stream } from 'effect';
|
|
4
|
+
import { Chunk, Deferred, Effect, Exit, Fiber, Scope, Stream } from 'effect';
|
|
6
5
|
import * as ChildProcessWorker from "../ChildProcessWorker.js";
|
|
7
|
-
import { GetPersonById, GetUserById, InitialMessage, Person, User } from "./schema.js";
|
|
6
|
+
import { GetPersonById, GetUserById, InitialMessage, Person, StartStubbornWorker, User } from "./schema.js";
|
|
8
7
|
const WorkerLive = ChildProcessWorker.layer(() => ChildProcess.fork(new URL('../../../../dist/node/ChildProcessRunner/ChildProcessRunnerTest/serializedWorker.js', import.meta.url)));
|
|
9
8
|
// const WorkerLive = NodeWorker.layer(
|
|
10
9
|
// () =>
|
|
@@ -35,5 +34,180 @@ describe('ChildProcessRunner', { timeout: 10_000 }, () => {
|
|
|
35
34
|
new Person({ id: 123, name: 'ing', data: new Uint8Array([4, 5, 6]) }),
|
|
36
35
|
]);
|
|
37
36
|
}).pipe(Effect.scoped, Effect.provide(WorkerLive), Effect.runPromise));
|
|
37
|
+
describe('Process Cleanup', { timeout: 15_000 }, () => {
|
|
38
|
+
const isProcessRunning = (pid) => {
|
|
39
|
+
try {
|
|
40
|
+
process.kill(pid, 0); // Signal 0 checks if process exists
|
|
41
|
+
return true;
|
|
42
|
+
}
|
|
43
|
+
catch {
|
|
44
|
+
return false;
|
|
45
|
+
}
|
|
46
|
+
};
|
|
47
|
+
it('should clean up child processes when Effect is interrupted', () => Effect.gen(function* () {
|
|
48
|
+
const workerPidDeferred = yield* Deferred.make();
|
|
49
|
+
const testEffect = Effect.gen(function* () {
|
|
50
|
+
const pool = yield* EffectWorker.makePoolSerialized({
|
|
51
|
+
size: 1,
|
|
52
|
+
initialMessage: () => new InitialMessage({ name: 'test', data: new Uint8Array([1, 2, 3]) }),
|
|
53
|
+
});
|
|
54
|
+
const result = yield* pool.executeEffect(new StartStubbornWorker({ blockDuration: 30_000 }));
|
|
55
|
+
yield* Deferred.succeed(workerPidDeferred, result.pid);
|
|
56
|
+
// Verify the worker process is running
|
|
57
|
+
assert.strictEqual(isProcessRunning(result.pid), true, 'Worker process should be running');
|
|
58
|
+
// Start a long-running operation that we'll interrupt
|
|
59
|
+
yield* Effect.sleep('60 seconds');
|
|
60
|
+
}).pipe(Effect.scoped, Effect.provide(WorkerLive));
|
|
61
|
+
// Run the test effect but interrupt it after 2 seconds
|
|
62
|
+
const fiber = yield* Effect.forkScoped(testEffect);
|
|
63
|
+
const workerPid = yield* Deferred.await(workerPidDeferred).pipe(Effect.raceFirst(Fiber.join(fiber).pipe(Effect.flatMap(() => Effect.fail(new Error('testEffect completed before reporting worker PID'))))), Effect.timeout(10_000));
|
|
64
|
+
yield* Effect.sleep('2 seconds');
|
|
65
|
+
yield* Fiber.interrupt(fiber);
|
|
66
|
+
// Wait a moment for cleanup to complete
|
|
67
|
+
yield* Effect.sleep('1 second');
|
|
68
|
+
assert.strictEqual(isProcessRunning(workerPid), false, `Worker process ${workerPid} should be terminated after Effect interruption`);
|
|
69
|
+
}).pipe(Effect.scoped, Effect.runPromise));
|
|
70
|
+
it('should clean up child processes when scope is closed abruptly', () => Effect.gen(function* () {
|
|
71
|
+
let workerPid;
|
|
72
|
+
// Create a scope that we can close manually
|
|
73
|
+
const scope = yield* Scope.make();
|
|
74
|
+
try {
|
|
75
|
+
const pool = yield* EffectWorker.makePoolSerialized({
|
|
76
|
+
size: 1,
|
|
77
|
+
initialMessage: () => new InitialMessage({ name: 'test', data: new Uint8Array([1, 2, 3]) }),
|
|
78
|
+
}).pipe(Scope.extend(scope), Effect.provide(WorkerLive));
|
|
79
|
+
const result = yield* pool.executeEffect(new StartStubbornWorker({ blockDuration: 30_000 }));
|
|
80
|
+
workerPid = result.pid;
|
|
81
|
+
// Verify the worker is running
|
|
82
|
+
assert.strictEqual(isProcessRunning(workerPid), true, 'Worker process should be running');
|
|
83
|
+
}
|
|
84
|
+
finally {
|
|
85
|
+
// Abruptly close the scope (simulating test abortion)
|
|
86
|
+
yield* Scope.close(scope, Exit.void);
|
|
87
|
+
}
|
|
88
|
+
// Wait for cleanup
|
|
89
|
+
yield* Effect.sleep('1 second');
|
|
90
|
+
// This should pass but will initially fail due to zombie process issue
|
|
91
|
+
if (workerPid) {
|
|
92
|
+
assert.strictEqual(isProcessRunning(workerPid), false, `Worker process ${workerPid} should be terminated after scope closure`);
|
|
93
|
+
}
|
|
94
|
+
else {
|
|
95
|
+
assert.fail('Worker PID was not captured');
|
|
96
|
+
}
|
|
97
|
+
}).pipe(Effect.runPromise));
|
|
98
|
+
it('should clean up child processes when parent receives SIGINT', () => Effect.gen(function* () {
|
|
99
|
+
let workerPid;
|
|
100
|
+
const pool = yield* EffectWorker.makePoolSerialized({
|
|
101
|
+
size: 1,
|
|
102
|
+
initialMessage: () => new InitialMessage({ name: 'test', data: new Uint8Array([1, 2, 3]) }),
|
|
103
|
+
});
|
|
104
|
+
const result = yield* pool.executeEffect(new StartStubbornWorker({ blockDuration: 60_000 }));
|
|
105
|
+
workerPid = result.pid;
|
|
106
|
+
// Verify the worker is running
|
|
107
|
+
assert.strictEqual(isProcessRunning(workerPid), true, 'Worker process should be running');
|
|
108
|
+
// Simulate SIGINT being sent to current process (like Ctrl+C in vitest)
|
|
109
|
+
// This should trigger cleanup of child processes
|
|
110
|
+
yield* Effect.async((resume) => {
|
|
111
|
+
// Store current listeners before we manipulate them
|
|
112
|
+
const currentSIGINTListeners = process.listeners('SIGINT').slice();
|
|
113
|
+
// Set up our test handler
|
|
114
|
+
const testHandler = () => {
|
|
115
|
+
// Emit SIGINT to all current listeners to trigger cleanup
|
|
116
|
+
currentSIGINTListeners.forEach((listener) => {
|
|
117
|
+
try {
|
|
118
|
+
;
|
|
119
|
+
listener();
|
|
120
|
+
}
|
|
121
|
+
catch {
|
|
122
|
+
// Ignore errors
|
|
123
|
+
}
|
|
124
|
+
});
|
|
125
|
+
resume(Effect.void);
|
|
126
|
+
};
|
|
127
|
+
// Remove all current SIGINT listeners and add our test handler
|
|
128
|
+
process.removeAllListeners('SIGINT');
|
|
129
|
+
process.once('SIGINT', testHandler);
|
|
130
|
+
// Send SIGINT after a short delay
|
|
131
|
+
setTimeout(() => {
|
|
132
|
+
process.kill(process.pid, 'SIGINT');
|
|
133
|
+
}, 1000);
|
|
134
|
+
});
|
|
135
|
+
// Wait for cleanup to complete
|
|
136
|
+
yield* Effect.sleep('2 seconds');
|
|
137
|
+
// This test should initially fail - child process will still be running
|
|
138
|
+
if (workerPid) {
|
|
139
|
+
assert.strictEqual(isProcessRunning(workerPid), false, `Worker process ${workerPid} should be terminated after SIGINT`);
|
|
140
|
+
}
|
|
141
|
+
else {
|
|
142
|
+
assert.fail('Worker PID was not captured');
|
|
143
|
+
}
|
|
144
|
+
}).pipe(Effect.scoped, Effect.provide(WorkerLive), Effect.runPromise));
|
|
145
|
+
it('should clean up multiple concurrent child processes', () => Effect.gen(function* () {
|
|
146
|
+
let workerPids = [];
|
|
147
|
+
const testEffect = Effect.gen(function* () {
|
|
148
|
+
const pool = yield* EffectWorker.makePoolSerialized({
|
|
149
|
+
size: 3, // Multiple workers
|
|
150
|
+
initialMessage: () => new InitialMessage({ name: 'test', data: new Uint8Array([1, 2, 3]) }),
|
|
151
|
+
});
|
|
152
|
+
// Start multiple stubborn workers
|
|
153
|
+
const workers = yield* Effect.all([
|
|
154
|
+
pool.executeEffect(new StartStubbornWorker({ blockDuration: 30_000 })),
|
|
155
|
+
pool.executeEffect(new StartStubbornWorker({ blockDuration: 30_000 })),
|
|
156
|
+
pool.executeEffect(new StartStubbornWorker({ blockDuration: 30_000 })),
|
|
157
|
+
], { concurrency: 'unbounded' });
|
|
158
|
+
workerPids = workers.map((w) => w.pid);
|
|
159
|
+
// Verify all workers are running
|
|
160
|
+
for (const pid of workerPids) {
|
|
161
|
+
assert.strictEqual(isProcessRunning(pid), true, `Worker process ${pid} should be running`);
|
|
162
|
+
}
|
|
163
|
+
yield* Effect.sleep('30 seconds'); // Keep running until interrupted
|
|
164
|
+
}).pipe(Effect.scoped, Effect.provide(WorkerLive));
|
|
165
|
+
// Run with timeout to force termination
|
|
166
|
+
const fiber = yield* Effect.fork(testEffect);
|
|
167
|
+
yield* Effect.sleep('2 seconds');
|
|
168
|
+
yield* Fiber.interrupt(fiber);
|
|
169
|
+
// Wait for cleanup
|
|
170
|
+
yield* Effect.sleep('2 seconds');
|
|
171
|
+
// All worker processes should be cleaned up
|
|
172
|
+
for (const pid of workerPids) {
|
|
173
|
+
assert.strictEqual(isProcessRunning(pid), false, `Worker process ${pid} should be terminated after pool cleanup`);
|
|
174
|
+
}
|
|
175
|
+
}).pipe(Effect.runPromise));
|
|
176
|
+
it('should handle direct ChildProcess.fork cleanup (node-sync pattern)', () => Effect.gen(function* () {
|
|
177
|
+
let childPid;
|
|
178
|
+
// This mimics the exact pattern used in node-sync tests
|
|
179
|
+
const nodeChildProcess = ChildProcess.fork(new URL('../../../../dist/node/ChildProcessRunner/ChildProcessRunnerTest/serializedWorker.js', import.meta.url), ['test-client']);
|
|
180
|
+
childPid = nodeChildProcess.pid;
|
|
181
|
+
const testEffect = Effect.gen(function* () {
|
|
182
|
+
const worker = yield* EffectWorker.makePoolSerialized({
|
|
183
|
+
size: 1,
|
|
184
|
+
concurrency: 100,
|
|
185
|
+
initialMessage: () => new InitialMessage({ name: 'test', data: new Uint8Array([1, 2, 3]) }),
|
|
186
|
+
}).pipe(Effect.provide(ChildProcessWorker.layer(() => nodeChildProcess)));
|
|
187
|
+
// Start stubborn worker
|
|
188
|
+
yield* worker.executeEffect(new StartStubbornWorker({ blockDuration: 60_000 }));
|
|
189
|
+
// Verify process is running
|
|
190
|
+
if (childPid) {
|
|
191
|
+
assert.strictEqual(isProcessRunning(childPid), true, 'Child process should be running');
|
|
192
|
+
}
|
|
193
|
+
// Keep running until interrupted
|
|
194
|
+
yield* Effect.sleep('30 seconds');
|
|
195
|
+
}).pipe(Effect.scoped);
|
|
196
|
+
// Simulate the exact abortion pattern from node-sync
|
|
197
|
+
const fiber = yield* Effect.fork(testEffect);
|
|
198
|
+
yield* Effect.sleep('2 seconds');
|
|
199
|
+
// Force kill the fiber without proper cleanup (simulates Ctrl+C)
|
|
200
|
+
yield* Fiber.interrupt(fiber);
|
|
201
|
+
// Wait for cleanup
|
|
202
|
+
yield* Effect.sleep('3 seconds');
|
|
203
|
+
// This test should initially fail - demonstrating the zombie process issue
|
|
204
|
+
if (childPid) {
|
|
205
|
+
assert.strictEqual(isProcessRunning(childPid), false, `Child process ${childPid} should be terminated after forced interruption`);
|
|
206
|
+
}
|
|
207
|
+
else {
|
|
208
|
+
assert.fail('Child PID was not captured');
|
|
209
|
+
}
|
|
210
|
+
}).pipe(Effect.runPromise));
|
|
211
|
+
});
|
|
38
212
|
});
|
|
39
213
|
//# sourceMappingURL=ChildProcessRunner.test.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ChildProcessRunner.test.js","sourceRoot":"","sources":["../../../../src/node/ChildProcessRunner/ChildProcessRunnerTest/ChildProcessRunner.test.ts"],"names":[],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"ChildProcessRunner.test.js","sourceRoot":"","sources":["../../../../src/node/ChildProcessRunner/ChildProcessRunnerTest/ChildProcessRunner.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -48,6 +48,15 @@ declare const RunnerInterrupt_base: Schema.TaggedRequestClass<RunnerInterrupt, "
|
|
|
48
48
|
}, typeof Schema.Void, typeof Schema.Never>;
|
|
49
49
|
export declare class RunnerInterrupt extends RunnerInterrupt_base {
|
|
50
50
|
}
|
|
51
|
+
declare const StartStubbornWorker_base: Schema.TaggedRequestClass<StartStubbornWorker, "StartStubbornWorker", {
|
|
52
|
+
readonly _tag: Schema.tag<"StartStubbornWorker">;
|
|
53
|
+
} & {
|
|
54
|
+
blockDuration: typeof Schema.Number;
|
|
55
|
+
}, Schema.Struct<{
|
|
56
|
+
pid: typeof Schema.Number;
|
|
57
|
+
}>, typeof Schema.Never>;
|
|
58
|
+
export declare class StartStubbornWorker extends StartStubbornWorker_base {
|
|
59
|
+
}
|
|
51
60
|
declare const InitialMessage_base: Schema.TaggedRequestClass<InitialMessage, "InitialMessage", {
|
|
52
61
|
readonly _tag: Schema.tag<"InitialMessage">;
|
|
53
62
|
} & {
|
|
@@ -69,7 +78,7 @@ declare const GetSpan_base: Schema.TaggedRequestClass<GetSpan, "GetSpan", {
|
|
|
69
78
|
}>, typeof Schema.Never>;
|
|
70
79
|
export declare class GetSpan extends GetSpan_base {
|
|
71
80
|
}
|
|
72
|
-
export declare const WorkerMessage: Schema.Union<[typeof GetUserById, typeof GetPersonById, typeof InitialMessage, typeof GetSpan, typeof RunnerInterrupt]>;
|
|
81
|
+
export declare const WorkerMessage: Schema.Union<[typeof GetUserById, typeof GetPersonById, typeof InitialMessage, typeof GetSpan, typeof RunnerInterrupt, typeof StartStubbornWorker]>;
|
|
73
82
|
export type WorkerMessage = Schema.Schema.Type<typeof WorkerMessage>;
|
|
74
83
|
export {};
|
|
75
84
|
//# sourceMappingURL=schema.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"schema.d.ts","sourceRoot":"","sources":["../../../../src/node/ChildProcessRunner/ChildProcessRunnerTest/schema.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,MAAM,MAAM,eAAe,CAAA;;;;;;;;;;;;AAEvC,qBAAa,IAAK,SAAQ,SAGxB;CAAG;;;;;;AAEL,qBAAa,WAAY,SAAQ,gBAM/B;CAAG;;;;;;;;;;;;;;;;AAEL,qBAAa,MAAO,SAAQ,WAK1B;CAAG;;;;;;AAEL,qBAAa,aAAc,SAAQ,kBAMjC;CAAG;;;;AAEL,qBAAa,eAAgB,SAAQ,oBAInC;CAAG;;;;;;;AAEL,qBAAa,cAAe,SAAQ,mBAQlC;CAAG;;;;;;;;;;;;AAEL,qBAAa,OAAQ,SAAQ,YAc3B;CAAG;AAEL,eAAO,MAAM,aAAa,
|
|
1
|
+
{"version":3,"file":"schema.d.ts","sourceRoot":"","sources":["../../../../src/node/ChildProcessRunner/ChildProcessRunnerTest/schema.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,MAAM,MAAM,eAAe,CAAA;;;;;;;;;;;;AAEvC,qBAAa,IAAK,SAAQ,SAGxB;CAAG;;;;;;AAEL,qBAAa,WAAY,SAAQ,gBAM/B;CAAG;;;;;;;;;;;;;;;;AAEL,qBAAa,MAAO,SAAQ,WAK1B;CAAG;;;;;;AAEL,qBAAa,aAAc,SAAQ,kBAMjC;CAAG;;;;AAEL,qBAAa,eAAgB,SAAQ,oBAInC;CAAG;;;;;;;;AAEL,qBAAa,mBAAoB,SAAQ,wBAIvC;CAAG;;;;;;;AAEL,qBAAa,cAAe,SAAQ,mBAQlC;CAAG;;;;;;;;;;;;AAEL,qBAAa,OAAQ,SAAQ,YAc3B;CAAG;AAEL,eAAO,MAAM,aAAa,qJAOzB,CAAA;AACD,MAAM,MAAM,aAAa,GAAG,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,OAAO,aAAa,CAAC,CAAA"}
|
|
@@ -34,6 +34,12 @@ export class RunnerInterrupt extends Schema.TaggedRequest()('RunnerInterrupt', {
|
|
|
34
34
|
payload: {},
|
|
35
35
|
}) {
|
|
36
36
|
}
|
|
37
|
+
export class StartStubbornWorker extends Schema.TaggedRequest()('StartStubbornWorker', {
|
|
38
|
+
failure: Schema.Never,
|
|
39
|
+
success: Schema.Struct({ pid: Schema.Number }),
|
|
40
|
+
payload: { blockDuration: Schema.Number },
|
|
41
|
+
}) {
|
|
42
|
+
}
|
|
37
43
|
export class InitialMessage extends Schema.TaggedRequest()('InitialMessage', {
|
|
38
44
|
failure: Schema.Never,
|
|
39
45
|
success: Schema.Void,
|
|
@@ -58,5 +64,5 @@ export class GetSpan extends Schema.TaggedRequest()('GetSpan', {
|
|
|
58
64
|
payload: {},
|
|
59
65
|
}) {
|
|
60
66
|
}
|
|
61
|
-
export const WorkerMessage = Schema.Union(GetUserById, GetPersonById, InitialMessage, GetSpan, RunnerInterrupt);
|
|
67
|
+
export const WorkerMessage = Schema.Union(GetUserById, GetPersonById, InitialMessage, GetSpan, RunnerInterrupt, StartStubbornWorker);
|
|
62
68
|
//# sourceMappingURL=schema.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"schema.js","sourceRoot":"","sources":["../../../../src/node/ChildProcessRunner/ChildProcessRunnerTest/schema.ts"],"names":[],"mappings":"AAAA,gEAAgE;AAChE,OAAO,KAAK,MAAM,MAAM,eAAe,CAAA;AAEvC,MAAM,OAAO,IAAK,SAAQ,MAAM,CAAC,KAAK,CAAO,MAAM,CAAC,CAAC;IACnD,EAAE,EAAE,MAAM,CAAC,MAAM;IACjB,IAAI,EAAE,MAAM,CAAC,MAAM;CACpB,CAAC;CAAG;AAEL,MAAM,OAAO,WAAY,SAAQ,MAAM,CAAC,aAAa,EAAe,CAAC,aAAa,EAAE;IAClF,OAAO,EAAE,MAAM,CAAC,KAAK;IACrB,OAAO,EAAE,IAAI;IACb,OAAO,EAAE;QACP,EAAE,EAAE,MAAM,CAAC,MAAM;KAClB;CACF,CAAC;CAAG;AAEL,MAAM,OAAO,MAAO,SAAQ,MAAM,CAAC,KAAK,CAAS,QAAQ,CAAC,CAAC;IACzD,EAAE,EAAE,MAAM,CAAC,MAAM;IACjB,IAAI,EAAE,MAAM,CAAC,MAAM;IACnB,iCAAiC;IACjC,IAAI,EAAE,MAAM,CAAC,UAAU;CACxB,CAAC;CAAG;AAEL,MAAM,OAAO,aAAc,SAAQ,MAAM,CAAC,aAAa,EAAiB,CAAC,eAAe,EAAE;IACxF,OAAO,EAAE,MAAM,CAAC,KAAK;IACrB,OAAO,EAAE,MAAM;IACf,OAAO,EAAE;QACP,EAAE,EAAE,MAAM,CAAC,MAAM;KAClB;CACF,CAAC;CAAG;AAEL,MAAM,OAAO,eAAgB,SAAQ,MAAM,CAAC,aAAa,EAAmB,CAAC,iBAAiB,EAAE;IAC9F,OAAO,EAAE,MAAM,CAAC,KAAK;IACrB,OAAO,EAAE,MAAM,CAAC,IAAI;IACpB,OAAO,EAAE,EAAE;CACZ,CAAC;CAAG;AAEL,MAAM,OAAO,cAAe,SAAQ,MAAM,CAAC,aAAa,EAAkB,CAAC,gBAAgB,EAAE;IAC3F,OAAO,EAAE,MAAM,CAAC,KAAK;IACrB,OAAO,EAAE,MAAM,CAAC,IAAI;IACpB,OAAO,EAAE;QACP,IAAI,EAAE,MAAM,CAAC,MAAM;QACnB,IAAI,EAAE,MAAM,CAAC,UAAU;QACvB,iCAAiC;KAClC;CACF,CAAC;CAAG;AAEL,MAAM,OAAO,OAAQ,SAAQ,MAAM,CAAC,aAAa,EAAW,CAAC,SAAS,EAAE;IACtE,OAAO,EAAE,MAAM,CAAC,KAAK;IACrB,OAAO,EAAE,MAAM,CAAC,MAAM,CAAC;QACrB,IAAI,EAAE,MAAM,CAAC,MAAM;QACnB,OAAO,EAAE,MAAM,CAAC,MAAM;QACtB,MAAM,EAAE,MAAM,CAAC,MAAM;QACrB,MAAM,EAAE,MAAM,CAAC,MAAM,CACnB,MAAM,CAAC,MAAM,CAAC;YACZ,OAAO,EAAE,MAAM,CAAC,MAAM;YACtB,MAAM,EAAE,MAAM,CAAC,MAAM;SACtB,CAAC,CACH;KACF,CAAC;IACF,OAAO,EAAE,EAAE;CACZ,CAAC;CAAG;AAEL,MAAM,CAAC,MAAM,aAAa,GAAG,MAAM,CAAC,KAAK,
|
|
1
|
+
{"version":3,"file":"schema.js","sourceRoot":"","sources":["../../../../src/node/ChildProcessRunner/ChildProcessRunnerTest/schema.ts"],"names":[],"mappings":"AAAA,gEAAgE;AAChE,OAAO,KAAK,MAAM,MAAM,eAAe,CAAA;AAEvC,MAAM,OAAO,IAAK,SAAQ,MAAM,CAAC,KAAK,CAAO,MAAM,CAAC,CAAC;IACnD,EAAE,EAAE,MAAM,CAAC,MAAM;IACjB,IAAI,EAAE,MAAM,CAAC,MAAM;CACpB,CAAC;CAAG;AAEL,MAAM,OAAO,WAAY,SAAQ,MAAM,CAAC,aAAa,EAAe,CAAC,aAAa,EAAE;IAClF,OAAO,EAAE,MAAM,CAAC,KAAK;IACrB,OAAO,EAAE,IAAI;IACb,OAAO,EAAE;QACP,EAAE,EAAE,MAAM,CAAC,MAAM;KAClB;CACF,CAAC;CAAG;AAEL,MAAM,OAAO,MAAO,SAAQ,MAAM,CAAC,KAAK,CAAS,QAAQ,CAAC,CAAC;IACzD,EAAE,EAAE,MAAM,CAAC,MAAM;IACjB,IAAI,EAAE,MAAM,CAAC,MAAM;IACnB,iCAAiC;IACjC,IAAI,EAAE,MAAM,CAAC,UAAU;CACxB,CAAC;CAAG;AAEL,MAAM,OAAO,aAAc,SAAQ,MAAM,CAAC,aAAa,EAAiB,CAAC,eAAe,EAAE;IACxF,OAAO,EAAE,MAAM,CAAC,KAAK;IACrB,OAAO,EAAE,MAAM;IACf,OAAO,EAAE;QACP,EAAE,EAAE,MAAM,CAAC,MAAM;KAClB;CACF,CAAC;CAAG;AAEL,MAAM,OAAO,eAAgB,SAAQ,MAAM,CAAC,aAAa,EAAmB,CAAC,iBAAiB,EAAE;IAC9F,OAAO,EAAE,MAAM,CAAC,KAAK;IACrB,OAAO,EAAE,MAAM,CAAC,IAAI;IACpB,OAAO,EAAE,EAAE;CACZ,CAAC;CAAG;AAEL,MAAM,OAAO,mBAAoB,SAAQ,MAAM,CAAC,aAAa,EAAuB,CAAC,qBAAqB,EAAE;IAC1G,OAAO,EAAE,MAAM,CAAC,KAAK;IACrB,OAAO,EAAE,MAAM,CAAC,MAAM,CAAC,EAAE,GAAG,EAAE,MAAM,CAAC,MAAM,EAAE,CAAC;IAC9C,OAAO,EAAE,EAAE,aAAa,EAAE,MAAM,CAAC,MAAM,EAAE;CAC1C,CAAC;CAAG;AAEL,MAAM,OAAO,cAAe,SAAQ,MAAM,CAAC,aAAa,EAAkB,CAAC,gBAAgB,EAAE;IAC3F,OAAO,EAAE,MAAM,CAAC,KAAK;IACrB,OAAO,EAAE,MAAM,CAAC,IAAI;IACpB,OAAO,EAAE;QACP,IAAI,EAAE,MAAM,CAAC,MAAM;QACnB,IAAI,EAAE,MAAM,CAAC,UAAU;QACvB,iCAAiC;KAClC;CACF,CAAC;CAAG;AAEL,MAAM,OAAO,OAAQ,SAAQ,MAAM,CAAC,aAAa,EAAW,CAAC,SAAS,EAAE;IACtE,OAAO,EAAE,MAAM,CAAC,KAAK;IACrB,OAAO,EAAE,MAAM,CAAC,MAAM,CAAC;QACrB,IAAI,EAAE,MAAM,CAAC,MAAM;QACnB,OAAO,EAAE,MAAM,CAAC,MAAM;QACtB,MAAM,EAAE,MAAM,CAAC,MAAM;QACrB,MAAM,EAAE,MAAM,CAAC,MAAM,CACnB,MAAM,CAAC,MAAM,CAAC;YACZ,OAAO,EAAE,MAAM,CAAC,MAAM;YACtB,MAAM,EAAE,MAAM,CAAC,MAAM;SACtB,CAAC,CACH;KACF,CAAC;IACF,OAAO,EAAE,EAAE;CACZ,CAAC;CAAG;AAEL,MAAM,CAAC,MAAM,aAAa,GAAG,MAAM,CAAC,KAAK,CACvC,WAAW,EACX,aAAa,EACb,cAAc,EACd,OAAO,EACP,eAAe,EACf,mBAAmB,CACpB,CAAA"}
|
|
@@ -12,7 +12,7 @@ const WorkerLive = Runner.layerSerialized(WorkerMessage, {
|
|
|
12
12
|
GetUserById: (req) => Effect.map(Name, (name) => new User({ id: req.id, name })),
|
|
13
13
|
// InitialMessage: (req) => Layer.succeed(Name, req.name),
|
|
14
14
|
InitialMessage: (req) => Effect.gen(function* () {
|
|
15
|
-
yield* Effect.addFinalizer(() => Effect.log('closing worker scope'))
|
|
15
|
+
// yield* Effect.addFinalizer(() => Effect.log('closing worker scope'))
|
|
16
16
|
return Layer.succeed(Name, req.name);
|
|
17
17
|
}).pipe(Layer.unwrapScoped),
|
|
18
18
|
// InitialMessage: (req) =>
|
|
@@ -23,8 +23,8 @@ const WorkerLive = Runner.layerSerialized(WorkerMessage, {
|
|
|
23
23
|
// return req.name
|
|
24
24
|
// }),
|
|
25
25
|
// ),
|
|
26
|
-
GetSpan: (_) => Effect.gen(function* (
|
|
27
|
-
const span = yield*
|
|
26
|
+
GetSpan: (_) => Effect.gen(function* () {
|
|
27
|
+
const span = yield* Effect.currentSpan.pipe(Effect.orDie);
|
|
28
28
|
return {
|
|
29
29
|
traceId: span.traceId,
|
|
30
30
|
spanId: span.spanId,
|
|
@@ -36,6 +36,16 @@ const WorkerLive = Runner.layerSerialized(WorkerMessage, {
|
|
|
36
36
|
};
|
|
37
37
|
}).pipe(Effect.withSpan('GetSpan')),
|
|
38
38
|
RunnerInterrupt: () => Effect.interrupt,
|
|
39
|
+
StartStubbornWorker: ({ blockDuration }) => Effect.gen(function* () {
|
|
40
|
+
// Start a blocking operation that won't respond to normal shutdown signals
|
|
41
|
+
const pid = process.pid;
|
|
42
|
+
yield* Effect.fork(Effect.gen(function* () {
|
|
43
|
+
// Block for the specified duration, ignoring shutdown attempts
|
|
44
|
+
yield* Effect.sleep(`${blockDuration} millis`);
|
|
45
|
+
yield* Effect.log('Stubborn worker finished blocking');
|
|
46
|
+
}).pipe(Effect.uninterruptible));
|
|
47
|
+
return { pid };
|
|
48
|
+
}),
|
|
39
49
|
}).pipe(Layer.provide(ChildProcessRunner.layer));
|
|
40
50
|
// }).pipe(Layer.provide(PlatformNode.NodeWorkerRunner.layer))
|
|
41
51
|
PlatformNode.NodeRuntime.runMain(Runner.launch(WorkerLive));
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"serializedWorker.js","sourceRoot":"","sources":["../../../../src/node/ChildProcessRunner/ChildProcessRunnerTest/serializedWorker.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,MAAM,+BAA+B,CAAA;AACvD,OAAO,EAAE,OAAO,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,QAAQ,CAAA;AAE/D,wEAAwE;AACxE,OAAO,EAAE,YAAY,EAAE,MAAM,cAAc,CAAA;AAC3C,OAAO,KAAK,kBAAkB,MAAM,0BAA0B,CAAA;AAC9D,OAAO,EAAE,MAAM,EAAE,IAAI,EAAE,aAAa,EAAE,MAAM,aAAa,CAAA;AAKzD,MAAM,IAAI,GAAG,OAAO,CAAC,UAAU,CAAe,MAAM,CAAC,CAAA;AAErD,MAAM,UAAU,GAAG,MAAM,CAAC,eAAe,CAAC,aAAa,EAAE;IACvD,aAAa,EAAE,CAAC,GAAG,EAAE,EAAE;QACrB,OAAO,MAAM,CAAC,IAAI,CAChB,IAAI,MAAM,CAAC,EAAE,EAAE,EAAE,GAAG,CAAC,EAAE,EAAE,IAAI,EAAE,MAAM,EAAE,IAAI,EAAE,IAAI,UAAU,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,EACzE,IAAI,MAAM,CAAC,EAAE,EAAE,EAAE,GAAG,CAAC,EAAE,EAAE,IAAI,EAAE,KAAK,EAAE,IAAI,EAAE,IAAI,UAAU,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,CACzE,CAAA;IACH,CAAC;IACD,WAAW,EAAE,CAAC,GAAG,EAAE,EAAE,CAAC,MAAM,CAAC,GAAG,CAAC,IAAI,EAAE,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,IAAI,CAAC,EAAE,EAAE,EAAE,GAAG,CAAC,EAAE,EAAE,IAAI,EAAE,CAAC,CAAC;IAChF,0DAA0D;IAC1D,cAAc,EAAE,CAAC,GAAG,EAAE,EAAE,CACtB,MAAM,CAAC,GAAG,CAAC,QAAQ,CAAC;QAClB,
|
|
1
|
+
{"version":3,"file":"serializedWorker.js","sourceRoot":"","sources":["../../../../src/node/ChildProcessRunner/ChildProcessRunnerTest/serializedWorker.ts"],"names":[],"mappings":"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"}
|
|
@@ -3,5 +3,21 @@ import * as Worker from '@effect/platform/Worker';
|
|
|
3
3
|
import * as Layer from 'effect/Layer';
|
|
4
4
|
export declare const layerWorker: Layer.Layer<Worker.PlatformWorker, never, never>;
|
|
5
5
|
export declare const layerManager: Layer.Layer<Worker.WorkerManager, never, never>;
|
|
6
|
+
/**
|
|
7
|
+
* @example
|
|
8
|
+
* ```ts
|
|
9
|
+
* import * as ChildProcess from 'node:child_process'
|
|
10
|
+
* import { Effect, Worker } from '@effect/platform/Worker'
|
|
11
|
+
* import { ChildProcessWorker } from '@livestore/utils/node'
|
|
12
|
+
*
|
|
13
|
+
* Worker.makePoolSerialized<WorkerMessage>({
|
|
14
|
+
* size: 1,
|
|
15
|
+
* initialMessage: () => new InitialMessage({ name: 'test', data: new Uint8Array([1, 2, 3]) }),
|
|
16
|
+
* }).pipe(
|
|
17
|
+
* Effect.provide(ChildProcessWorker.layer(() => ChildProcess.fork(new URL('worker.ts', import.meta.url)))),
|
|
18
|
+
* )
|
|
19
|
+
* ```
|
|
20
|
+
*
|
|
21
|
+
*/
|
|
6
22
|
export declare const layer: (spawn: (id: number) => ChildProcess.ChildProcess) => Layer.Layer<Worker.Spawner | Worker.WorkerManager, never, never>;
|
|
7
23
|
//# sourceMappingURL=ChildProcessWorker.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ChildProcessWorker.d.ts","sourceRoot":"","sources":["../../../src/node/ChildProcessRunner/ChildProcessWorker.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,KAAK,YAAY,MAAM,oBAAoB,CAAA;AACvD,OAAO,KAAK,MAAM,MAAM,yBAAyB,CAAA;AAKjD,OAAO,KAAK,KAAK,MAAM,cAAc,CAAA;
|
|
1
|
+
{"version":3,"file":"ChildProcessWorker.d.ts","sourceRoot":"","sources":["../../../src/node/ChildProcessRunner/ChildProcessWorker.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,KAAK,YAAY,MAAM,oBAAoB,CAAA;AACvD,OAAO,KAAK,MAAM,MAAM,yBAAyB,CAAA;AAKjD,OAAO,KAAK,KAAK,MAAM,cAAc,CAAA;AA4IrC,eAAO,MAAM,WAAW,kDAA2D,CAAA;AAEnF,eAAO,MAAM,YAAY,iDAAkD,CAAA;AAE3E;;;;;;;;;;;;;;;GAeG;AACH,eAAO,MAAM,KAAK,GAAI,OAAO,CAAC,EAAE,EAAE,MAAM,KAAK,YAAY,CAAC,YAAY,qEACf,CAAA"}
|
|
@@ -5,16 +5,96 @@ import * as Effect from 'effect/Effect';
|
|
|
5
5
|
import * as Exit from 'effect/Exit';
|
|
6
6
|
import * as Layer from 'effect/Layer';
|
|
7
7
|
import * as Scope from 'effect/Scope';
|
|
8
|
+
// Track child processes for cleanup on process signals
|
|
9
|
+
const childProcesses = new Set();
|
|
10
|
+
// Force cleanup all tracked child processes
|
|
11
|
+
const forceCleanupChildren = (signal = 'SIGKILL') => {
|
|
12
|
+
for (const child of childProcesses) {
|
|
13
|
+
try {
|
|
14
|
+
if (!child.killed) {
|
|
15
|
+
child.kill(signal);
|
|
16
|
+
}
|
|
17
|
+
}
|
|
18
|
+
catch {
|
|
19
|
+
// Ignore errors during cleanup
|
|
20
|
+
}
|
|
21
|
+
}
|
|
22
|
+
childProcesses.clear();
|
|
23
|
+
};
|
|
24
|
+
// Install signal handlers once to clean up all child processes
|
|
25
|
+
let signalHandlersInstalled = false;
|
|
26
|
+
const installSignalHandlers = () => {
|
|
27
|
+
if (signalHandlersInstalled)
|
|
28
|
+
return;
|
|
29
|
+
signalHandlersInstalled = true;
|
|
30
|
+
// Use 'beforeExit' instead of signal handlers since tests may interfere with signals
|
|
31
|
+
process.on('beforeExit', () => {
|
|
32
|
+
forceCleanupChildren('SIGKILL');
|
|
33
|
+
});
|
|
34
|
+
// Also try to cleanup on uncaught exceptions
|
|
35
|
+
process.on('uncaughtException', () => {
|
|
36
|
+
forceCleanupChildren('SIGKILL');
|
|
37
|
+
});
|
|
38
|
+
// Install signal handlers but make them more robust
|
|
39
|
+
const sigintHandler = () => {
|
|
40
|
+
forceCleanupChildren('SIGINT');
|
|
41
|
+
};
|
|
42
|
+
const sigtermHandler = () => {
|
|
43
|
+
forceCleanupChildren('SIGTERM');
|
|
44
|
+
};
|
|
45
|
+
const exitHandler = () => {
|
|
46
|
+
forceCleanupChildren('SIGKILL');
|
|
47
|
+
};
|
|
48
|
+
// Add handlers that will persist even if tests remove/add other handlers
|
|
49
|
+
process.prependListener('SIGINT', sigintHandler);
|
|
50
|
+
process.prependListener('SIGTERM', sigtermHandler);
|
|
51
|
+
process.prependListener('exit', exitHandler);
|
|
52
|
+
};
|
|
8
53
|
const platformWorkerImpl = Worker.makePlatform()({
|
|
9
54
|
setup({ scope, worker: childProcess }) {
|
|
10
55
|
return Effect.flatMap(Deferred.make(), (exitDeferred) => {
|
|
56
|
+
// Install signal handlers for process-wide cleanup
|
|
57
|
+
installSignalHandlers();
|
|
58
|
+
// Track this child process for cleanup
|
|
59
|
+
childProcesses.add(childProcess);
|
|
11
60
|
childProcess.on('exit', () => {
|
|
61
|
+
// Remove from tracking when process exits
|
|
62
|
+
childProcesses.delete(childProcess);
|
|
12
63
|
Deferred.unsafeDone(exitDeferred, Exit.void);
|
|
13
64
|
});
|
|
65
|
+
childProcess.send(['setup-parent-death-detection', { parentPid: process.pid }]);
|
|
14
66
|
return Effect.as(Scope.addFinalizer(scope, Effect.suspend(() => {
|
|
15
|
-
|
|
67
|
+
// Try graceful shutdown first
|
|
68
|
+
try {
|
|
69
|
+
childProcess.send([1]);
|
|
70
|
+
}
|
|
71
|
+
catch {
|
|
72
|
+
// IPC channel might be closed, proceed to forceful termination
|
|
73
|
+
}
|
|
16
74
|
return Deferred.await(exitDeferred);
|
|
17
|
-
}).pipe(Effect.timeout(
|
|
75
|
+
}).pipe(Effect.timeout(3000), // Reduced timeout for faster cleanup
|
|
76
|
+
Effect.interruptible, Effect.catchAllCause(() => Effect.sync(() => {
|
|
77
|
+
// Enhanced cleanup with escalating signals
|
|
78
|
+
if (!childProcess.killed) {
|
|
79
|
+
try {
|
|
80
|
+
// First try SIGTERM
|
|
81
|
+
childProcess.kill('SIGTERM');
|
|
82
|
+
// If still running after a short delay, use SIGKILL
|
|
83
|
+
setTimeout(() => {
|
|
84
|
+
if (!childProcess.killed) {
|
|
85
|
+
childProcess.kill('SIGKILL');
|
|
86
|
+
}
|
|
87
|
+
}, 1000);
|
|
88
|
+
}
|
|
89
|
+
catch {
|
|
90
|
+
// Process might already be dead
|
|
91
|
+
}
|
|
92
|
+
finally {
|
|
93
|
+
// Ensure it's removed from tracking
|
|
94
|
+
childProcesses.delete(childProcess);
|
|
95
|
+
}
|
|
96
|
+
}
|
|
97
|
+
})))), {
|
|
18
98
|
postMessage: (message) => childProcess.send(message),
|
|
19
99
|
on: (event, handler) => childProcess.on(event, handler),
|
|
20
100
|
});
|
|
@@ -38,5 +118,21 @@ const platformWorkerImpl = Worker.makePlatform()({
|
|
|
38
118
|
});
|
|
39
119
|
export const layerWorker = Layer.succeed(Worker.PlatformWorker, platformWorkerImpl);
|
|
40
120
|
export const layerManager = Layer.provide(Worker.layerManager, layerWorker);
|
|
121
|
+
/**
|
|
122
|
+
* @example
|
|
123
|
+
* ```ts
|
|
124
|
+
* import * as ChildProcess from 'node:child_process'
|
|
125
|
+
* import { Effect, Worker } from '@effect/platform/Worker'
|
|
126
|
+
* import { ChildProcessWorker } from '@livestore/utils/node'
|
|
127
|
+
*
|
|
128
|
+
* Worker.makePoolSerialized<WorkerMessage>({
|
|
129
|
+
* size: 1,
|
|
130
|
+
* initialMessage: () => new InitialMessage({ name: 'test', data: new Uint8Array([1, 2, 3]) }),
|
|
131
|
+
* }).pipe(
|
|
132
|
+
* Effect.provide(ChildProcessWorker.layer(() => ChildProcess.fork(new URL('worker.ts', import.meta.url)))),
|
|
133
|
+
* )
|
|
134
|
+
* ```
|
|
135
|
+
*
|
|
136
|
+
*/
|
|
41
137
|
export const layer = (spawn) => Layer.merge(layerManager, Worker.layerSpawner(spawn));
|
|
42
138
|
//# sourceMappingURL=ChildProcessWorker.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ChildProcessWorker.js","sourceRoot":"","sources":["../../../src/node/ChildProcessRunner/ChildProcessWorker.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,MAAM,MAAM,yBAAyB,CAAA;AACjD,OAAO,EAAE,WAAW,EAAE,MAAM,8BAA8B,CAAA;AAC1D,OAAO,KAAK,QAAQ,MAAM,iBAAiB,CAAA;AAC3C,OAAO,KAAK,MAAM,MAAM,eAAe,CAAA;AACvC,OAAO,KAAK,IAAI,MAAM,aAAa,CAAA;AACnC,OAAO,KAAK,KAAK,MAAM,cAAc,CAAA;AACrC,OAAO,KAAK,KAAK,MAAM,cAAc,CAAA;AAErC,MAAM,kBAAkB,GAAG,MAAM,CAAC,YAAY,EAA6B,CAAC;IAC1E,KAAK,CAAC,EAAE,KAAK,EAAE,MAAM,EAAE,YAAY,EAAE;QACnC,OAAO,MAAM,CAAC,OAAO,CAAC,QAAQ,CAAC,IAAI,EAAqB,EAAE,CAAC,YAAY,EAAE,EAAE;YACzE,YAAY,CAAC,EAAE,CAAC,MAAM,EAAE,GAAG,EAAE;gBAC3B,QAAQ,CAAC,UAAU,CAAC,YAAY,EAAE,IAAI,CAAC,IAAI,CAAC,CAAA;YAC9C,CAAC,CAAC,CAAA;
|
|
1
|
+
{"version":3,"file":"ChildProcessWorker.js","sourceRoot":"","sources":["../../../src/node/ChildProcessRunner/ChildProcessWorker.ts"],"names":[],"mappings":"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"}
|