@chkit/plugin-backfill 0.1.0-beta.2 → 0.1.0-beta.21
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 +170 -0
- package/dist/args.d.ts +109 -6
- package/dist/args.d.ts.map +1 -1
- package/dist/args.js +73 -97
- package/dist/args.js.map +1 -1
- package/dist/async-backfill.d.ts +64 -0
- package/dist/async-backfill.d.ts.map +1 -0
- package/dist/async-backfill.js +251 -0
- package/dist/async-backfill.js.map +1 -0
- package/dist/check.d.ts +9 -0
- package/dist/check.d.ts.map +1 -0
- package/dist/check.js +79 -0
- package/dist/check.js.map +1 -0
- package/dist/chunking/analyze.d.ts +8 -0
- package/dist/chunking/analyze.d.ts.map +1 -0
- package/dist/chunking/analyze.js +8 -0
- package/dist/chunking/analyze.js.map +1 -0
- package/dist/chunking/boundary-codec.d.ts +10 -0
- package/dist/chunking/boundary-codec.d.ts.map +1 -0
- package/dist/chunking/boundary-codec.js +79 -0
- package/dist/chunking/boundary-codec.js.map +1 -0
- package/dist/chunking/build.d.ts +11 -0
- package/dist/chunking/build.d.ts.map +1 -0
- package/dist/chunking/build.js +51 -0
- package/dist/chunking/build.js.map +1 -0
- package/dist/chunking/e2e/constants.d.ts +2 -0
- package/dist/chunking/e2e/constants.d.ts.map +1 -0
- package/dist/chunking/e2e/constants.js +2 -0
- package/dist/chunking/e2e/constants.js.map +1 -0
- package/dist/chunking/e2e/seed-datasets.script.d.ts +20 -0
- package/dist/chunking/e2e/seed-datasets.script.d.ts.map +1 -0
- package/dist/chunking/e2e/seed-datasets.script.js +134 -0
- package/dist/chunking/e2e/seed-datasets.script.js.map +1 -0
- package/dist/chunking/introspect.d.ts +40 -0
- package/dist/chunking/introspect.d.ts.map +1 -0
- package/dist/chunking/introspect.js +187 -0
- package/dist/chunking/introspect.js.map +1 -0
- package/dist/chunking/partition-slices.d.ts +14 -0
- package/dist/chunking/partition-slices.d.ts.map +1 -0
- package/dist/chunking/partition-slices.js +111 -0
- package/dist/chunking/partition-slices.js.map +1 -0
- package/dist/chunking/planner.d.ts +3 -0
- package/dist/chunking/planner.d.ts.map +1 -0
- package/dist/chunking/planner.js +343 -0
- package/dist/chunking/planner.js.map +1 -0
- package/dist/chunking/services/distribution-source.d.ts +11 -0
- package/dist/chunking/services/distribution-source.d.ts.map +1 -0
- package/dist/chunking/services/distribution-source.js +60 -0
- package/dist/chunking/services/distribution-source.js.map +1 -0
- package/dist/chunking/services/metadata-source.d.ts +4 -0
- package/dist/chunking/services/metadata-source.d.ts.map +1 -0
- package/dist/chunking/services/metadata-source.js +138 -0
- package/dist/chunking/services/metadata-source.js.map +1 -0
- package/dist/chunking/services/row-probe.d.ts +14 -0
- package/dist/chunking/services/row-probe.d.ts.map +1 -0
- package/dist/chunking/services/row-probe.js +62 -0
- package/dist/chunking/services/row-probe.js.map +1 -0
- package/dist/chunking/splitter.d.ts +20 -0
- package/dist/chunking/splitter.d.ts.map +1 -0
- package/dist/chunking/splitter.js +76 -0
- package/dist/chunking/splitter.js.map +1 -0
- package/dist/chunking/sql.d.ts +20 -0
- package/dist/chunking/sql.d.ts.map +1 -0
- package/dist/chunking/sql.js +304 -0
- package/dist/chunking/sql.js.map +1 -0
- package/dist/chunking/strategies/equal-width-split.d.ts +4 -0
- package/dist/chunking/strategies/equal-width-split.d.ts.map +1 -0
- package/dist/chunking/strategies/equal-width-split.js +46 -0
- package/dist/chunking/strategies/equal-width-split.js.map +1 -0
- package/dist/chunking/strategies/group-by-key-split.d.ts +3 -0
- package/dist/chunking/strategies/group-by-key-split.d.ts.map +1 -0
- package/dist/chunking/strategies/group-by-key-split.js +54 -0
- package/dist/chunking/strategies/group-by-key-split.js.map +1 -0
- package/dist/chunking/strategies/metadata-single-chunk.d.ts +3 -0
- package/dist/chunking/strategies/metadata-single-chunk.d.ts.map +1 -0
- package/dist/chunking/strategies/metadata-single-chunk.js +5 -0
- package/dist/chunking/strategies/metadata-single-chunk.js.map +1 -0
- package/dist/chunking/strategies/quantile-range-split.d.ts +5 -0
- package/dist/chunking/strategies/quantile-range-split.d.ts.map +1 -0
- package/dist/chunking/strategies/quantile-range-split.js +132 -0
- package/dist/chunking/strategies/quantile-range-split.js.map +1 -0
- package/dist/chunking/strategies/refinement.d.ts +4 -0
- package/dist/chunking/strategies/refinement.d.ts.map +1 -0
- package/dist/chunking/strategies/refinement.js +61 -0
- package/dist/chunking/strategies/refinement.js.map +1 -0
- package/dist/chunking/strategies/string-prefix-split.d.ts +4 -0
- package/dist/chunking/strategies/string-prefix-split.d.ts.map +1 -0
- package/dist/chunking/strategies/string-prefix-split.js +73 -0
- package/dist/chunking/strategies/string-prefix-split.js.map +1 -0
- package/dist/chunking/strategies/temporal-bucket-split.d.ts +4 -0
- package/dist/chunking/strategies/temporal-bucket-split.d.ts.map +1 -0
- package/dist/chunking/strategies/temporal-bucket-split.js +67 -0
- package/dist/chunking/strategies/temporal-bucket-split.js.map +1 -0
- package/dist/chunking/strategy-policy.d.ts +3 -0
- package/dist/chunking/strategy-policy.d.ts.map +1 -0
- package/dist/chunking/strategy-policy.js +4 -0
- package/dist/chunking/strategy-policy.js.map +1 -0
- package/dist/chunking/types.d.ts +139 -0
- package/dist/chunking/types.d.ts.map +1 -0
- package/dist/chunking/types.js +2 -0
- package/dist/chunking/types.js.map +1 -0
- package/dist/chunking/utils/binary-string.d.ts +8 -0
- package/dist/chunking/utils/binary-string.d.ts.map +1 -0
- package/dist/chunking/utils/binary-string.js +52 -0
- package/dist/chunking/utils/binary-string.js.map +1 -0
- package/dist/chunking/utils/ids.d.ts +4 -0
- package/dist/chunking/utils/ids.d.ts.map +1 -0
- package/dist/chunking/utils/ids.js +11 -0
- package/dist/chunking/utils/ids.js.map +1 -0
- package/dist/chunking/utils/ranges.d.ts +5 -0
- package/dist/chunking/utils/ranges.d.ts.map +1 -0
- package/dist/chunking/utils/ranges.js +19 -0
- package/dist/chunking/utils/ranges.js.map +1 -0
- package/dist/detect.d.ts +13 -0
- package/dist/detect.d.ts.map +1 -0
- package/dist/detect.js +113 -0
- package/dist/detect.js.map +1 -0
- package/dist/index.d.ts +3 -0
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +1 -0
- package/dist/index.js.map +1 -1
- package/dist/logging.d.ts +12 -0
- package/dist/logging.d.ts.map +1 -0
- package/dist/logging.js +61 -0
- package/dist/logging.js.map +1 -0
- package/dist/options.d.ts +151 -4
- package/dist/options.d.ts.map +1 -1
- package/dist/options.js +161 -109
- package/dist/options.js.map +1 -1
- package/dist/payload.d.ts +7 -17
- package/dist/payload.d.ts.map +1 -1
- package/dist/payload.js +7 -19
- package/dist/payload.js.map +1 -1
- package/dist/planner.d.ts +10 -8
- package/dist/planner.d.ts.map +1 -1
- package/dist/planner.js +76 -97
- package/dist/planner.js.map +1 -1
- package/dist/plugin.d.ts +4 -3
- package/dist/plugin.d.ts.map +1 -1
- package/dist/plugin.js +311 -215
- package/dist/plugin.js.map +1 -1
- package/dist/queries.d.ts +21 -0
- package/dist/queries.d.ts.map +1 -0
- package/dist/queries.js +113 -0
- package/dist/queries.js.map +1 -0
- package/dist/runtime.d.ts +14 -0
- package/dist/runtime.d.ts.map +1 -1
- package/dist/runtime.js +162 -83
- package/dist/runtime.js.map +1 -1
- package/dist/sdk.d.ts +12 -0
- package/dist/sdk.d.ts.map +1 -0
- package/dist/sdk.js +9 -0
- package/dist/sdk.js.map +1 -0
- package/dist/state.d.ts +16 -28
- package/dist/state.d.ts.map +1 -1
- package/dist/state.js +73 -127
- package/dist/state.js.map +1 -1
- package/dist/table-config.d.ts +9 -0
- package/dist/table-config.d.ts.map +1 -0
- package/dist/table-config.js +2 -0
- package/dist/table-config.js.map +1 -0
- package/dist/types.d.ts +49 -114
- package/dist/types.d.ts.map +1 -1
- package/package.json +31 -2
package/dist/plugin.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"plugin.js","sourceRoot":"","sources":["../src/plugin.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,eAAe,EAAE,eAAe,EAAE,aAAa,EAAE,eAAe,EAAE,YAAY,EAAE,eAAe,EAAE,MAAM,WAAW,CAAA;AAC3H,OAAO,EAAE,mBAAmB,EAAE,MAAM,aAAa,CAAA;AACjD,OAAO,EAAE,wBAAwB,EAAE,YAAY,EAAE,mBAAmB,EAAE,MAAM,cAAc,CAAA;AAC1F,OAAO,EAAE,WAAW,EAAE,UAAU,EAAE,aAAa,EAAE,aAAa,EAAE,aAAa,EAAE,MAAM,cAAc,CAAA;AACnG,OAAO,EAAE,iBAAiB,EAAE,MAAM,cAAc,CAAA;AAChD,OAAO,EACL,iBAAiB,EACjB,qBAAqB,EACrB,kBAAkB,EAClB,uBAAuB,EACvB,iBAAiB,EACjB,iBAAiB,GAClB,MAAM,cAAc,CAAA;AAGrB,MAAM,UAAU,oBAAoB,CAAC,UAAiC,EAAE;IACtE,MAAM,IAAI,GAAG,wBAAwB,CAAC,OAAO,CAAC,CAAA;IAC9C,mBAAmB,CAAC,IAAI,CAAC,CAAA;IAEzB,OAAO;QACL,QAAQ,EAAE;YACR,IAAI,EAAE,UAAU;YAChB,UAAU,EAAE,CAAC;SACd;QACD,QAAQ,EAAE;YACR;gBACE,IAAI,EAAE,MAAM;gBACZ,WAAW,EAAE,sEAAsE;gBACnF,KAAK,CAAC,GAAG,CAAC,EAAE,IAAI,EAAE,QAAQ,EAAE,KAAK,EAAE,OAAO,EAAE,cAAc,EAAE,MAAM,EAAE,UAAU,EAAE;oBAC9E,IAAI,CAAC;wBACH,MAAM,MAAM,GAAG,aAAa,CAAC,IAAI,CAAC,CAAA;wBAClC,MAAM,gBAAgB,GAAG,YAAY,CAAC,IAAI,EAAE,cAAc,CAAC,CAAA;wBAC3D,mBAAmB,CAAC,gBAAgB,CAAC,CAAA;wBAErC,MAAM,MAAM,GAAG,MAAM,iBAAiB,CAAC;4BACrC,MAAM,EAAE,MAAM,CAAC,MAAM;4BACrB,IAAI,EAAE,MAAM,CAAC,IAAI;4BACjB,EAAE,EAAE,MAAM,CAAC,EAAE;4BACb,MAAM;4BACN,UAAU;4BACV,OAAO,EAAE,gBAAgB;4BACzB,UAAU,EAAE,MAAM,CAAC,UAAU;4BAC7B,gBAAgB,EAAE,MAAM,CAAC,gBAAgB;yBAC1C,CAAC,CAAA;wBAEF,MAAM,OAAO,GAAG,WAAW,CAAC,MAAM,CAAC,CAAA;wBACnC,IAAI,QAAQ,EAAE,CAAC;4BACb,KAAK,CAAC,OAAO,CAAC,CAAA;wBAChB,CAAC;6BAAM,CAAC;4BACN,KAAK,CACH,iBAAiB,OAAO,CAAC,MAAM,QAAQ,OAAO,CAAC,MAAM,KAAK,OAAO,CAAC,UAAU,cAAc,OAAO,CAAC,UAAU,SAAS,OAAO,CAAC,QAAQ,GAAG,OAAO,CAAC,OAAO,CAAC,CAAC,CAAC,aAAa,CAAC,CAAC,CAAC,EAAE,EAAE,CAC/K,CAAA;wBACH,CAAC;wBAED,OAAO,CAAC,CAAA;oBACV,CAAC;oBAAC,OAAO,KAAK,EAAE,CAAC;wBACf,MAAM,OAAO,GAAG,KAAK,YAAY,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,CAAA;wBACtE,IAAI,QAAQ,EAAE,CAAC;4BACb,KAAK,CAAC;gCACJ,EAAE,EAAE,KAAK;gCACT,OAAO,EAAE,MAAM;gCACf,KAAK,EAAE,OAAO;6BACf,CAAC,CAAA;wBACJ,CAAC;6BAAM,CAAC;4BACN,KAAK,CAAC,yBAAyB,OAAO,EAAE,CAAC,CAAA;wBAC3C,CAAC;wBAED,IAAI,KAAK,YAAY,mBAAmB;4BAAE,OAAO,CAAC,CAAA;wBAClD,OAAO,CAAC,CAAA;oBACV,CAAC;gBACH,CAAC;aACF;YACD;gBACE,IAAI,EAAE,KAAK;gBACX,WAAW,EAAE,6DAA6D;gBAC1E,KAAK,CAAC,GAAG,CAAC,EAAE,IAAI,EAAE,QAAQ,EAAE,KAAK,EAAE,OAAO,EAAE,cAAc,EAAE,MAAM,EAAE,UAAU,EAAE;oBAC9E,IAAI,CAAC;wBACH,MAAM,MAAM,GAAG,YAAY,CAAC,IAAI,CAAC,CAAA;wBACjC,MAAM,gBAAgB,GAAG,YAAY,CAAC,IAAI,EAAE,cAAc,CAAC,CAAA;wBAC3D,mBAAmB,CAAC,gBAAgB,CAAC,CAAA;wBAErC,MAAM,MAAM,GAAG,MAAM,kBAAkB,CAAC;4BACtC,MAAM,EAAE,MAAM,CAAC,MAAM;4BACrB,MAAM;4BACN,UAAU;4BACV,OAAO,EAAE,gBAAgB;4BACzB,SAAS,EAAE;gCACT,UAAU,EAAE,MAAM,CAAC,UAAU;gCAC7B,YAAY,EAAE,MAAM,CAAC,YAAY;gCACjC,YAAY,EAAE,MAAM,CAAC,YAAY;gCACjC,kBAAkB,EAAE,MAAM,CAAC,kBAAkB;gCAC7C,UAAU,EAAE;oCACV,WAAW,EAAE,MAAM,CAAC,iBAAiB;oCACrC,SAAS,EAAE,MAAM,CAAC,iBAAiB;iCACpC;6BACF;yBACF,CAAC,CAAA;wBAEF,MAAM,OAAO,GAAG;4BACd,GAAG,UAAU,CAAC,MAAM,CAAC;4BACrB,OAAO,EAAE,KAAc;yBACxB,CAAA;wBAED,IAAI,QAAQ,EAAE,CAAC;4BACb,KAAK,CAAC,OAAO,CAAC,CAAA;wBAChB,CAAC;6BAAM,CAAC;4BACN,KAAK,CACH,gBAAgB,OAAO,CAAC,MAAM,KAAK,OAAO,CAAC,MAAM,UAAU,OAAO,CAAC,WAAW,CAAC,IAAI,IAAI,OAAO,CAAC,WAAW,CAAC,KAAK,GAAG,CACpH,CAAA;wBACH,CAAC;wBAED,OAAO,OAAO,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAA;oBAC3B,CAAC;oBAAC,OAAO,KAAK,EAAE,CAAC;wBACf,MAAM,OAAO,GAAG,KAAK,YAAY,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,CAAA;wBACtE,IAAI,QAAQ,EAAE,CAAC;4BACb,KAAK,CAAC,EAAE,EAAE,EAAE,KAAK,EAAE,OAAO,EAAE,KAAK,EAAE,KAAK,EAAE,OAAO,EAAE,CAAC,CAAA;wBACtD,CAAC;6BAAM,CAAC;4BACN,KAAK,CAAC,wBAAwB,OAAO,EAAE,CAAC,CAAA;wBAC1C,CAAC;wBAED,IAAI,KAAK,YAAY,mBAAmB;4BAAE,OAAO,CAAC,CAAA;wBAClD,OAAO,CAAC,CAAA;oBACV,CAAC;gBACH,CAAC;aACF;YACD;gBACE,IAAI,EAAE,QAAQ;gBACd,WAAW,EAAE,4CAA4C;gBACzD,KAAK,CAAC,GAAG,CAAC,EAAE,IAAI,EAAE,QAAQ,EAAE,KAAK,EAAE,OAAO,EAAE,cAAc,EAAE,MAAM,EAAE,UAAU,EAAE;oBAC9E,IAAI,CAAC;wBACH,MAAM,MAAM,GAAG,eAAe,CAAC,IAAI,CAAC,CAAA;wBACpC,MAAM,gBAAgB,GAAG,YAAY,CAAC,IAAI,EAAE,cAAc,CAAC,CAAA;wBAC3D,mBAAmB,CAAC,gBAAgB,CAAC,CAAA;wBAErC,MAAM,MAAM,GAAG,MAAM,iBAAiB,CAAC;4BACrC,MAAM,EAAE,MAAM,CAAC,MAAM;4BACrB,MAAM;4BACN,UAAU;4BACV,OAAO,EAAE,gBAAgB;4BACzB,SAAS,EAAE;gCACT,UAAU,EAAE,MAAM,CAAC,UAAU;gCAC7B,YAAY,EAAE,MAAM,CAAC,YAAY;gCACjC,YAAY,EAAE,MAAM,CAAC,YAAY;gCACjC,kBAAkB,EAAE,MAAM,CAAC,kBAAkB;6BAC9C;yBACF,CAAC,CAAA;wBAEF,MAAM,OAAO,GAAG;4BACd,GAAG,UAAU,CAAC,MAAM,CAAC;4BACrB,OAAO,EAAE,QAAiB;yBAC3B,CAAA;wBAED,IAAI,QAAQ,EAAE,CAAC;4BACb,KAAK,CAAC,OAAO,CAAC,CAAA;wBAChB,CAAC;6BAAM,CAAC;4BACN,KAAK,CACH,mBAAmB,OAAO,CAAC,MAAM,KAAK,OAAO,CAAC,MAAM,UAAU,OAAO,CAAC,WAAW,CAAC,IAAI,IAAI,OAAO,CAAC,WAAW,CAAC,KAAK,GAAG,CACvH,CAAA;wBACH,CAAC;wBAED,OAAO,OAAO,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAA;oBAC3B,CAAC;oBAAC,OAAO,KAAK,EAAE,CAAC;wBACf,MAAM,OAAO,GAAG,KAAK,YAAY,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,CAAA;wBACtE,IAAI,QAAQ,EAAE,CAAC;4BACb,KAAK,CAAC,EAAE,EAAE,EAAE,KAAK,EAAE,OAAO,EAAE,QAAQ,EAAE,KAAK,EAAE,OAAO,EAAE,CAAC,CAAA;wBACzD,CAAC;6BAAM,CAAC;4BACN,KAAK,CAAC,2BAA2B,OAAO,EAAE,CAAC,CAAA;wBAC7C,CAAC;wBAED,IAAI,KAAK,YAAY,mBAAmB;4BAAE,OAAO,CAAC,CAAA;wBAClD,OAAO,CAAC,CAAA;oBACV,CAAC;gBACH,CAAC;aACF;YACD;gBACE,IAAI,EAAE,QAAQ;gBACd,WAAW,EAAE,uDAAuD;gBACpE,KAAK,CAAC,GAAG,CAAC,EAAE,IAAI,EAAE,QAAQ,EAAE,KAAK,EAAE,OAAO,EAAE,cAAc,EAAE,MAAM,EAAE,UAAU,EAAE;oBAC9E,IAAI,CAAC;wBACH,MAAM,MAAM,GAAG,eAAe,CAAC,IAAI,CAAC,CAAA;wBACpC,MAAM,gBAAgB,GAAG,YAAY,CAAC,IAAI,EAAE,cAAc,CAAC,CAAA;wBAC3D,mBAAmB,CAAC,gBAAgB,CAAC,CAAA;wBAErC,MAAM,OAAO,GAAG,MAAM,iBAAiB,CAAC;4BACtC,MAAM,EAAE,MAAM,CAAC,MAAM;4BACrB,MAAM;4BACN,UAAU;4BACV,OAAO,EAAE,gBAAgB;yBAC1B,CAAC,CAAA;wBACF,MAAM,OAAO,GAAG,aAAa,CAAC,OAAO,CAAC,CAAA;wBAEtC,IAAI,QAAQ,EAAE,CAAC;4BACb,KAAK,CAAC,OAAO,CAAC,CAAA;wBAChB,CAAC;6BAAM,CAAC;4BACN,KAAK,CACH,mBAAmB,OAAO,CAAC,MAAM,KAAK,OAAO,CAAC,MAAM,UAAU,OAAO,CAAC,WAAW,CAAC,IAAI,IAAI,OAAO,CAAC,WAAW,CAAC,KAAK,YAAY,OAAO,CAAC,WAAW,CAAC,MAAM,GAAG,CAC7J,CAAA;wBACH,CAAC;wBAED,OAAO,OAAO,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAA;oBAC3B,CAAC;oBAAC,OAAO,KAAK,EAAE,CAAC;wBACf,MAAM,OAAO,GAAG,KAAK,YAAY,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,CAAA;wBACtE,IAAI,QAAQ,EAAE,CAAC;4BACb,KAAK,CAAC,EAAE,EAAE,EAAE,KAAK,EAAE,OAAO,EAAE,QAAQ,EAAE,KAAK,EAAE,OAAO,EAAE,CAAC,CAAA;wBACzD,CAAC;6BAAM,CAAC;4BACN,KAAK,CAAC,2BAA2B,OAAO,EAAE,CAAC,CAAA;wBAC7C,CAAC;wBAED,IAAI,KAAK,YAAY,mBAAmB;4BAAE,OAAO,CAAC,CAAA;wBAClD,OAAO,CAAC,CAAA;oBACV,CAAC;gBACH,CAAC;aACF;YACD;gBACE,IAAI,EAAE,QAAQ;gBACd,WAAW,EAAE,wEAAwE;gBACrF,KAAK,CAAC,GAAG,CAAC,EAAE,IAAI,EAAE,QAAQ,EAAE,KAAK,EAAE,OAAO,EAAE,cAAc,EAAE,MAAM,EAAE,UAAU,EAAE;oBAC9E,IAAI,CAAC;wBACH,MAAM,MAAM,GAAG,eAAe,CAAC,IAAI,CAAC,CAAA;wBACpC,MAAM,gBAAgB,GAAG,YAAY,CAAC,IAAI,EAAE,cAAc,CAAC,CAAA;wBAC3D,mBAAmB,CAAC,gBAAgB,CAAC,CAAA;wBAErC,MAAM,OAAO,GAAG,MAAM,iBAAiB,CAAC;4BACtC,MAAM,EAAE,MAAM,CAAC,MAAM;4BACrB,MAAM;4BACN,UAAU;4BACV,OAAO,EAAE,gBAAgB;yBAC1B,CAAC,CAAA;wBACF,MAAM,OAAO,GAAG,aAAa,CAAC,OAAO,CAAC,CAAA;wBAEtC,IAAI,QAAQ,EAAE,CAAC;4BACb,KAAK,CAAC,OAAO,CAAC,CAAA;wBAChB,CAAC;6BAAM,CAAC;4BACN,KAAK,CACH,mBAAmB,OAAO,CAAC,MAAM,KAAK,OAAO,CAAC,MAAM,UAAU,OAAO,CAAC,WAAW,CAAC,IAAI,IAAI,OAAO,CAAC,WAAW,CAAC,KAAK,GAAG,CACvH,CAAA;wBACH,CAAC;wBAED,OAAO,OAAO,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAA;oBAC3B,CAAC;oBAAC,OAAO,KAAK,EAAE,CAAC;wBACf,MAAM,OAAO,GAAG,KAAK,YAAY,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,CAAA;wBACtE,IAAI,QAAQ,EAAE,CAAC;4BACb,KAAK,CAAC,EAAE,EAAE,EAAE,KAAK,EAAE,OAAO,EAAE,QAAQ,EAAE,KAAK,EAAE,OAAO,EAAE,CAAC,CAAA;wBACzD,CAAC;6BAAM,CAAC;4BACN,KAAK,CAAC,2BAA2B,OAAO,EAAE,CAAC,CAAA;wBAC7C,CAAC;wBAED,IAAI,KAAK,YAAY,mBAAmB;4BAAE,OAAO,CAAC,CAAA;wBAClD,OAAO,CAAC,CAAA;oBACV,CAAC;gBACH,CAAC;aACF;YACD;gBACE,IAAI,EAAE,QAAQ;gBACd,WAAW,EAAE,0EAA0E;gBACvF,KAAK,CAAC,GAAG,CAAC,EAAE,IAAI,EAAE,QAAQ,EAAE,KAAK,EAAE,OAAO,EAAE,cAAc,EAAE,MAAM,EAAE,UAAU,EAAE;oBAC9E,IAAI,CAAC;wBACH,MAAM,MAAM,GAAG,eAAe,CAAC,IAAI,CAAC,CAAA;wBACpC,MAAM,gBAAgB,GAAG,YAAY,CAAC,IAAI,EAAE,cAAc,CAAC,CAAA;wBAC3D,mBAAmB,CAAC,gBAAgB,CAAC,CAAA;wBAErC,MAAM,MAAM,GAAG,MAAM,uBAAuB,CAAC;4BAC3C,MAAM,EAAE,MAAM,CAAC,MAAM;4BACrB,MAAM;4BACN,UAAU;4BACV,OAAO,EAAE,gBAAgB;yBAC1B,CAAC,CAAA;wBACF,MAAM,OAAO,GAAG,aAAa,CAAC,MAAM,CAAC,CAAA;wBAErC,IAAI,QAAQ,EAAE,CAAC;4BACb,KAAK,CAAC,OAAO,CAAC,CAAA;wBAChB,CAAC;6BAAM,CAAC;4BACN,KAAK,CACH,mBAAmB,OAAO,CAAC,MAAM,KAAK,OAAO,CAAC,UAAU,CAAC,MAAM,KAAK,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,OAAO,CAAC,UAAU,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAC/G,CAAA;4BACD,KAAK,MAAM,cAAc,IAAI,OAAO,CAAC,eAAe,EAAE,CAAC;gCACrD,KAAK,CAAC,KAAK,cAAc,EAAE,CAAC,CAAA;4BAC9B,CAAC;wBACH,CAAC;wBAED,OAAO,OAAO,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAA;oBAC3B,CAAC;oBAAC,OAAO,KAAK,EAAE,CAAC;wBACf,MAAM,OAAO,GAAG,KAAK,YAAY,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,CAAA;wBACtE,IAAI,QAAQ,EAAE,CAAC;4BACb,KAAK,CAAC,EAAE,EAAE,EAAE,KAAK,EAAE,OAAO,EAAE,QAAQ,EAAE,KAAK,EAAE,OAAO,EAAE,CAAC,CAAA;wBACzD,CAAC;6BAAM,CAAC;4BACN,KAAK,CAAC,2BAA2B,OAAO,EAAE,CAAC,CAAA;wBAC7C,CAAC;wBAED,IAAI,KAAK,YAAY,mBAAmB;4BAAE,OAAO,CAAC,CAAA;wBAClD,OAAO,CAAC,CAAA;oBACV,CAAC;gBACH,CAAC;aACF;SACF;QACD,KAAK,EAAE;YACL,cAAc,CAAC,EAAE,OAAO,EAAE,cAAc,EAAE;gBACxC,MAAM,MAAM,GAAG,YAAY,CAAC,IAAI,EAAE,cAAc,CAAC,CAAA;gBACjD,mBAAmB,CAAC,MAAM,CAAC,CAAA;YAC7B,CAAC;YACD,KAAK,CAAC,OAAO,CAAC,EAAE,MAAM,EAAE,UAAU,EAAE,OAAO,EAAE,cAAc,EAAE;gBAC3D,MAAM,gBAAgB,GAAG,YAAY,CAAC,IAAI,EAAE,cAAc,CAAC,CAAA;gBAC3D,mBAAmB,CAAC,gBAAgB,CAAC,CAAA;gBACrC,OAAO,qBAAqB,CAAC;oBAC3B,UAAU;oBACV,MAAM;oBACN,OAAO,EAAE,gBAAgB;iBAC1B,CAAC,CAAA;YACJ,CAAC;YACD,aAAa,CAAC,EAAE,MAAM,EAAE,KAAK,EAAE;gBAC7B,MAAM,YAAY,GAAG,MAAM,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC,OAAO,EAAE,EAAE,CAAC,OAAO,CAAC,IAAI,CAAC,CAAA;gBACnE,IAAI,MAAM,CAAC,EAAE,EAAE,CAAC;oBACd,KAAK,CAAC,oBAAoB,CAAC,CAAA;oBAC3B,OAAM;gBACR,CAAC;gBACD,KAAK,CACH,yBAAyB,YAAY,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,KAAK,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAC1F,CAAA;YACH,CAAC;SACF;KACF,CAAA;AACH,CAAC;AAED,MAAM,UAAU,QAAQ,CAAC,UAAiC,EAAE;IAC1D,OAAO;QACL,MAAM,EAAE,oBAAoB,EAAE;QAC9B,IAAI,EAAE,UAAU;QAChB,OAAO,EAAE,IAAI;QACb,OAAO;KACR,CAAA;AACH,CAAC"}
|
|
1
|
+
{"version":3,"file":"plugin.js","sourceRoot":"","sources":["../src/plugin.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
import type { ResolvedChxConfig } from '@chkit/core';
|
|
2
|
+
import type { BackfillDoctorReport, BackfillStatusSummary } from './types.js';
|
|
3
|
+
export declare function getBackfillStatus(input: {
|
|
4
|
+
planId: string;
|
|
5
|
+
configPath: string;
|
|
6
|
+
config: Pick<ResolvedChxConfig, 'metaDir'>;
|
|
7
|
+
stateDir?: string;
|
|
8
|
+
}): Promise<BackfillStatusSummary>;
|
|
9
|
+
export declare function cancelBackfillRun(input: {
|
|
10
|
+
planId: string;
|
|
11
|
+
configPath: string;
|
|
12
|
+
config: Pick<ResolvedChxConfig, 'metaDir'>;
|
|
13
|
+
stateDir?: string;
|
|
14
|
+
}): Promise<BackfillStatusSummary>;
|
|
15
|
+
export declare function getBackfillDoctorReport(input: {
|
|
16
|
+
planId: string;
|
|
17
|
+
configPath: string;
|
|
18
|
+
config: Pick<ResolvedChxConfig, 'metaDir'>;
|
|
19
|
+
stateDir?: string;
|
|
20
|
+
}): Promise<BackfillDoctorReport>;
|
|
21
|
+
//# sourceMappingURL=queries.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"queries.d.ts","sourceRoot":"","sources":["../src/queries.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,aAAa,CAAA;AAWpD,OAAO,KAAK,EACV,oBAAoB,EACpB,qBAAqB,EACtB,MAAM,YAAY,CAAA;AAEnB,wBAAsB,iBAAiB,CAAC,KAAK,EAAE;IAC7C,MAAM,EAAE,MAAM,CAAA;IACd,UAAU,EAAE,MAAM,CAAA;IAClB,MAAM,EAAE,IAAI,CAAC,iBAAiB,EAAE,SAAS,CAAC,CAAA;IAC1C,QAAQ,CAAC,EAAE,MAAM,CAAA;CAClB,GAAG,OAAO,CAAC,qBAAqB,CAAC,CA8BjC;AAED,wBAAsB,iBAAiB,CAAC,KAAK,EAAE;IAC7C,MAAM,EAAE,MAAM,CAAA;IACd,UAAU,EAAE,MAAM,CAAA;IAClB,MAAM,EAAE,IAAI,CAAC,iBAAiB,EAAE,SAAS,CAAC,CAAA;IAC1C,QAAQ,CAAC,EAAE,MAAM,CAAA;CAClB,GAAG,OAAO,CAAC,qBAAqB,CAAC,CA6BjC;AAED,wBAAsB,uBAAuB,CAAC,KAAK,EAAE;IACnD,MAAM,EAAE,MAAM,CAAA;IACd,UAAU,EAAE,MAAM,CAAA;IAClB,MAAM,EAAE,IAAI,CAAC,iBAAiB,EAAE,SAAS,CAAC,CAAA;IAC1C,QAAQ,CAAC,EAAE,MAAM,CAAA;CAClB,GAAG,OAAO,CAAC,oBAAoB,CAAC,CAgEhC"}
|
package/dist/queries.js
ADDED
|
@@ -0,0 +1,113 @@
|
|
|
1
|
+
import { BackfillConfigError } from './errors.js';
|
|
2
|
+
import { backfillPaths, nowIso, readPlan, readRun, summarizeRunStatus, writeJson, } from './state.js';
|
|
3
|
+
export async function getBackfillStatus(input) {
|
|
4
|
+
const { plan, stateDir } = await readPlan({
|
|
5
|
+
planId: input.planId,
|
|
6
|
+
configPath: input.configPath,
|
|
7
|
+
config: input.config,
|
|
8
|
+
stateDir: input.stateDir,
|
|
9
|
+
});
|
|
10
|
+
const paths = backfillPaths(stateDir, plan.planId);
|
|
11
|
+
const run = await readRun(paths.runPath);
|
|
12
|
+
if (!run) {
|
|
13
|
+
return {
|
|
14
|
+
planId: plan.planId,
|
|
15
|
+
target: plan.target,
|
|
16
|
+
status: 'planned',
|
|
17
|
+
totals: {
|
|
18
|
+
total: plan.chunkPlan.chunks.length,
|
|
19
|
+
pending: plan.chunkPlan.chunks.length,
|
|
20
|
+
submitted: 0,
|
|
21
|
+
running: 0,
|
|
22
|
+
done: 0,
|
|
23
|
+
failed: 0,
|
|
24
|
+
},
|
|
25
|
+
rowsWritten: 0,
|
|
26
|
+
updatedAt: plan.createdAt,
|
|
27
|
+
runPath: paths.runPath,
|
|
28
|
+
};
|
|
29
|
+
}
|
|
30
|
+
return summarizeRunStatus(run, paths.runPath, plan);
|
|
31
|
+
}
|
|
32
|
+
export async function cancelBackfillRun(input) {
|
|
33
|
+
const { plan, stateDir } = await readPlan({
|
|
34
|
+
planId: input.planId,
|
|
35
|
+
configPath: input.configPath,
|
|
36
|
+
config: input.config,
|
|
37
|
+
stateDir: input.stateDir,
|
|
38
|
+
});
|
|
39
|
+
const paths = backfillPaths(stateDir, plan.planId);
|
|
40
|
+
const run = await readRun(paths.runPath);
|
|
41
|
+
if (!run) {
|
|
42
|
+
throw new BackfillConfigError(`Run state not found for plan ${plan.planId}. Start with backfill run before cancel.`);
|
|
43
|
+
}
|
|
44
|
+
if (run.status === 'completed') {
|
|
45
|
+
throw new BackfillConfigError(`Run already completed for plan ${plan.planId}; cannot cancel.`);
|
|
46
|
+
}
|
|
47
|
+
if (run.status === 'cancelled') {
|
|
48
|
+
return summarizeRunStatus(run, paths.runPath, plan);
|
|
49
|
+
}
|
|
50
|
+
run.status = 'cancelled';
|
|
51
|
+
run.completedAt = nowIso();
|
|
52
|
+
run.lastError = 'Cancelled by operator';
|
|
53
|
+
await writeJson(paths.runPath, run);
|
|
54
|
+
return summarizeRunStatus(run, paths.runPath, plan);
|
|
55
|
+
}
|
|
56
|
+
export async function getBackfillDoctorReport(input) {
|
|
57
|
+
const { plan, stateDir } = await readPlan({
|
|
58
|
+
planId: input.planId,
|
|
59
|
+
configPath: input.configPath,
|
|
60
|
+
config: input.config,
|
|
61
|
+
stateDir: input.stateDir,
|
|
62
|
+
});
|
|
63
|
+
const paths = backfillPaths(stateDir, plan.planId);
|
|
64
|
+
const run = await readRun(paths.runPath);
|
|
65
|
+
const status = run
|
|
66
|
+
? summarizeRunStatus(run, paths.runPath, plan)
|
|
67
|
+
: {
|
|
68
|
+
planId: plan.planId,
|
|
69
|
+
target: plan.target,
|
|
70
|
+
status: 'planned',
|
|
71
|
+
totals: { total: plan.chunkPlan.chunks.length, pending: plan.chunkPlan.chunks.length, submitted: 0, running: 0, done: 0, failed: 0 },
|
|
72
|
+
rowsWritten: 0,
|
|
73
|
+
updatedAt: plan.createdAt,
|
|
74
|
+
runPath: paths.runPath,
|
|
75
|
+
};
|
|
76
|
+
const issueCodes = [];
|
|
77
|
+
const recommendations = [];
|
|
78
|
+
const failedChunkIds = [];
|
|
79
|
+
if (run) {
|
|
80
|
+
for (const [chunkId, state] of Object.entries(run.progress)) {
|
|
81
|
+
if (state.status === 'failed')
|
|
82
|
+
failedChunkIds.push(chunkId);
|
|
83
|
+
}
|
|
84
|
+
}
|
|
85
|
+
if (status.status === 'planned') {
|
|
86
|
+
issueCodes.push('backfill_plan_missing');
|
|
87
|
+
recommendations.push(`Run: chkit plugin backfill run --plan-id ${status.planId}`);
|
|
88
|
+
}
|
|
89
|
+
if (status.status === 'failed') {
|
|
90
|
+
issueCodes.push('backfill_chunk_failed_retry_exhausted');
|
|
91
|
+
recommendations.push(`Inspect status: chkit plugin backfill status --plan-id ${status.planId}`);
|
|
92
|
+
recommendations.push(`Retry failed chunks: chkit plugin backfill resume --plan-id ${status.planId} --replay-failed`);
|
|
93
|
+
}
|
|
94
|
+
if (status.status === 'cancelled') {
|
|
95
|
+
issueCodes.push('backfill_required_pending');
|
|
96
|
+
recommendations.push(`Resume execution: chkit plugin backfill resume --plan-id ${status.planId} --replay-failed`);
|
|
97
|
+
}
|
|
98
|
+
if (status.status === 'running') {
|
|
99
|
+
issueCodes.push('backfill_required_pending');
|
|
100
|
+
recommendations.push(`Monitor progress: chkit plugin backfill status --plan-id ${status.planId}`);
|
|
101
|
+
}
|
|
102
|
+
if (issueCodes.length === 0) {
|
|
103
|
+
recommendations.push('No remediation required.');
|
|
104
|
+
}
|
|
105
|
+
return {
|
|
106
|
+
planId: status.planId,
|
|
107
|
+
status: status.status,
|
|
108
|
+
issueCodes,
|
|
109
|
+
recommendations,
|
|
110
|
+
failedChunkIds,
|
|
111
|
+
};
|
|
112
|
+
}
|
|
113
|
+
//# sourceMappingURL=queries.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"queries.js","sourceRoot":"","sources":["../src/queries.ts"],"names":[],"mappings":"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"}
|
package/dist/runtime.d.ts
CHANGED
|
@@ -11,6 +11,13 @@ export declare function executeBackfillRun(input: {
|
|
|
11
11
|
config: Pick<ResolvedChxConfig, 'metaDir'>;
|
|
12
12
|
options: NormalizedBackfillPluginOptions;
|
|
13
13
|
execution?: BackfillExecutionOptions;
|
|
14
|
+
execute?: (sql: string) => Promise<undefined | {
|
|
15
|
+
rowsWritten?: number;
|
|
16
|
+
}>;
|
|
17
|
+
clickhouse?: {
|
|
18
|
+
url: string;
|
|
19
|
+
database: string;
|
|
20
|
+
};
|
|
14
21
|
}): Promise<ExecuteBackfillRunOutput>;
|
|
15
22
|
export declare function resumeBackfillRun(input: {
|
|
16
23
|
planId: string;
|
|
@@ -18,6 +25,13 @@ export declare function resumeBackfillRun(input: {
|
|
|
18
25
|
config: Pick<ResolvedChxConfig, 'metaDir'>;
|
|
19
26
|
options: NormalizedBackfillPluginOptions;
|
|
20
27
|
execution?: BackfillExecutionOptions;
|
|
28
|
+
execute?: (sql: string) => Promise<undefined | {
|
|
29
|
+
rowsWritten?: number;
|
|
30
|
+
}>;
|
|
31
|
+
clickhouse?: {
|
|
32
|
+
url: string;
|
|
33
|
+
database: string;
|
|
34
|
+
};
|
|
21
35
|
}): Promise<ExecuteBackfillRunOutput>;
|
|
22
36
|
export declare function getBackfillStatus(input: {
|
|
23
37
|
planId: string;
|
package/dist/runtime.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"runtime.d.ts","sourceRoot":"","sources":["../src/runtime.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"runtime.d.ts","sourceRoot":"","sources":["../src/runtime.ts"],"names":[],"mappings":"AAGA,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,aAAa,CAAA;AAiBpD,OAAO,KAAK,EACV,oBAAoB,EAEpB,wBAAwB,EACxB,yBAAyB,EAGzB,qBAAqB,EACrB,wBAAwB,EACxB,+BAA+B,EAChC,MAAM,YAAY,CAAA;AAEnB,wBAAsB,qBAAqB,CAAC,KAAK,EAAE;IACjD,UAAU,EAAE,MAAM,CAAA;IAClB,MAAM,EAAE,IAAI,CAAC,iBAAiB,EAAE,SAAS,CAAC,CAAA;IAC1C,OAAO,EAAE,+BAA+B,CAAA;CACzC,GAAG,OAAO,CAAC,yBAAyB,CAAC,CAgFrC;AA+RD,wBAAsB,kBAAkB,CAAC,KAAK,EAAE;IAC9C,MAAM,EAAE,MAAM,CAAA;IACd,UAAU,EAAE,MAAM,CAAA;IAClB,MAAM,EAAE,IAAI,CAAC,iBAAiB,EAAE,SAAS,CAAC,CAAA;IAC1C,OAAO,EAAE,+BAA+B,CAAA;IACxC,SAAS,CAAC,EAAE,wBAAwB,CAAA;IACpC,OAAO,CAAC,EAAE,CAAC,GAAG,EAAE,MAAM,KAAK,OAAO,CAAC,SAAS,GAAG;QAAE,WAAW,CAAC,EAAE,MAAM,CAAA;KAAE,CAAC,CAAA;IACxE,UAAU,CAAC,EAAE;QAAE,GAAG,EAAE,MAAM,CAAC;QAAC,QAAQ,EAAE,MAAM,CAAA;KAAE,CAAA;CAC/C,GAAG,OAAO,CAAC,wBAAwB,CAAC,CAgEpC;AAED,wBAAsB,iBAAiB,CAAC,KAAK,EAAE;IAC7C,MAAM,EAAE,MAAM,CAAA;IACd,UAAU,EAAE,MAAM,CAAA;IAClB,MAAM,EAAE,IAAI,CAAC,iBAAiB,EAAE,SAAS,CAAC,CAAA;IAC1C,OAAO,EAAE,+BAA+B,CAAA;IACxC,SAAS,CAAC,EAAE,wBAAwB,CAAA;IACpC,OAAO,CAAC,EAAE,CAAC,GAAG,EAAE,MAAM,KAAK,OAAO,CAAC,SAAS,GAAG;QAAE,WAAW,CAAC,EAAE,MAAM,CAAA;KAAE,CAAC,CAAA;IACxE,UAAU,CAAC,EAAE;QAAE,GAAG,EAAE,MAAM,CAAC;QAAC,QAAQ,EAAE,MAAM,CAAA;KAAE,CAAA;CAC/C,GAAG,OAAO,CAAC,wBAAwB,CAAC,CAyDpC;AAED,wBAAsB,iBAAiB,CAAC,KAAK,EAAE;IAC7C,MAAM,EAAE,MAAM,CAAA;IACd,UAAU,EAAE,MAAM,CAAA;IAClB,MAAM,EAAE,IAAI,CAAC,iBAAiB,EAAE,SAAS,CAAC,CAAA;IAC1C,OAAO,EAAE,+BAA+B,CAAA;CACzC,GAAG,OAAO,CAAC,qBAAqB,CAAC,CAgCjC;AAED,wBAAsB,iBAAiB,CAAC,KAAK,EAAE;IAC7C,MAAM,EAAE,MAAM,CAAA;IACd,UAAU,EAAE,MAAM,CAAA;IAClB,MAAM,EAAE,IAAI,CAAC,iBAAiB,EAAE,SAAS,CAAC,CAAA;IAC1C,OAAO,EAAE,+BAA+B,CAAA;CACzC,GAAG,OAAO,CAAC,qBAAqB,CAAC,CA0CjC;AAED,wBAAsB,uBAAuB,CAAC,KAAK,EAAE;IACnD,MAAM,EAAE,MAAM,CAAA;IACd,UAAU,EAAE,MAAM,CAAA;IAClB,MAAM,EAAE,IAAI,CAAC,iBAAiB,EAAE,SAAS,CAAC,CAAA;IAC1C,OAAO,EAAE,+BAA+B,CAAA;CACzC,GAAG,OAAO,CAAC,oBAAoB,CAAC,CA2ChC"}
|
package/dist/runtime.js
CHANGED
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
import { join } from 'node:path';
|
|
2
|
+
import process from 'node:process';
|
|
2
3
|
import { BackfillConfigError } from './errors.js';
|
|
3
|
-
import { backfillPaths, collectActiveRunTargets, computeBackfillStateDir, createRunState, ensureRunCompatibility, listPlanIds, nowIso, persistRunAndEvent, readPlan, readRun, summarizeRunStatus, } from './state.js';
|
|
4
|
+
import { backfillPaths, collectActiveRunTargets, computeBackfillStateDir, createRunState, ensureEnvironmentMatch, ensureRunCompatibility, listPlanIds, nowIso, persistRunAndEvent, readPlan, readRun, summarizeRunStatus, } from './state.js';
|
|
4
5
|
export async function evaluateBackfillCheck(input) {
|
|
5
6
|
const stateDir = computeBackfillStateDir(input.config, input.configPath, input.options);
|
|
6
7
|
const plansDir = join(stateDir, 'plans');
|
|
@@ -77,6 +78,9 @@ export async function evaluateBackfillCheck(input) {
|
|
|
77
78
|
},
|
|
78
79
|
};
|
|
79
80
|
}
|
|
81
|
+
function sleep(ms) {
|
|
82
|
+
return new Promise((resolve) => setTimeout(resolve, ms));
|
|
83
|
+
}
|
|
80
84
|
async function executeChunk(input) {
|
|
81
85
|
const failureBudget = input.simulation?.failCount ?? 0;
|
|
82
86
|
while (input.chunk.attempts < input.maxRetries) {
|
|
@@ -95,10 +99,26 @@ async function executeChunk(input) {
|
|
|
95
99
|
},
|
|
96
100
|
});
|
|
97
101
|
const shouldSimulateFailure = input.simulation?.failChunkId === input.chunk.id && input.chunk.attempts <= failureBudget;
|
|
98
|
-
|
|
102
|
+
let attemptError;
|
|
103
|
+
let executionResult;
|
|
104
|
+
if (shouldSimulateFailure) {
|
|
105
|
+
attemptError = `Simulated failure for chunk ${input.chunk.id} attempt ${input.chunk.attempts}`;
|
|
106
|
+
}
|
|
107
|
+
else if (input.execute) {
|
|
108
|
+
try {
|
|
109
|
+
executionResult = await input.execute(input.chunk.sqlTemplate);
|
|
110
|
+
}
|
|
111
|
+
catch (error) {
|
|
112
|
+
attemptError = error instanceof Error ? error.message : String(error);
|
|
113
|
+
}
|
|
114
|
+
}
|
|
115
|
+
if (!attemptError) {
|
|
99
116
|
input.chunk.status = 'done';
|
|
100
117
|
input.chunk.completedAt = nowIso();
|
|
101
118
|
input.chunk.lastError = undefined;
|
|
119
|
+
if (executionResult && typeof executionResult === 'object' && typeof executionResult.rowsWritten === 'number') {
|
|
120
|
+
input.chunk.rowsWritten = executionResult.rowsWritten;
|
|
121
|
+
}
|
|
102
122
|
await persistRunAndEvent({
|
|
103
123
|
run: input.run,
|
|
104
124
|
runPath: input.runPath,
|
|
@@ -112,12 +132,9 @@ async function executeChunk(input) {
|
|
|
112
132
|
});
|
|
113
133
|
return { ok: true };
|
|
114
134
|
}
|
|
115
|
-
|
|
116
|
-
input.chunk.lastError = errorMessage;
|
|
135
|
+
input.chunk.lastError = attemptError;
|
|
117
136
|
if (input.chunk.attempts >= input.maxRetries) {
|
|
118
137
|
input.chunk.status = 'failed';
|
|
119
|
-
input.run.status = 'failed';
|
|
120
|
-
input.run.lastError = errorMessage;
|
|
121
138
|
await persistRunAndEvent({
|
|
122
139
|
run: input.run,
|
|
123
140
|
runPath: input.runPath,
|
|
@@ -127,10 +144,10 @@ async function executeChunk(input) {
|
|
|
127
144
|
planId: input.run.planId,
|
|
128
145
|
chunkId: input.chunk.id,
|
|
129
146
|
attempt: input.chunk.attempts,
|
|
130
|
-
message:
|
|
147
|
+
message: attemptError,
|
|
131
148
|
},
|
|
132
149
|
});
|
|
133
|
-
return { ok: false, error:
|
|
150
|
+
return { ok: false, error: attemptError };
|
|
134
151
|
}
|
|
135
152
|
input.chunk.status = 'pending';
|
|
136
153
|
await persistRunAndEvent({
|
|
@@ -145,6 +162,10 @@ async function executeChunk(input) {
|
|
|
145
162
|
nextAttempt: input.chunk.attempts + 1,
|
|
146
163
|
},
|
|
147
164
|
});
|
|
165
|
+
if (input.retryDelayMs > 0) {
|
|
166
|
+
const delay = input.retryDelayMs * 2 ** (input.chunk.attempts - 1);
|
|
167
|
+
await sleep(delay);
|
|
168
|
+
}
|
|
148
169
|
}
|
|
149
170
|
return {
|
|
150
171
|
ok: false,
|
|
@@ -153,66 +174,73 @@ async function executeChunk(input) {
|
|
|
153
174
|
}
|
|
154
175
|
async function executeRunLoop(input) {
|
|
155
176
|
const maxRetries = input.plan.options.maxRetriesPerChunk;
|
|
156
|
-
|
|
157
|
-
|
|
158
|
-
|
|
159
|
-
|
|
160
|
-
|
|
161
|
-
|
|
162
|
-
|
|
163
|
-
|
|
164
|
-
|
|
165
|
-
planId: input.plan.planId,
|
|
166
|
-
replayDone: input.run.replayDone,
|
|
167
|
-
replayFailed: input.run.replayFailed,
|
|
168
|
-
},
|
|
169
|
-
});
|
|
170
|
-
for (const chunk of input.run.chunks) {
|
|
171
|
-
if (chunk.status === 'done' && !input.run.replayDone)
|
|
172
|
-
continue;
|
|
173
|
-
if (chunk.status === 'failed') {
|
|
174
|
-
if (!input.run.replayFailed) {
|
|
175
|
-
input.run.status = 'failed';
|
|
176
|
-
input.run.lastError =
|
|
177
|
-
chunk.lastError ??
|
|
178
|
-
`Chunk ${chunk.id} is failed and resume requires --replay-failed to re-run failed chunks.`;
|
|
179
|
-
await persistRunAndEvent({
|
|
180
|
-
run: input.run,
|
|
181
|
-
runPath: input.paths.runPath,
|
|
182
|
-
eventPath: input.paths.eventPath,
|
|
183
|
-
event: {
|
|
184
|
-
type: 'run_blocked_failed_chunk',
|
|
185
|
-
planId: input.plan.planId,
|
|
186
|
-
chunkId: chunk.id,
|
|
187
|
-
message: input.run.lastError,
|
|
188
|
-
},
|
|
189
|
-
});
|
|
190
|
-
return {
|
|
191
|
-
run: input.run,
|
|
192
|
-
status: summarizeRunStatus(input.run, input.paths.runPath, input.paths.eventPath),
|
|
193
|
-
runPath: input.paths.runPath,
|
|
194
|
-
eventPath: input.paths.eventPath,
|
|
195
|
-
};
|
|
196
|
-
}
|
|
197
|
-
chunk.status = 'pending';
|
|
198
|
-
chunk.attempts = 0;
|
|
199
|
-
chunk.lastError = undefined;
|
|
200
|
-
chunk.startedAt = undefined;
|
|
201
|
-
chunk.completedAt = undefined;
|
|
202
|
-
}
|
|
203
|
-
if (chunk.status === 'running') {
|
|
204
|
-
chunk.status = 'pending';
|
|
205
|
-
}
|
|
206
|
-
const executed = await executeChunk({
|
|
177
|
+
let aborted = false;
|
|
178
|
+
const onSignal = () => { aborted = true; };
|
|
179
|
+
process.on('SIGINT', onSignal);
|
|
180
|
+
process.on('SIGTERM', onSignal);
|
|
181
|
+
try {
|
|
182
|
+
input.run.status = 'running';
|
|
183
|
+
input.run.replayDone = input.execution.replayDone ?? false;
|
|
184
|
+
input.run.replayFailed = input.execution.replayFailed ?? false;
|
|
185
|
+
await persistRunAndEvent({
|
|
207
186
|
run: input.run,
|
|
208
|
-
chunk,
|
|
209
|
-
maxRetries,
|
|
210
187
|
runPath: input.paths.runPath,
|
|
211
188
|
eventPath: input.paths.eventPath,
|
|
212
|
-
|
|
189
|
+
event: {
|
|
190
|
+
type: 'run_started',
|
|
191
|
+
planId: input.plan.planId,
|
|
192
|
+
replayDone: input.run.replayDone,
|
|
193
|
+
replayFailed: input.run.replayFailed,
|
|
194
|
+
},
|
|
213
195
|
});
|
|
214
|
-
|
|
196
|
+
for (const chunk of input.run.chunks) {
|
|
197
|
+
if (aborted)
|
|
198
|
+
break;
|
|
199
|
+
if (chunk.status === 'done' && !input.run.replayDone)
|
|
200
|
+
continue;
|
|
201
|
+
if (chunk.status === 'failed') {
|
|
202
|
+
if (!input.run.replayFailed) {
|
|
203
|
+
// Skip previously failed chunk — continue to remaining chunks
|
|
204
|
+
continue;
|
|
205
|
+
}
|
|
206
|
+
chunk.status = 'pending';
|
|
207
|
+
chunk.attempts = 0;
|
|
208
|
+
chunk.lastError = undefined;
|
|
209
|
+
chunk.startedAt = undefined;
|
|
210
|
+
chunk.completedAt = undefined;
|
|
211
|
+
}
|
|
212
|
+
if (chunk.status === 'running') {
|
|
213
|
+
chunk.status = 'pending';
|
|
214
|
+
}
|
|
215
|
+
await executeChunk({
|
|
216
|
+
run: input.run,
|
|
217
|
+
chunk,
|
|
218
|
+
maxRetries,
|
|
219
|
+
retryDelayMs: input.retryDelayMs,
|
|
220
|
+
runPath: input.paths.runPath,
|
|
221
|
+
eventPath: input.paths.eventPath,
|
|
222
|
+
execute: input.execute,
|
|
223
|
+
simulation: input.execution.simulation,
|
|
224
|
+
});
|
|
225
|
+
}
|
|
226
|
+
// Determine final run status after all chunks have been attempted
|
|
227
|
+
const failedChunks = input.run.chunks.filter((c) => c.status === 'failed');
|
|
228
|
+
if (!aborted && failedChunks.length > 0) {
|
|
229
|
+
input.run.status = 'failed';
|
|
230
|
+
input.run.lastError =
|
|
231
|
+
failedChunks[failedChunks.length - 1]?.lastError ?? 'One or more chunks failed';
|
|
215
232
|
input.run.completedAt = nowIso();
|
|
233
|
+
await persistRunAndEvent({
|
|
234
|
+
run: input.run,
|
|
235
|
+
runPath: input.paths.runPath,
|
|
236
|
+
eventPath: input.paths.eventPath,
|
|
237
|
+
event: {
|
|
238
|
+
type: 'run_completed_with_failures',
|
|
239
|
+
planId: input.plan.planId,
|
|
240
|
+
failedCount: failedChunks.length,
|
|
241
|
+
totalCount: input.run.chunks.length,
|
|
242
|
+
},
|
|
243
|
+
});
|
|
216
244
|
return {
|
|
217
245
|
run: input.run,
|
|
218
246
|
status: summarizeRunStatus(input.run, input.paths.runPath, input.paths.eventPath),
|
|
@@ -220,25 +248,49 @@ async function executeRunLoop(input) {
|
|
|
220
248
|
eventPath: input.paths.eventPath,
|
|
221
249
|
};
|
|
222
250
|
}
|
|
251
|
+
if (!aborted) {
|
|
252
|
+
input.run.status = 'completed';
|
|
253
|
+
input.run.completedAt = nowIso();
|
|
254
|
+
input.run.lastError = undefined;
|
|
255
|
+
await persistRunAndEvent({
|
|
256
|
+
run: input.run,
|
|
257
|
+
runPath: input.paths.runPath,
|
|
258
|
+
eventPath: input.paths.eventPath,
|
|
259
|
+
event: {
|
|
260
|
+
type: 'run_completed',
|
|
261
|
+
planId: input.plan.planId,
|
|
262
|
+
},
|
|
263
|
+
});
|
|
264
|
+
}
|
|
265
|
+
return {
|
|
266
|
+
run: input.run,
|
|
267
|
+
status: summarizeRunStatus(input.run, input.paths.runPath, input.paths.eventPath),
|
|
268
|
+
runPath: input.paths.runPath,
|
|
269
|
+
eventPath: input.paths.eventPath,
|
|
270
|
+
};
|
|
271
|
+
}
|
|
272
|
+
finally {
|
|
273
|
+
process.removeListener('SIGINT', onSignal);
|
|
274
|
+
process.removeListener('SIGTERM', onSignal);
|
|
275
|
+
for (const chunk of input.run.chunks) {
|
|
276
|
+
if (chunk.status === 'running') {
|
|
277
|
+
chunk.status = 'pending';
|
|
278
|
+
}
|
|
279
|
+
}
|
|
280
|
+
if (input.run.status === 'running') {
|
|
281
|
+
input.run.status = 'paused';
|
|
282
|
+
await persistRunAndEvent({
|
|
283
|
+
run: input.run,
|
|
284
|
+
runPath: input.paths.runPath,
|
|
285
|
+
eventPath: input.paths.eventPath,
|
|
286
|
+
event: {
|
|
287
|
+
type: 'run_paused',
|
|
288
|
+
planId: input.plan.planId,
|
|
289
|
+
reason: 'process_exit',
|
|
290
|
+
},
|
|
291
|
+
});
|
|
292
|
+
}
|
|
223
293
|
}
|
|
224
|
-
input.run.status = 'completed';
|
|
225
|
-
input.run.completedAt = nowIso();
|
|
226
|
-
input.run.lastError = undefined;
|
|
227
|
-
await persistRunAndEvent({
|
|
228
|
-
run: input.run,
|
|
229
|
-
runPath: input.paths.runPath,
|
|
230
|
-
eventPath: input.paths.eventPath,
|
|
231
|
-
event: {
|
|
232
|
-
type: 'run_completed',
|
|
233
|
-
planId: input.plan.planId,
|
|
234
|
-
},
|
|
235
|
-
});
|
|
236
|
-
return {
|
|
237
|
-
run: input.run,
|
|
238
|
-
status: summarizeRunStatus(input.run, input.paths.runPath, input.paths.eventPath),
|
|
239
|
-
runPath: input.paths.runPath,
|
|
240
|
-
eventPath: input.paths.eventPath,
|
|
241
|
-
};
|
|
242
294
|
}
|
|
243
295
|
async function assertNoOverlappingActiveRun(input) {
|
|
244
296
|
const activeTargets = await collectActiveRunTargets(input.runsDir);
|
|
@@ -258,6 +310,11 @@ export async function executeBackfillRun(input) {
|
|
|
258
310
|
config: input.config,
|
|
259
311
|
options: input.options,
|
|
260
312
|
});
|
|
313
|
+
ensureEnvironmentMatch({
|
|
314
|
+
plan,
|
|
315
|
+
clickhouse: input.clickhouse,
|
|
316
|
+
forceEnvironment: execution.forceEnvironment ?? false,
|
|
317
|
+
});
|
|
261
318
|
const paths = backfillPaths(stateDir, plan.planId);
|
|
262
319
|
if (input.options.policy.blockOverlappingRuns && !execution.forceOverlap) {
|
|
263
320
|
await assertNoOverlappingActiveRun({
|
|
@@ -283,7 +340,13 @@ export async function executeBackfillRun(input) {
|
|
|
283
340
|
});
|
|
284
341
|
}
|
|
285
342
|
if (run.status === 'completed' && !execution.replayDone && !execution.replayFailed) {
|
|
286
|
-
|
|
343
|
+
return {
|
|
344
|
+
run,
|
|
345
|
+
status: summarizeRunStatus(run, paths.runPath, paths.eventPath),
|
|
346
|
+
runPath: paths.runPath,
|
|
347
|
+
eventPath: paths.eventPath,
|
|
348
|
+
noop: true,
|
|
349
|
+
};
|
|
287
350
|
}
|
|
288
351
|
if (run.status === 'cancelled') {
|
|
289
352
|
throw new BackfillConfigError(`Run is cancelled for plan ${plan.planId}. Create a new plan or inspect with backfill doctor.`);
|
|
@@ -293,6 +356,8 @@ export async function executeBackfillRun(input) {
|
|
|
293
356
|
run,
|
|
294
357
|
paths,
|
|
295
358
|
execution,
|
|
359
|
+
retryDelayMs: input.options.defaults.retryDelayMs,
|
|
360
|
+
execute: input.execute,
|
|
296
361
|
});
|
|
297
362
|
}
|
|
298
363
|
export async function resumeBackfillRun(input) {
|
|
@@ -302,6 +367,11 @@ export async function resumeBackfillRun(input) {
|
|
|
302
367
|
config: input.config,
|
|
303
368
|
options: input.options,
|
|
304
369
|
});
|
|
370
|
+
ensureEnvironmentMatch({
|
|
371
|
+
plan,
|
|
372
|
+
clickhouse: input.clickhouse,
|
|
373
|
+
forceEnvironment: input.execution?.forceEnvironment ?? false,
|
|
374
|
+
});
|
|
305
375
|
const paths = backfillPaths(stateDir, plan.planId);
|
|
306
376
|
const run = await readRun(paths.runPath);
|
|
307
377
|
if (!run) {
|
|
@@ -323,11 +393,19 @@ export async function resumeBackfillRun(input) {
|
|
|
323
393
|
if (run.status === 'cancelled') {
|
|
324
394
|
throw new BackfillConfigError(`Run is cancelled for plan ${plan.planId}. Create a new plan or inspect with backfill doctor.`);
|
|
325
395
|
}
|
|
396
|
+
// Resume always retries failed chunks — the whole point of resume is to
|
|
397
|
+
// recover from failures. Users shouldn't need --replay-failed for this.
|
|
398
|
+
const execution = {
|
|
399
|
+
...input.execution,
|
|
400
|
+
replayFailed: true,
|
|
401
|
+
};
|
|
326
402
|
return executeRunLoop({
|
|
327
403
|
plan,
|
|
328
404
|
run,
|
|
329
405
|
paths,
|
|
330
|
-
execution
|
|
406
|
+
execution,
|
|
407
|
+
retryDelayMs: input.options.defaults.retryDelayMs,
|
|
408
|
+
execute: input.execute,
|
|
331
409
|
});
|
|
332
410
|
}
|
|
333
411
|
export async function getBackfillStatus(input) {
|
|
@@ -353,6 +431,7 @@ export async function getBackfillStatus(input) {
|
|
|
353
431
|
skipped: 0,
|
|
354
432
|
},
|
|
355
433
|
attempts: 0,
|
|
434
|
+
rowsWritten: 0,
|
|
356
435
|
updatedAt: plan.createdAt,
|
|
357
436
|
runPath: paths.runPath,
|
|
358
437
|
eventPath: paths.eventPath,
|