@convex-dev/workpool 0.1.2 → 0.2.0-alpha.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +155 -17
- package/dist/commonjs/client/index.d.ts +123 -35
- package/dist/commonjs/client/index.d.ts.map +1 -1
- package/dist/commonjs/client/index.js +122 -15
- package/dist/commonjs/client/index.js.map +1 -1
- package/dist/commonjs/client/utils.d.ts +16 -0
- package/dist/commonjs/client/utils.d.ts.map +1 -0
- package/dist/commonjs/client/utils.js +2 -0
- package/dist/commonjs/client/utils.js.map +1 -0
- package/dist/commonjs/component/complete.d.ts +89 -0
- package/dist/commonjs/component/complete.d.ts.map +1 -0
- package/dist/commonjs/component/complete.js +80 -0
- package/dist/commonjs/component/complete.js.map +1 -0
- package/dist/commonjs/component/convex.config.d.ts.map +1 -1
- package/dist/commonjs/component/convex.config.js +0 -2
- package/dist/commonjs/component/convex.config.js.map +1 -1
- package/dist/commonjs/component/kick.d.ts +9 -0
- package/dist/commonjs/component/kick.d.ts.map +1 -0
- package/dist/commonjs/component/kick.js +97 -0
- package/dist/commonjs/component/kick.js.map +1 -0
- package/dist/commonjs/component/lib.d.ts +23 -32
- package/dist/commonjs/component/lib.d.ts.map +1 -1
- package/dist/commonjs/component/lib.js +91 -563
- package/dist/commonjs/component/lib.js.map +1 -1
- package/dist/commonjs/component/logging.d.ts +5 -3
- package/dist/commonjs/component/logging.d.ts.map +1 -1
- package/dist/commonjs/component/logging.js +13 -2
- package/dist/commonjs/component/logging.js.map +1 -1
- package/dist/commonjs/component/loop.d.ts +13 -0
- package/dist/commonjs/component/loop.d.ts.map +1 -0
- package/dist/commonjs/component/loop.js +482 -0
- package/dist/commonjs/component/loop.js.map +1 -0
- package/dist/commonjs/component/recovery.d.ts +24 -0
- package/dist/commonjs/component/recovery.d.ts.map +1 -0
- package/dist/commonjs/component/recovery.js +94 -0
- package/dist/commonjs/component/recovery.js.map +1 -0
- package/dist/commonjs/component/schema.d.ts +167 -93
- package/dist/commonjs/component/schema.d.ts.map +1 -1
- package/dist/commonjs/component/schema.js +56 -65
- package/dist/commonjs/component/schema.js.map +1 -1
- package/dist/commonjs/component/shared.d.ts +138 -0
- package/dist/commonjs/component/shared.d.ts.map +1 -0
- package/dist/commonjs/component/shared.js +77 -0
- package/dist/commonjs/component/shared.js.map +1 -0
- package/dist/commonjs/component/stats.d.ts +6 -3
- package/dist/commonjs/component/stats.d.ts.map +1 -1
- package/dist/commonjs/component/stats.js +23 -4
- package/dist/commonjs/component/stats.js.map +1 -1
- package/dist/commonjs/component/worker.d.ts +15 -0
- package/dist/commonjs/component/worker.d.ts.map +1 -0
- package/dist/commonjs/component/worker.js +73 -0
- package/dist/commonjs/component/worker.js.map +1 -0
- package/dist/esm/client/index.d.ts +123 -35
- package/dist/esm/client/index.d.ts.map +1 -1
- package/dist/esm/client/index.js +122 -15
- package/dist/esm/client/index.js.map +1 -1
- package/dist/esm/client/utils.d.ts +16 -0
- package/dist/esm/client/utils.d.ts.map +1 -0
- package/dist/esm/client/utils.js +2 -0
- package/dist/esm/client/utils.js.map +1 -0
- package/dist/esm/component/complete.d.ts +89 -0
- package/dist/esm/component/complete.d.ts.map +1 -0
- package/dist/esm/component/complete.js +80 -0
- package/dist/esm/component/complete.js.map +1 -0
- package/dist/esm/component/convex.config.d.ts.map +1 -1
- package/dist/esm/component/convex.config.js +0 -2
- package/dist/esm/component/convex.config.js.map +1 -1
- package/dist/esm/component/kick.d.ts +9 -0
- package/dist/esm/component/kick.d.ts.map +1 -0
- package/dist/esm/component/kick.js +97 -0
- package/dist/esm/component/kick.js.map +1 -0
- package/dist/esm/component/lib.d.ts +23 -32
- package/dist/esm/component/lib.d.ts.map +1 -1
- package/dist/esm/component/lib.js +91 -563
- package/dist/esm/component/lib.js.map +1 -1
- package/dist/esm/component/logging.d.ts +5 -3
- package/dist/esm/component/logging.d.ts.map +1 -1
- package/dist/esm/component/logging.js +13 -2
- package/dist/esm/component/logging.js.map +1 -1
- package/dist/esm/component/loop.d.ts +13 -0
- package/dist/esm/component/loop.d.ts.map +1 -0
- package/dist/esm/component/loop.js +482 -0
- package/dist/esm/component/loop.js.map +1 -0
- package/dist/esm/component/recovery.d.ts +24 -0
- package/dist/esm/component/recovery.d.ts.map +1 -0
- package/dist/esm/component/recovery.js +94 -0
- package/dist/esm/component/recovery.js.map +1 -0
- package/dist/esm/component/schema.d.ts +167 -93
- package/dist/esm/component/schema.d.ts.map +1 -1
- package/dist/esm/component/schema.js +56 -65
- package/dist/esm/component/schema.js.map +1 -1
- package/dist/esm/component/shared.d.ts +138 -0
- package/dist/esm/component/shared.d.ts.map +1 -0
- package/dist/esm/component/shared.js +77 -0
- package/dist/esm/component/shared.js.map +1 -0
- package/dist/esm/component/stats.d.ts +6 -3
- package/dist/esm/component/stats.d.ts.map +1 -1
- package/dist/esm/component/stats.js +23 -4
- package/dist/esm/component/stats.js.map +1 -1
- package/dist/esm/component/worker.d.ts +15 -0
- package/dist/esm/component/worker.d.ts.map +1 -0
- package/dist/esm/component/worker.js +73 -0
- package/dist/esm/component/worker.js.map +1 -0
- package/package.json +6 -5
- package/src/client/index.ts +232 -68
- package/src/client/utils.ts +45 -0
- package/src/component/README.md +73 -0
- package/src/component/_generated/api.d.ts +38 -66
- package/src/component/complete.test.ts +508 -0
- package/src/component/complete.ts +98 -0
- package/src/component/convex.config.ts +0 -3
- package/src/component/kick.test.ts +285 -0
- package/src/component/kick.ts +118 -0
- package/src/component/lib.test.ts +448 -0
- package/src/component/lib.ts +105 -667
- package/src/component/logging.ts +24 -12
- package/src/component/loop.test.ts +1204 -0
- package/src/component/loop.ts +637 -0
- package/src/component/recovery.test.ts +541 -0
- package/src/component/recovery.ts +96 -0
- package/src/component/schema.ts +61 -77
- package/src/component/setup.test.ts +5 -0
- package/src/component/shared.ts +141 -0
- package/src/component/stats.ts +26 -8
- package/src/component/worker.ts +81 -0
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"lib.js","sourceRoot":"","sources":["../../../src/component/lib.ts"],"names":[],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"lib.js","sourceRoot":"","sources":["../../../src/component/lib.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,CAAC,EAAE,MAAM,eAAe,CAAC;AAClC,OAAO,EAAE,QAAQ,EAAe,KAAK,EAAE,MAAM,wBAAwB,CAAC;AACtE,OAAO,EACL,WAAW,EACX,UAAU,EACV,aAAa,EACb,MAAM,EACN,MAAM,IAAI,eAAe,EACzB,SAAS,EACT,kBAAkB,GACnB,MAAM,aAAa,CAAC;AACrB,OAAO,EAAY,QAAQ,EAAE,MAAM,cAAc,CAAC;AAClD,OAAO,EAAE,YAAY,EAAE,MAAM,WAAW,CAAC;AACzC,OAAO,EAAE,GAAG,EAAE,MAAM,qBAAqB,CAAC;AAC1C,OAAO,EAAE,YAAY,EAAE,MAAM,cAAc,CAAC;AAG5C,MAAM,wBAAwB,GAAG,GAAG,CAAC;AAErC,MAAM,CAAC,MAAM,OAAO,GAAG,QAAQ,CAAC;IAC9B,IAAI,EAAE;QACJ,QAAQ,EAAE,CAAC,CAAC,MAAM,EAAE;QACpB,MAAM,EAAE,CAAC,CAAC,MAAM,EAAE;QAClB,MAAM,EAAE,CAAC,CAAC,GAAG,EAAE;QACf,MAAM,EAAE,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,OAAO,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC,OAAO,CAAC,UAAU,CAAC,CAAC;QAC3D,KAAK,EAAE,CAAC,CAAC,MAAM,EAAE;QACjB,oBAAoB;QACpB,UAAU,EAAE,CAAC,CAAC,QAAQ,CAAC,UAAU,CAAC;QAClC,aAAa,EAAE,CAAC,CAAC,QAAQ,CAAC,aAAa,CAAC;QACxC,MAAM;KACP;IACD,OAAO,EAAE,CAAC,CAAC,EAAE,CAAC,MAAM,CAAC;IACrB,OAAO,EAAE,KAAK,EAAE,GAAG,EAAE,EAAE,MAAM,EAAE,KAAK,EAAE,GAAG,QAAQ,EAAE,EAAE,EAAE;QACrD,MAAM,OAAO,GAAG,YAAY,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC;QAC9C,IAAI,MAAM,CAAC,cAAc,GAAG,wBAAwB,EAAE;YACpD,MAAM,IAAI,KAAK,CAAC,6BAA6B,wBAAwB,EAAE,CAAC,CAAC;SAC1E;QACD,IAAI,MAAM,CAAC,cAAc,GAAG,CAAC,EAAE;YAC7B,MAAM,IAAI,KAAK,CAAC,6BAA6B,CAAC,CAAC;SAChD;QACD,KAAK,GAAG,kBAAkB,CAAC,KAAK,EAAE,OAAO,CAAC,CAAC;QAC3C,MAAM,MAAM,GAAG,MAAM,GAAG,CAAC,EAAE,CAAC,MAAM,CAAC,MAAM,EAAE;YACzC,GAAG,QAAQ;YACX,QAAQ,EAAE,CAAC;SACZ,CAAC,CAAC;QACH,MAAM,GAAG,CAAC,EAAE,CAAC,MAAM,CAAC,cAAc,EAAE;YAClC,MAAM;YACN,OAAO,EAAE,SAAS,CAAC,KAAK,CAAC;SAC1B,CAAC,CAAC;QACH,MAAM,YAAY,CAAC,GAAG,EAAE,SAAS,EAAE,MAAM,CAAC,CAAC;QAC3C,oBAAoB;QACpB,OAAO,MAAM,CAAC;IAChB,CAAC;CACF,CAAC,CAAC;AAEH,MAAM,CAAC,MAAM,MAAM,GAAG,QAAQ,CAAC;IAC7B,IAAI,EAAE;QACJ,EAAE,EAAE,CAAC,CAAC,EAAE,CAAC,MAAM,CAAC;QAChB,QAAQ;KACT;IACD,OAAO,EAAE,KAAK,EAAE,GAAG,EAAE,EAAE,EAAE,EAAE,QAAQ,EAAE,EAAE,EAAE;QACvC,MAAM,QAAQ,GAAG,MAAM,cAAc,CAAC,GAAG,EAAE,EAAE,EAAE,WAAW,EAAE,EAAE,QAAQ,CAAC,CAAC;QACxE,IAAI,QAAQ,EAAE;YACZ,MAAM,YAAY,CAAC,GAAG,EAAE,QAAQ,EAAE,EAAE,QAAQ,EAAE,CAAC,CAAC;SACjD;QACD,oBAAoB;IACtB,CAAC;CACF,CAAC,CAAC;AAEH,MAAM,SAAS,GAAG,EAAE,CAAC;AACrB,MAAM,CAAC,MAAM,SAAS,GAAG,QAAQ,CAAC;IAChC,IAAI,EAAE,EAAE,QAAQ,EAAE,MAAM,EAAE,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,MAAM,EAAE,CAAC,EAAE;IAClD,OAAO,EAAE,KAAK,EAAE,GAAG,EAAE,EAAE,QAAQ,EAAE,MAAM,EAAE,EAAE,EAAE;QAC3C,MAAM,UAAU,GAAG,MAAM,IAAI,IAAI,CAAC,GAAG,EAAE,CAAC;QACxC,MAAM,OAAO,GAAG,WAAW,EAAE,CAAC;QAC9B,MAAM,UAAU,GAAG,MAAM,GAAG,CAAC,EAAE;aAC5B,KAAK,CAAC,MAAM,CAAC;aACb,SAAS,CAAC,kBAAkB,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,GAAG,CAAC,eAAe,EAAE,UAAU,CAAC,CAAC;aACxE,KAAK,CAAC,MAAM,CAAC;aACb,IAAI,CAAC,SAAS,CAAC,CAAC;QACnB,MAAM,QAAQ,GAAG,MAAM,OAAO,CAAC,GAAG,CAChC,UAAU,CAAC,GAAG,CAAC,KAAK,EAAE,EAAE,GAAG,EAAE,EAAE,EAAE,CAC/B,cAAc,CAAC,GAAG,EAAE,GAAG,EAAE,OAAO,EAAE,QAAQ,CAAC,CAC5C,CACF,CAAC;QACF,IAAI,QAAQ,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,EAAE;YAC3B,MAAM,YAAY,CAAC,GAAG,EAAE,QAAQ,EAAE,EAAE,QAAQ,EAAE,CAAC,CAAC;SACjD;QACD,IAAI,UAAU,CAAC,MAAM,KAAK,SAAS,EAAE;YACnC,MAAM,GAAG,CAAC,SAAS,CAAC,QAAQ,CAAC,CAAC,EAAE,GAAG,CAAC,GAAG,CAAC,SAAS,EAAE;gBACjD,QAAQ;gBACR,MAAM,EAAE,UAAU,CAAC,UAAU,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,aAAa;aACxD,CAAC,CAAC;SACJ;IACH,CAAC;CACF,CAAC,CAAC;AAEH,MAAM,CAAC,MAAM,MAAM,GAAG,KAAK,CAAC;IAC1B,IAAI,EAAE,EAAE,EAAE,EAAE,CAAC,CAAC,EAAE,CAAC,MAAM,CAAC,EAAE;IAC1B,OAAO,EAAE,eAAe;IACxB,OAAO,EAAE,KAAK,EAAE,GAAG,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE;QAC7B,MAAM,IAAI,GAAG,MAAM,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;QAClC,IAAI,CAAC,IAAI,EAAE;YACT,OAAO,EAAE,KAAK,EAAE,UAAU,EAAW,CAAC;SACvC;QACD,MAAM,YAAY,GAAG,MAAM,GAAG,CAAC,EAAE;aAC9B,KAAK,CAAC,cAAc,CAAC;aACrB,SAAS,CAAC,QAAQ,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,QAAQ,EAAE,EAAE,CAAC,CAAC;aAC9C,MAAM,EAAE,CAAC;QACZ,IAAI,YAAY,EAAE;YAChB,OAAO,EAAE,KAAK,EAAE,SAAS,EAAE,gBAAgB,EAAE,IAAI,CAAC,QAAQ,EAAW,CAAC;SACvE;QACD,MAAM,iBAAiB,GAAG,MAAM,GAAG,CAAC,EAAE;aACnC,KAAK,CAAC,mBAAmB,CAAC;aAC1B,SAAS,CAAC,QAAQ,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,QAAQ,EAAE,EAAE,CAAC,CAAC;aAC9C,MAAM,EAAE,CAAC;QACZ,IAAI,iBAAiB,EAAE,KAAK,EAAE;YAC5B,OAAO,EAAE,KAAK,EAAE,SAAS,EAAE,gBAAgB,EAAE,IAAI,CAAC,QAAQ,EAAW,CAAC;SACvE;QACD,2DAA2D;QAC3D,OAAO,EAAE,KAAK,EAAE,SAAS,EAAE,gBAAgB,EAAE,IAAI,CAAC,QAAQ,EAAW,CAAC;IACxE,CAAC;CACF,CAAC,CAAC;AAEH,KAAK,UAAU,cAAc,CAC3B,GAAgB,EAChB,MAAkB,EAClB,OAAe,EACf,QAAkB;IAElB,MAAM,OAAO,GAAG,YAAY,CAAC,QAAQ,CAAC,CAAC;IACvC,oDAAoD;IACpD,MAAM,IAAI,GAAG,MAAM,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC;IACtC,IAAI,CAAC,IAAI,EAAE;QACT,OAAO,CAAC,IAAI,CAAC,iBAAiB,MAAM,gBAAgB,CAAC,CAAC;QACtD,OAAO,KAAK,CAAC;KACd;IACD,MAAM,kBAAkB,GAAG,MAAM,GAAG,CAAC,EAAE;SACpC,KAAK,CAAC,oBAAoB,CAAC;SAC3B,SAAS,CAAC,QAAQ,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,QAAQ,EAAE,MAAM,CAAC,CAAC;SAClD,MAAM,EAAE,CAAC;IACZ,IAAI,kBAAkB,EAAE;QACtB,OAAO,CAAC,IAAI,CAAC,iBAAiB,MAAM,4BAA4B,CAAC,CAAC;QAClE,OAAO,KAAK,CAAC;KACd;IACD,MAAM,GAAG,CAAC,EAAE,CAAC,MAAM,CAAC,oBAAoB,EAAE;QACxC,MAAM;QACN,OAAO;KACR,CAAC,CAAC;IACH,OAAO,IAAI,CAAC;AACd,CAAC;AAED,6DAA6D;AAC7D,MAAM,OAAO,GAAG,wCAAwC,CAAC"}
|
|
@@ -1,6 +1,5 @@
|
|
|
1
1
|
import { Infer } from "convex/values";
|
|
2
|
-
export declare const
|
|
3
|
-
export type LogLevel = Infer<typeof logLevel>;
|
|
2
|
+
export declare const DEFAULT_LOG_LEVEL: LogLevel;
|
|
4
3
|
export type Logger = {
|
|
5
4
|
debug: (...args: unknown[]) => void;
|
|
6
5
|
info: (...args: unknown[]) => void;
|
|
@@ -8,6 +7,9 @@ export type Logger = {
|
|
|
8
7
|
error: (...args: unknown[]) => void;
|
|
9
8
|
time: (label: string) => void;
|
|
10
9
|
timeEnd: (label: string) => void;
|
|
10
|
+
event: (event: string, payload: Record<string, unknown>) => void;
|
|
11
11
|
};
|
|
12
|
-
export declare function createLogger(level
|
|
12
|
+
export declare function createLogger(level?: LogLevel): Logger;
|
|
13
|
+
export declare const logLevel: import("convex/values").VUnion<"DEBUG" | "INFO" | "WARN" | "ERROR", [import("convex/values").VLiteral<"DEBUG", "required">, import("convex/values").VLiteral<"INFO", "required">, import("convex/values").VLiteral<"WARN", "required">, import("convex/values").VLiteral<"ERROR", "required">], "required", never>;
|
|
14
|
+
export type LogLevel = Infer<typeof logLevel>;
|
|
13
15
|
//# sourceMappingURL=logging.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"logging.d.ts","sourceRoot":"","sources":["../../../src/component/logging.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"logging.d.ts","sourceRoot":"","sources":["../../../src/component/logging.ts"],"names":[],"mappings":"AAAA,OAAO,EAAK,KAAK,EAAE,MAAM,eAAe,CAAC;AAEzC,eAAO,MAAM,iBAAiB,EAAE,QAAiB,CAAC;AAElD,MAAM,MAAM,MAAM,GAAG;IACnB,KAAK,EAAE,CAAC,GAAG,IAAI,EAAE,OAAO,EAAE,KAAK,IAAI,CAAC;IACpC,IAAI,EAAE,CAAC,GAAG,IAAI,EAAE,OAAO,EAAE,KAAK,IAAI,CAAC;IACnC,IAAI,EAAE,CAAC,GAAG,IAAI,EAAE,OAAO,EAAE,KAAK,IAAI,CAAC;IACnC,KAAK,EAAE,CAAC,GAAG,IAAI,EAAE,OAAO,EAAE,KAAK,IAAI,CAAC;IACpC,IAAI,EAAE,CAAC,KAAK,EAAE,MAAM,KAAK,IAAI,CAAC;IAC9B,OAAO,EAAE,CAAC,KAAK,EAAE,MAAM,KAAK,IAAI,CAAC;IACjC,KAAK,EAAE,CAAC,KAAK,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,KAAK,IAAI,CAAC;CAClE,CAAC;AAEF,wBAAgB,YAAY,CAAC,KAAK,CAAC,EAAE,QAAQ,GAAG,MAAM,CAiDrD;AACD,eAAO,MAAM,QAAQ,oTAKpB,CAAC;AACF,MAAM,MAAM,QAAQ,GAAG,KAAK,CAAC,OAAO,QAAQ,CAAC,CAAC"}
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import { v } from "convex/values";
|
|
2
|
-
export const
|
|
2
|
+
export const DEFAULT_LOG_LEVEL = "WARN";
|
|
3
3
|
export function createLogger(level) {
|
|
4
|
-
const levelIndex = ["DEBUG", "INFO", "WARN", "ERROR"].indexOf(level);
|
|
4
|
+
const levelIndex = ["DEBUG", "INFO", "WARN", "ERROR"].indexOf(level ?? DEFAULT_LOG_LEVEL);
|
|
5
5
|
if (levelIndex === -1) {
|
|
6
6
|
throw new Error(`Invalid log level: ${level}`);
|
|
7
7
|
}
|
|
@@ -36,6 +36,17 @@ export function createLogger(level) {
|
|
|
36
36
|
console.timeEnd(label);
|
|
37
37
|
}
|
|
38
38
|
},
|
|
39
|
+
event: (event, payload) => {
|
|
40
|
+
if (levelIndex <= 1) {
|
|
41
|
+
const fullPayload = {
|
|
42
|
+
system: "idempotent-workpool-component",
|
|
43
|
+
event,
|
|
44
|
+
payload,
|
|
45
|
+
};
|
|
46
|
+
console.info(JSON.stringify(fullPayload));
|
|
47
|
+
}
|
|
48
|
+
},
|
|
39
49
|
};
|
|
40
50
|
}
|
|
51
|
+
export const logLevel = v.union(v.literal("DEBUG"), v.literal("INFO"), v.literal("WARN"), v.literal("ERROR"));
|
|
41
52
|
//# sourceMappingURL=logging.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"logging.js","sourceRoot":"","sources":["../../../src/component/logging.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,CAAC,
|
|
1
|
+
{"version":3,"file":"logging.js","sourceRoot":"","sources":["../../../src/component/logging.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,CAAC,EAAS,MAAM,eAAe,CAAC;AAEzC,MAAM,CAAC,MAAM,iBAAiB,GAAa,MAAM,CAAC;AAYlD,MAAM,UAAU,YAAY,CAAC,KAAgB;IAC3C,MAAM,UAAU,GAAG,CAAC,OAAO,EAAE,MAAM,EAAE,MAAM,EAAE,OAAO,CAAC,CAAC,OAAO,CAC3D,KAAK,IAAI,iBAAiB,CAC3B,CAAC;IACF,IAAI,UAAU,KAAK,CAAC,CAAC,EAAE;QACrB,MAAM,IAAI,KAAK,CAAC,sBAAsB,KAAK,EAAE,CAAC,CAAC;KAChD;IACD,OAAO;QACL,KAAK,EAAE,CAAC,GAAG,IAAe,EAAE,EAAE;YAC5B,IAAI,UAAU,IAAI,CAAC,EAAE;gBACnB,OAAO,CAAC,KAAK,CAAC,GAAG,IAAI,CAAC,CAAC;aACxB;QACH,CAAC;QACD,IAAI,EAAE,CAAC,GAAG,IAAe,EAAE,EAAE;YAC3B,IAAI,UAAU,IAAI,CAAC,EAAE;gBACnB,OAAO,CAAC,IAAI,CAAC,GAAG,IAAI,CAAC,CAAC;aACvB;QACH,CAAC;QACD,IAAI,EAAE,CAAC,GAAG,IAAe,EAAE,EAAE;YAC3B,IAAI,UAAU,IAAI,CAAC,EAAE;gBACnB,OAAO,CAAC,IAAI,CAAC,GAAG,IAAI,CAAC,CAAC;aACvB;QACH,CAAC;QACD,KAAK,EAAE,CAAC,GAAG,IAAe,EAAE,EAAE;YAC5B,IAAI,UAAU,IAAI,CAAC,EAAE;gBACnB,OAAO,CAAC,KAAK,CAAC,GAAG,IAAI,CAAC,CAAC;aACxB;QACH,CAAC;QACD,IAAI,EAAE,CAAC,KAAa,EAAE,EAAE;YACtB,IAAI,UAAU,IAAI,CAAC,EAAE;gBACnB,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;aACrB;QACH,CAAC;QACD,OAAO,EAAE,CAAC,KAAa,EAAE,EAAE;YACzB,IAAI,UAAU,IAAI,CAAC,EAAE;gBACnB,OAAO,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC;aACxB;QACH,CAAC;QACD,KAAK,EAAE,CAAC,KAAa,EAAE,OAAgC,EAAE,EAAE;YACzD,IAAI,UAAU,IAAI,CAAC,EAAE;gBACnB,MAAM,WAAW,GAAG;oBAClB,MAAM,EAAE,+BAA+B;oBACvC,KAAK;oBACL,OAAO;iBACR,CAAC;gBACF,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,WAAW,CAAC,CAAC,CAAC;aAC3C;QACH,CAAC;KACF,CAAC;AACJ,CAAC;AACD,MAAM,CAAC,MAAM,QAAQ,GAAG,CAAC,CAAC,KAAK,CAC7B,CAAC,CAAC,OAAO,CAAC,OAAO,CAAC,EAClB,CAAC,CAAC,OAAO,CAAC,MAAM,CAAC,EACjB,CAAC,CAAC,OAAO,CAAC,MAAM,CAAC,EACjB,CAAC,CAAC,OAAO,CAAC,OAAO,CAAC,CACnB,CAAC"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import { WithoutSystemFields } from "convex/server";
|
|
2
|
+
import { Doc } from "./_generated/dataModel.js";
|
|
3
|
+
export declare const INITIAL_STATE: WithoutSystemFields<Doc<"internalState">>;
|
|
4
|
+
export declare const main: import("convex/server").RegisteredMutation<"internal", {
|
|
5
|
+
generation: bigint;
|
|
6
|
+
segment: bigint;
|
|
7
|
+
}, Promise<void>>;
|
|
8
|
+
export declare const updateRunStatus: import("convex/server").RegisteredMutation<"internal", {
|
|
9
|
+
generation: bigint;
|
|
10
|
+
segment: bigint;
|
|
11
|
+
}, Promise<void>>;
|
|
12
|
+
export declare function withJitter(delay: number): number;
|
|
13
|
+
//# sourceMappingURL=loop.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"loop.d.ts","sourceRoot":"","sources":["../../../src/component/loop.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,mBAAmB,EAAE,MAAM,eAAe,CAAC;AAGpD,OAAO,EAAE,GAAG,EAAM,MAAM,2BAA2B,CAAC;AA4BpD,eAAO,MAAM,aAAa,EAAE,mBAAmB,CAAC,GAAG,CAAC,eAAe,CAAC,CAanE,CAAC;AAGF,eAAO,MAAM,IAAI;;;iBAgEf,CAAC;AAEH,eAAO,MAAM,eAAe;;;iBA6H1B,CAAC;AAyWH,wBAAgB,UAAU,CAAC,KAAK,EAAE,MAAM,UAEvC"}
|
|
@@ -0,0 +1,482 @@
|
|
|
1
|
+
import { v } from "convex/values";
|
|
2
|
+
import { internal } from "./_generated/api.js";
|
|
3
|
+
import { internalMutation } from "./_generated/server.js";
|
|
4
|
+
import { DEFAULT_MAX_PARALLELISM } from "./kick.js";
|
|
5
|
+
import { createLogger, DEFAULT_LOG_LEVEL, } from "./logging.js";
|
|
6
|
+
import { boundScheduledTime, currentSegment, fromSegment, max, nextSegment, toSegment, } from "./shared.js";
|
|
7
|
+
import { recordCompleted, recordReport, recordStarted } from "./stats.js";
|
|
8
|
+
const CANCELLATION_BATCH_SIZE = 64; // the only queue that can get unbounded.
|
|
9
|
+
const SECOND = 1000;
|
|
10
|
+
const MINUTE = 60 * SECOND;
|
|
11
|
+
const RECOVERY_THRESHOLD_MS = 5 * MINUTE; // attempt to recover jobs this old.
|
|
12
|
+
const RECOVERY_PERIOD_SEGMENTS = toSegment(1 * MINUTE); // how often to check.
|
|
13
|
+
const CURSOR_BUFFER_SEGMENTS = toSegment(2 * SECOND); // buffer for cursor updates.
|
|
14
|
+
export const INITIAL_STATE = {
|
|
15
|
+
generation: 0n,
|
|
16
|
+
segmentCursors: { incoming: 0n, completion: 0n, cancelation: 0n },
|
|
17
|
+
lastRecovery: 0n,
|
|
18
|
+
report: {
|
|
19
|
+
completed: 0,
|
|
20
|
+
succeeded: 0,
|
|
21
|
+
failed: 0,
|
|
22
|
+
retries: 0,
|
|
23
|
+
canceled: 0,
|
|
24
|
+
lastReportTs: 0,
|
|
25
|
+
},
|
|
26
|
+
running: [],
|
|
27
|
+
};
|
|
28
|
+
// There should only ever be at most one of these scheduled or running.
|
|
29
|
+
export const main = internalMutation({
|
|
30
|
+
args: { generation: v.int64(), segment: v.int64() },
|
|
31
|
+
handler: async (ctx, args) => {
|
|
32
|
+
// State will be modified and patched at the end of the function.
|
|
33
|
+
const state = await getOrCreateState(ctx);
|
|
34
|
+
if (args.generation !== state.generation) {
|
|
35
|
+
throw new Error(`generation mismatch: ${args.generation} !== ${state.generation}`);
|
|
36
|
+
}
|
|
37
|
+
state.generation++;
|
|
38
|
+
const globals = await getGlobals(ctx);
|
|
39
|
+
const console = createLogger(globals.logLevel);
|
|
40
|
+
// Read pendingCompletions, including retry handling.
|
|
41
|
+
console.time("[main] pendingCompletion");
|
|
42
|
+
const toCancel = await handleCompletions(ctx, state, args.segment, console);
|
|
43
|
+
console.timeEnd("[main] pendingCompletion");
|
|
44
|
+
// Read pendingCancelation, deleting from pendingStart. If it's still running, queue to cancel.
|
|
45
|
+
console.time("[main] pendingCancelation");
|
|
46
|
+
await handleCancelation(ctx, state, args.segment, console, toCancel);
|
|
47
|
+
console.timeEnd("[main] pendingCancelation");
|
|
48
|
+
if (state.running.length === 0) {
|
|
49
|
+
// If there's nothing active, reset lastRecovery.
|
|
50
|
+
state.lastRecovery = args.segment;
|
|
51
|
+
}
|
|
52
|
+
else if (args.segment - state.lastRecovery >= RECOVERY_PERIOD_SEGMENTS) {
|
|
53
|
+
// Otherwise schedule recovery for any old jobs.
|
|
54
|
+
await handleRecovery(ctx, state, console);
|
|
55
|
+
state.lastRecovery = args.segment;
|
|
56
|
+
}
|
|
57
|
+
// Read pendingStart up to max capacity. Update the config, and incomingSegmentCursor.
|
|
58
|
+
console.time("[main] pendingStart");
|
|
59
|
+
await handleStart(ctx, state, args.segment, console, globals);
|
|
60
|
+
console.timeEnd("[main] pendingStart");
|
|
61
|
+
if (Date.now() - state.report.lastReportTs >= MINUTE) {
|
|
62
|
+
// If minute rollover since last report, log report.
|
|
63
|
+
// Try to avoid clock skew by shifting by a minute.
|
|
64
|
+
let lastReportTs = state.report.lastReportTs + MINUTE;
|
|
65
|
+
if (Date.now() > lastReportTs + MINUTE / 2) {
|
|
66
|
+
// It's been a while, let's start fresh.
|
|
67
|
+
lastReportTs = Date.now();
|
|
68
|
+
}
|
|
69
|
+
console.info(recordReport(state));
|
|
70
|
+
state.report = {
|
|
71
|
+
completed: 0,
|
|
72
|
+
succeeded: 0,
|
|
73
|
+
failed: 0,
|
|
74
|
+
retries: 0,
|
|
75
|
+
canceled: 0,
|
|
76
|
+
lastReportTs,
|
|
77
|
+
};
|
|
78
|
+
}
|
|
79
|
+
await ctx.db.replace(state._id, state);
|
|
80
|
+
await ctx.scheduler.runAfter(0, internal.loop.updateRunStatus, {
|
|
81
|
+
generation: state.generation,
|
|
82
|
+
segment: args.segment,
|
|
83
|
+
});
|
|
84
|
+
},
|
|
85
|
+
});
|
|
86
|
+
export const updateRunStatus = internalMutation({
|
|
87
|
+
args: { generation: v.int64(), segment: v.int64() },
|
|
88
|
+
handler: async (ctx, args) => {
|
|
89
|
+
const globals = await getGlobals(ctx);
|
|
90
|
+
const console = createLogger(globals.logLevel);
|
|
91
|
+
const maxParallelism = globals.maxParallelism;
|
|
92
|
+
const state = await getOrCreateState(ctx);
|
|
93
|
+
if (args.generation !== state.generation) {
|
|
94
|
+
throw new Error(`generation mismatch: ${args.generation} !== ${state.generation}`);
|
|
95
|
+
}
|
|
96
|
+
console.time("[updateRunStatus] outstandingCancelations");
|
|
97
|
+
const outstandingCancelations = await getNextUp(ctx, "pendingCancelation", {
|
|
98
|
+
start: state.segmentCursors.cancelation,
|
|
99
|
+
end: args.segment,
|
|
100
|
+
});
|
|
101
|
+
console.timeEnd("[updateRunStatus] outstandingCancelations");
|
|
102
|
+
if (outstandingCancelations) {
|
|
103
|
+
await ctx.scheduler.runAfter(0, internal.loop.main, {
|
|
104
|
+
generation: args.generation,
|
|
105
|
+
segment: args.segment,
|
|
106
|
+
});
|
|
107
|
+
return;
|
|
108
|
+
}
|
|
109
|
+
// TODO: check for current segment (or from args) first, to avoid OCCs.
|
|
110
|
+
console.time("[updateRunStatus] nextSegmentIsActionable");
|
|
111
|
+
const next = max(args.segment + 1n, currentSegment());
|
|
112
|
+
const nextIsActionable = await nextSegmentIsActionable(ctx, state, maxParallelism, next);
|
|
113
|
+
console.timeEnd("[updateRunStatus] nextSegmentIsActionable");
|
|
114
|
+
if (nextIsActionable) {
|
|
115
|
+
await ctx.scheduler.runAt(boundScheduledTime(fromSegment(next), console), internal.loop.main, {
|
|
116
|
+
generation: args.generation,
|
|
117
|
+
segment: next,
|
|
118
|
+
});
|
|
119
|
+
return;
|
|
120
|
+
}
|
|
121
|
+
console.time("[updateRunStatus] oldSegmentIsActionable");
|
|
122
|
+
const [oldIsActionable, cursors] = await oldSegmentIsActionable(ctx, state, maxParallelism);
|
|
123
|
+
console.timeEnd("[updateRunStatus] oldSegmentIsActionable");
|
|
124
|
+
if (oldIsActionable) {
|
|
125
|
+
await ctx.db.patch(state._id, {
|
|
126
|
+
segmentCursors: {
|
|
127
|
+
...state.segmentCursors,
|
|
128
|
+
...cursors,
|
|
129
|
+
},
|
|
130
|
+
});
|
|
131
|
+
await ctx.scheduler.runAfter(0, internal.loop.main, {
|
|
132
|
+
generation: args.generation,
|
|
133
|
+
segment: currentSegment(),
|
|
134
|
+
});
|
|
135
|
+
return;
|
|
136
|
+
}
|
|
137
|
+
// Find next actionable segment (min next segment).
|
|
138
|
+
console.time("[updateRunStatus] findNextSegment");
|
|
139
|
+
const actionableTables = ["pendingCompletion", "pendingCancelation"];
|
|
140
|
+
if (state.running.length < maxParallelism) {
|
|
141
|
+
actionableTables.push("pendingStart");
|
|
142
|
+
}
|
|
143
|
+
const docs = await Promise.all(actionableTables.map(async (tableName) => getNextUp(ctx, tableName, { start: next })));
|
|
144
|
+
console.timeEnd("[updateRunStatus] findNextSegment");
|
|
145
|
+
let segment = docs.map((d) => d?.segment).sort()[0];
|
|
146
|
+
const runStatus = await getOrCreateRunningStatus(ctx);
|
|
147
|
+
const saturated = state.running.length >= maxParallelism;
|
|
148
|
+
if (segment !== undefined || state.running.length > 0) {
|
|
149
|
+
// If there's something to do, schedule for next actionable segment.
|
|
150
|
+
// Or the next recovery, whichever comes first.
|
|
151
|
+
const nextRecoverySegment = state.lastRecovery + RECOVERY_PERIOD_SEGMENTS;
|
|
152
|
+
if (!segment || segment > nextRecoverySegment) {
|
|
153
|
+
segment = nextRecoverySegment;
|
|
154
|
+
}
|
|
155
|
+
const scheduledId = await ctx.scheduler.runAt(boundScheduledTime(fromSegment(segment), console), internal.loop.main, { generation: args.generation, segment });
|
|
156
|
+
if (segment > nextSegment()) {
|
|
157
|
+
await ctx.db.patch(runStatus._id, {
|
|
158
|
+
state: {
|
|
159
|
+
kind: "scheduled",
|
|
160
|
+
scheduledId,
|
|
161
|
+
saturated,
|
|
162
|
+
generation: args.generation,
|
|
163
|
+
segment,
|
|
164
|
+
},
|
|
165
|
+
});
|
|
166
|
+
}
|
|
167
|
+
else {
|
|
168
|
+
console.debug(`[updateRunStatus] staying running because it's the next segment`);
|
|
169
|
+
}
|
|
170
|
+
return;
|
|
171
|
+
}
|
|
172
|
+
// There seems to be nothing in the future to do, so go idle.
|
|
173
|
+
await ctx.db.patch(runStatus._id, {
|
|
174
|
+
state: { kind: "idle", generation: args.generation },
|
|
175
|
+
});
|
|
176
|
+
},
|
|
177
|
+
});
|
|
178
|
+
async function nextSegmentIsActionable(ctx, state, maxParallelism, end) {
|
|
179
|
+
// First, try with our cursor range, up to end.
|
|
180
|
+
if (await getNextUp(ctx, "pendingCancelation", {
|
|
181
|
+
start: state.segmentCursors.cancelation,
|
|
182
|
+
end,
|
|
183
|
+
})) {
|
|
184
|
+
return true;
|
|
185
|
+
}
|
|
186
|
+
if (await getNextUp(ctx, "pendingCompletion", {
|
|
187
|
+
start: state.segmentCursors.completion,
|
|
188
|
+
end,
|
|
189
|
+
})) {
|
|
190
|
+
return true;
|
|
191
|
+
}
|
|
192
|
+
if (state.running.length < maxParallelism) {
|
|
193
|
+
if (await getNextUp(ctx, "pendingStart", {
|
|
194
|
+
start: state.segmentCursors.incoming,
|
|
195
|
+
end,
|
|
196
|
+
})) {
|
|
197
|
+
return true;
|
|
198
|
+
}
|
|
199
|
+
}
|
|
200
|
+
return false;
|
|
201
|
+
}
|
|
202
|
+
async function oldSegmentIsActionable(ctx, state, maxParallelism) {
|
|
203
|
+
// Next, we look for out-of-order additions we may have missed.
|
|
204
|
+
const oldCompletion = await getNextUp(ctx, "pendingCompletion", {
|
|
205
|
+
end: state.segmentCursors.completion,
|
|
206
|
+
});
|
|
207
|
+
if (oldCompletion) {
|
|
208
|
+
return [true, { completion: oldCompletion.segment }];
|
|
209
|
+
}
|
|
210
|
+
const oldCancelation = await getNextUp(ctx, "pendingCancelation", {
|
|
211
|
+
end: state.segmentCursors.cancelation,
|
|
212
|
+
});
|
|
213
|
+
if (oldCancelation) {
|
|
214
|
+
return [true, { cancelation: oldCancelation.segment }];
|
|
215
|
+
}
|
|
216
|
+
if (state.running.length < maxParallelism) {
|
|
217
|
+
const oldStart = await getNextUp(ctx, "pendingStart", {
|
|
218
|
+
end: state.segmentCursors.incoming,
|
|
219
|
+
});
|
|
220
|
+
if (oldStart) {
|
|
221
|
+
return [true, { incoming: oldStart.segment }];
|
|
222
|
+
}
|
|
223
|
+
}
|
|
224
|
+
return [false, {}];
|
|
225
|
+
}
|
|
226
|
+
// Fetch the next item. If only one of start & end are provided, it's exclusive.
|
|
227
|
+
async function getNextUp(ctx, table, range) {
|
|
228
|
+
return ctx.db
|
|
229
|
+
.query(table)
|
|
230
|
+
.withIndex("segment", (q) => range.start !== undefined
|
|
231
|
+
? range.end !== undefined
|
|
232
|
+
? q
|
|
233
|
+
.gte("segment", range.start - CURSOR_BUFFER_SEGMENTS)
|
|
234
|
+
.lte("segment", range.end)
|
|
235
|
+
: q.gt("segment", range.start - CURSOR_BUFFER_SEGMENTS)
|
|
236
|
+
: range.end !== undefined
|
|
237
|
+
? q.lt("segment", range.end)
|
|
238
|
+
: q)
|
|
239
|
+
.first();
|
|
240
|
+
}
|
|
241
|
+
/**
|
|
242
|
+
* Handles the completion of pending completions.
|
|
243
|
+
* This only processes work that succeeded or failed, not canceled.
|
|
244
|
+
*/
|
|
245
|
+
async function handleCompletions(ctx, state, segment, console) {
|
|
246
|
+
const startSegment = state.segmentCursors.completion - CURSOR_BUFFER_SEGMENTS;
|
|
247
|
+
// This won't be too many because the jobs all correspond to being scheduled
|
|
248
|
+
// by a single main (the previous one), so they're limited by MAX_PARALLELISM.
|
|
249
|
+
const completed = await ctx.db
|
|
250
|
+
.query("pendingCompletion")
|
|
251
|
+
.withIndex("segment", (q) => q.gte("segment", startSegment).lte("segment", segment))
|
|
252
|
+
.collect();
|
|
253
|
+
state.segmentCursors.completion = segment;
|
|
254
|
+
// Completions that were going to be retried but have since been canceled.
|
|
255
|
+
const toCancel = [];
|
|
256
|
+
await Promise.all(completed.map(async (c) => {
|
|
257
|
+
await ctx.db.delete(c._id);
|
|
258
|
+
const running = state.running.find((r) => r.workId === c.workId);
|
|
259
|
+
if (!running) {
|
|
260
|
+
console.error(`[main] completing ${c.workId} but it's not in "running"`);
|
|
261
|
+
return;
|
|
262
|
+
}
|
|
263
|
+
if (c.retry) {
|
|
264
|
+
// Only check for work if it's going to be retried.
|
|
265
|
+
const work = await ctx.db.get(c.workId);
|
|
266
|
+
if (!work) {
|
|
267
|
+
console.warn(`[main] ${c.workId} is gone, but trying to complete`);
|
|
268
|
+
return;
|
|
269
|
+
}
|
|
270
|
+
const retried = await rescheduleJob(ctx, work, console);
|
|
271
|
+
if (retried) {
|
|
272
|
+
state.report.retries++;
|
|
273
|
+
console.info(recordCompleted(work, "retrying"));
|
|
274
|
+
}
|
|
275
|
+
else {
|
|
276
|
+
// We don't retry if it's been canceled in the mean time.
|
|
277
|
+
state.report.canceled++;
|
|
278
|
+
toCancel.push({
|
|
279
|
+
workId: c.workId,
|
|
280
|
+
runResult: { kind: "canceled" },
|
|
281
|
+
attempt: work.attempts,
|
|
282
|
+
});
|
|
283
|
+
}
|
|
284
|
+
}
|
|
285
|
+
else {
|
|
286
|
+
if (c.runResult.kind === "success") {
|
|
287
|
+
state.report.succeeded++;
|
|
288
|
+
}
|
|
289
|
+
else if (c.runResult.kind === "failed") {
|
|
290
|
+
state.report.failed++;
|
|
291
|
+
}
|
|
292
|
+
}
|
|
293
|
+
}));
|
|
294
|
+
// We do this after so the stats above know if it was in progress.
|
|
295
|
+
const before = state.running.length;
|
|
296
|
+
state.running = state.running.filter((r) => !completed.some((c) => c.workId === r.workId));
|
|
297
|
+
const numCompleted = before - state.running.length;
|
|
298
|
+
state.report.completed += numCompleted;
|
|
299
|
+
console.debug(`[main] completed ${numCompleted} work`);
|
|
300
|
+
return toCancel;
|
|
301
|
+
}
|
|
302
|
+
async function handleCancelation(ctx, state, segment, console, toCancel) {
|
|
303
|
+
const start = state.segmentCursors.cancelation - CURSOR_BUFFER_SEGMENTS;
|
|
304
|
+
const canceled = await ctx.db
|
|
305
|
+
.query("pendingCancelation")
|
|
306
|
+
.withIndex("segment", (q) => q.gte("segment", start).lte("segment", segment))
|
|
307
|
+
.take(CANCELLATION_BATCH_SIZE);
|
|
308
|
+
state.segmentCursors.cancelation = canceled.at(-1)?.segment ?? segment;
|
|
309
|
+
if (canceled.length) {
|
|
310
|
+
console.debug(`[main] attempting to cancel ${canceled.length}`);
|
|
311
|
+
}
|
|
312
|
+
const canceledWork = new Set();
|
|
313
|
+
const runResult = { kind: "canceled" };
|
|
314
|
+
const jobs = toCancel.concat(...(await Promise.all(canceled.map(async ({ _id, _creationTime, workId }) => {
|
|
315
|
+
await ctx.db.delete(_id);
|
|
316
|
+
if (canceledWork.has(workId)) {
|
|
317
|
+
// We shouldn't have multiple pending cancelations for the same work.
|
|
318
|
+
console.error(`[main] ${workId} already canceled`);
|
|
319
|
+
return null;
|
|
320
|
+
}
|
|
321
|
+
const work = await ctx.db.get(workId);
|
|
322
|
+
if (!work) {
|
|
323
|
+
console.warn(`[main] ${workId} is gone, but trying to cancel`);
|
|
324
|
+
return null;
|
|
325
|
+
}
|
|
326
|
+
// Ensure it doesn't retry.
|
|
327
|
+
await ctx.db.patch(workId, { canceled: true });
|
|
328
|
+
// Ensure it doesn't start.
|
|
329
|
+
const pendingStart = await ctx.db
|
|
330
|
+
.query("pendingStart")
|
|
331
|
+
.withIndex("workId", (q) => q.eq("workId", workId))
|
|
332
|
+
.unique();
|
|
333
|
+
if (pendingStart && !canceledWork.has(workId)) {
|
|
334
|
+
state.report.canceled++;
|
|
335
|
+
await ctx.db.delete(pendingStart._id);
|
|
336
|
+
canceledWork.add(workId);
|
|
337
|
+
return { workId, runResult, attempt: work.attempts };
|
|
338
|
+
}
|
|
339
|
+
return null;
|
|
340
|
+
}))).flatMap((r) => (r ? [r] : [])));
|
|
341
|
+
if (jobs.length) {
|
|
342
|
+
await ctx.scheduler.runAfter(0, internal.complete.complete, { jobs });
|
|
343
|
+
}
|
|
344
|
+
}
|
|
345
|
+
async function handleRecovery(ctx, state, console) {
|
|
346
|
+
const missing = new Set();
|
|
347
|
+
const oldEnoughToConsider = Date.now() - RECOVERY_THRESHOLD_MS;
|
|
348
|
+
const jobs = (await Promise.all(state.running.map(async (r) => {
|
|
349
|
+
if (r.started >= oldEnoughToConsider) {
|
|
350
|
+
return null;
|
|
351
|
+
}
|
|
352
|
+
const work = await ctx.db.get(r.workId);
|
|
353
|
+
if (!work) {
|
|
354
|
+
missing.add(r.workId);
|
|
355
|
+
console.error(`[main] ${r.workId} already gone (skipping recovery)`);
|
|
356
|
+
return null;
|
|
357
|
+
}
|
|
358
|
+
return { ...r, attempt: work.attempts };
|
|
359
|
+
}))).flatMap((r) => (r ? [r] : []));
|
|
360
|
+
state.running = state.running.filter((r) => !missing.has(r.workId));
|
|
361
|
+
if (jobs.length) {
|
|
362
|
+
await ctx.scheduler.runAfter(0, internal.recovery.recover, { jobs });
|
|
363
|
+
}
|
|
364
|
+
}
|
|
365
|
+
async function handleStart(ctx, state, segment, console, globals) {
|
|
366
|
+
const maxParallelism = globals.maxParallelism;
|
|
367
|
+
// Schedule as many as needed to reach maxParallelism.
|
|
368
|
+
const toSchedule = maxParallelism - state.running.length;
|
|
369
|
+
const pending = await ctx.db
|
|
370
|
+
.query("pendingStart")
|
|
371
|
+
.withIndex("segment", (q) => q
|
|
372
|
+
.gte("segment", state.segmentCursors.incoming - CURSOR_BUFFER_SEGMENTS)
|
|
373
|
+
.lte("segment", segment))
|
|
374
|
+
.take(toSchedule);
|
|
375
|
+
state.segmentCursors.incoming = pending.at(-1)?.segment ?? segment;
|
|
376
|
+
console.debug(`[main] scheduling ${pending.length} pending work`);
|
|
377
|
+
// Start new work.
|
|
378
|
+
state.running.push(...(await Promise.all(pending.map(async ({ _id, workId }) => {
|
|
379
|
+
if (state.running.some((r) => r.workId === workId)) {
|
|
380
|
+
console.error(`[main] ${workId} already running (skipping start)`);
|
|
381
|
+
return null;
|
|
382
|
+
}
|
|
383
|
+
const scheduledId = await beginWork(ctx, workId, globals.logLevel);
|
|
384
|
+
await ctx.db.delete(_id);
|
|
385
|
+
return { scheduledId, workId, started: Date.now() };
|
|
386
|
+
}))).flatMap((r) => (r ? [r] : [])));
|
|
387
|
+
}
|
|
388
|
+
async function beginWork(ctx, workId, logLevel) {
|
|
389
|
+
const console = createLogger(logLevel);
|
|
390
|
+
const work = await ctx.db.get(workId);
|
|
391
|
+
if (!work) {
|
|
392
|
+
throw new Error("work not found");
|
|
393
|
+
}
|
|
394
|
+
console.info(recordStarted(work));
|
|
395
|
+
const { attempts: attempt, fnHandle, fnArgs } = work;
|
|
396
|
+
const args = { workId, fnHandle, fnArgs, logLevel, attempt };
|
|
397
|
+
if (work.fnType === "action") {
|
|
398
|
+
return ctx.scheduler.runAfter(0, internal.worker.runActionWrapper, args);
|
|
399
|
+
}
|
|
400
|
+
else if (work.fnType === "mutation") {
|
|
401
|
+
return ctx.scheduler.runAfter(0, internal.worker.runMutationWrapper, args);
|
|
402
|
+
}
|
|
403
|
+
else {
|
|
404
|
+
throw new Error(`Unexpected fnType ${work.fnType}`);
|
|
405
|
+
}
|
|
406
|
+
}
|
|
407
|
+
/**
|
|
408
|
+
* Reschedules a job for retry.
|
|
409
|
+
* If it's been canceled in the mean time, don't retry.
|
|
410
|
+
* @returns true if the job was rescheduled, false if it was not.
|
|
411
|
+
*/
|
|
412
|
+
async function rescheduleJob(ctx, work, console) {
|
|
413
|
+
const pendingCancelation = await ctx.db
|
|
414
|
+
.query("pendingCancelation")
|
|
415
|
+
.withIndex("workId", (q) => q.eq("workId", work._id))
|
|
416
|
+
.unique();
|
|
417
|
+
if (pendingCancelation) {
|
|
418
|
+
// If there's an un-processed cancelation request, don't retry.
|
|
419
|
+
console.warn(`[main] ${work._id} in pendingCancelation so not retrying`);
|
|
420
|
+
return false;
|
|
421
|
+
}
|
|
422
|
+
if (work.canceled) {
|
|
423
|
+
return false;
|
|
424
|
+
}
|
|
425
|
+
if (!work.retryBehavior) {
|
|
426
|
+
console.warn(`[main] ${work._id} has no retryBehavior so not retrying`);
|
|
427
|
+
return false;
|
|
428
|
+
}
|
|
429
|
+
const existing = await ctx.db
|
|
430
|
+
.query("pendingStart")
|
|
431
|
+
.withIndex("workId", (q) => q.eq("workId", work._id))
|
|
432
|
+
.first();
|
|
433
|
+
if (existing) {
|
|
434
|
+
// Not sure why this would ever happen, but ensure uniqueness explicitly.
|
|
435
|
+
console.error(`[main] ${work._id} already in pendingStart so not retrying`);
|
|
436
|
+
return false;
|
|
437
|
+
}
|
|
438
|
+
const backoffMs = work.retryBehavior.initialBackoffMs *
|
|
439
|
+
Math.pow(work.retryBehavior.base, work.attempts - 1);
|
|
440
|
+
const nextAttempt = withJitter(backoffMs);
|
|
441
|
+
const startTime = boundScheduledTime(Date.now() + nextAttempt, console);
|
|
442
|
+
const segment = toSegment(startTime);
|
|
443
|
+
await ctx.db.insert("pendingStart", {
|
|
444
|
+
workId: work._id,
|
|
445
|
+
segment,
|
|
446
|
+
});
|
|
447
|
+
return true;
|
|
448
|
+
}
|
|
449
|
+
export function withJitter(delay) {
|
|
450
|
+
return delay * (0.5 + Math.random());
|
|
451
|
+
}
|
|
452
|
+
async function getGlobals(ctx) {
|
|
453
|
+
const globals = await ctx.db.query("globals").unique();
|
|
454
|
+
if (!globals) {
|
|
455
|
+
return {
|
|
456
|
+
maxParallelism: DEFAULT_MAX_PARALLELISM,
|
|
457
|
+
logLevel: DEFAULT_LOG_LEVEL,
|
|
458
|
+
};
|
|
459
|
+
}
|
|
460
|
+
return globals;
|
|
461
|
+
}
|
|
462
|
+
async function getOrCreateState(ctx) {
|
|
463
|
+
const state = await ctx.db.query("internalState").unique();
|
|
464
|
+
if (state)
|
|
465
|
+
return state;
|
|
466
|
+
const globals = await getGlobals(ctx);
|
|
467
|
+
const console = createLogger(globals.logLevel);
|
|
468
|
+
console.error("No internalState in running loop! Re-creating empty one...");
|
|
469
|
+
return (await ctx.db.get(await ctx.db.insert("internalState", INITIAL_STATE)));
|
|
470
|
+
}
|
|
471
|
+
async function getOrCreateRunningStatus(ctx) {
|
|
472
|
+
const runStatus = await ctx.db.query("runStatus").unique();
|
|
473
|
+
if (runStatus)
|
|
474
|
+
return runStatus;
|
|
475
|
+
const globals = await getGlobals(ctx);
|
|
476
|
+
const console = createLogger(globals.logLevel);
|
|
477
|
+
console.error("No runStatus in running loop! Re-creating one...");
|
|
478
|
+
return (await ctx.db.get(await ctx.db.insert("runStatus", { state: { kind: "running" } })));
|
|
479
|
+
}
|
|
480
|
+
// eslint-disable-next-line @typescript-eslint/no-unused-vars
|
|
481
|
+
const console = "THIS IS A REMINDER TO USE createLogger";
|
|
482
|
+
//# sourceMappingURL=loop.js.map
|