@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.
Files changed (164) hide show
  1. package/README.md +170 -0
  2. package/dist/args.d.ts +109 -6
  3. package/dist/args.d.ts.map +1 -1
  4. package/dist/args.js +73 -97
  5. package/dist/args.js.map +1 -1
  6. package/dist/async-backfill.d.ts +64 -0
  7. package/dist/async-backfill.d.ts.map +1 -0
  8. package/dist/async-backfill.js +251 -0
  9. package/dist/async-backfill.js.map +1 -0
  10. package/dist/check.d.ts +9 -0
  11. package/dist/check.d.ts.map +1 -0
  12. package/dist/check.js +79 -0
  13. package/dist/check.js.map +1 -0
  14. package/dist/chunking/analyze.d.ts +8 -0
  15. package/dist/chunking/analyze.d.ts.map +1 -0
  16. package/dist/chunking/analyze.js +8 -0
  17. package/dist/chunking/analyze.js.map +1 -0
  18. package/dist/chunking/boundary-codec.d.ts +10 -0
  19. package/dist/chunking/boundary-codec.d.ts.map +1 -0
  20. package/dist/chunking/boundary-codec.js +79 -0
  21. package/dist/chunking/boundary-codec.js.map +1 -0
  22. package/dist/chunking/build.d.ts +11 -0
  23. package/dist/chunking/build.d.ts.map +1 -0
  24. package/dist/chunking/build.js +51 -0
  25. package/dist/chunking/build.js.map +1 -0
  26. package/dist/chunking/e2e/constants.d.ts +2 -0
  27. package/dist/chunking/e2e/constants.d.ts.map +1 -0
  28. package/dist/chunking/e2e/constants.js +2 -0
  29. package/dist/chunking/e2e/constants.js.map +1 -0
  30. package/dist/chunking/e2e/seed-datasets.script.d.ts +20 -0
  31. package/dist/chunking/e2e/seed-datasets.script.d.ts.map +1 -0
  32. package/dist/chunking/e2e/seed-datasets.script.js +134 -0
  33. package/dist/chunking/e2e/seed-datasets.script.js.map +1 -0
  34. package/dist/chunking/introspect.d.ts +40 -0
  35. package/dist/chunking/introspect.d.ts.map +1 -0
  36. package/dist/chunking/introspect.js +187 -0
  37. package/dist/chunking/introspect.js.map +1 -0
  38. package/dist/chunking/partition-slices.d.ts +14 -0
  39. package/dist/chunking/partition-slices.d.ts.map +1 -0
  40. package/dist/chunking/partition-slices.js +111 -0
  41. package/dist/chunking/partition-slices.js.map +1 -0
  42. package/dist/chunking/planner.d.ts +3 -0
  43. package/dist/chunking/planner.d.ts.map +1 -0
  44. package/dist/chunking/planner.js +343 -0
  45. package/dist/chunking/planner.js.map +1 -0
  46. package/dist/chunking/services/distribution-source.d.ts +11 -0
  47. package/dist/chunking/services/distribution-source.d.ts.map +1 -0
  48. package/dist/chunking/services/distribution-source.js +60 -0
  49. package/dist/chunking/services/distribution-source.js.map +1 -0
  50. package/dist/chunking/services/metadata-source.d.ts +4 -0
  51. package/dist/chunking/services/metadata-source.d.ts.map +1 -0
  52. package/dist/chunking/services/metadata-source.js +138 -0
  53. package/dist/chunking/services/metadata-source.js.map +1 -0
  54. package/dist/chunking/services/row-probe.d.ts +14 -0
  55. package/dist/chunking/services/row-probe.d.ts.map +1 -0
  56. package/dist/chunking/services/row-probe.js +62 -0
  57. package/dist/chunking/services/row-probe.js.map +1 -0
  58. package/dist/chunking/splitter.d.ts +20 -0
  59. package/dist/chunking/splitter.d.ts.map +1 -0
  60. package/dist/chunking/splitter.js +76 -0
  61. package/dist/chunking/splitter.js.map +1 -0
  62. package/dist/chunking/sql.d.ts +20 -0
  63. package/dist/chunking/sql.d.ts.map +1 -0
  64. package/dist/chunking/sql.js +304 -0
  65. package/dist/chunking/sql.js.map +1 -0
  66. package/dist/chunking/strategies/equal-width-split.d.ts +4 -0
  67. package/dist/chunking/strategies/equal-width-split.d.ts.map +1 -0
  68. package/dist/chunking/strategies/equal-width-split.js +46 -0
  69. package/dist/chunking/strategies/equal-width-split.js.map +1 -0
  70. package/dist/chunking/strategies/group-by-key-split.d.ts +3 -0
  71. package/dist/chunking/strategies/group-by-key-split.d.ts.map +1 -0
  72. package/dist/chunking/strategies/group-by-key-split.js +54 -0
  73. package/dist/chunking/strategies/group-by-key-split.js.map +1 -0
  74. package/dist/chunking/strategies/metadata-single-chunk.d.ts +3 -0
  75. package/dist/chunking/strategies/metadata-single-chunk.d.ts.map +1 -0
  76. package/dist/chunking/strategies/metadata-single-chunk.js +5 -0
  77. package/dist/chunking/strategies/metadata-single-chunk.js.map +1 -0
  78. package/dist/chunking/strategies/quantile-range-split.d.ts +5 -0
  79. package/dist/chunking/strategies/quantile-range-split.d.ts.map +1 -0
  80. package/dist/chunking/strategies/quantile-range-split.js +132 -0
  81. package/dist/chunking/strategies/quantile-range-split.js.map +1 -0
  82. package/dist/chunking/strategies/refinement.d.ts +4 -0
  83. package/dist/chunking/strategies/refinement.d.ts.map +1 -0
  84. package/dist/chunking/strategies/refinement.js +61 -0
  85. package/dist/chunking/strategies/refinement.js.map +1 -0
  86. package/dist/chunking/strategies/string-prefix-split.d.ts +4 -0
  87. package/dist/chunking/strategies/string-prefix-split.d.ts.map +1 -0
  88. package/dist/chunking/strategies/string-prefix-split.js +73 -0
  89. package/dist/chunking/strategies/string-prefix-split.js.map +1 -0
  90. package/dist/chunking/strategies/temporal-bucket-split.d.ts +4 -0
  91. package/dist/chunking/strategies/temporal-bucket-split.d.ts.map +1 -0
  92. package/dist/chunking/strategies/temporal-bucket-split.js +67 -0
  93. package/dist/chunking/strategies/temporal-bucket-split.js.map +1 -0
  94. package/dist/chunking/strategy-policy.d.ts +3 -0
  95. package/dist/chunking/strategy-policy.d.ts.map +1 -0
  96. package/dist/chunking/strategy-policy.js +4 -0
  97. package/dist/chunking/strategy-policy.js.map +1 -0
  98. package/dist/chunking/types.d.ts +139 -0
  99. package/dist/chunking/types.d.ts.map +1 -0
  100. package/dist/chunking/types.js +2 -0
  101. package/dist/chunking/types.js.map +1 -0
  102. package/dist/chunking/utils/binary-string.d.ts +8 -0
  103. package/dist/chunking/utils/binary-string.d.ts.map +1 -0
  104. package/dist/chunking/utils/binary-string.js +52 -0
  105. package/dist/chunking/utils/binary-string.js.map +1 -0
  106. package/dist/chunking/utils/ids.d.ts +4 -0
  107. package/dist/chunking/utils/ids.d.ts.map +1 -0
  108. package/dist/chunking/utils/ids.js +11 -0
  109. package/dist/chunking/utils/ids.js.map +1 -0
  110. package/dist/chunking/utils/ranges.d.ts +5 -0
  111. package/dist/chunking/utils/ranges.d.ts.map +1 -0
  112. package/dist/chunking/utils/ranges.js +19 -0
  113. package/dist/chunking/utils/ranges.js.map +1 -0
  114. package/dist/detect.d.ts +13 -0
  115. package/dist/detect.d.ts.map +1 -0
  116. package/dist/detect.js +113 -0
  117. package/dist/detect.js.map +1 -0
  118. package/dist/index.d.ts +3 -0
  119. package/dist/index.d.ts.map +1 -1
  120. package/dist/index.js +1 -0
  121. package/dist/index.js.map +1 -1
  122. package/dist/logging.d.ts +12 -0
  123. package/dist/logging.d.ts.map +1 -0
  124. package/dist/logging.js +61 -0
  125. package/dist/logging.js.map +1 -0
  126. package/dist/options.d.ts +151 -4
  127. package/dist/options.d.ts.map +1 -1
  128. package/dist/options.js +161 -109
  129. package/dist/options.js.map +1 -1
  130. package/dist/payload.d.ts +7 -17
  131. package/dist/payload.d.ts.map +1 -1
  132. package/dist/payload.js +7 -19
  133. package/dist/payload.js.map +1 -1
  134. package/dist/planner.d.ts +10 -8
  135. package/dist/planner.d.ts.map +1 -1
  136. package/dist/planner.js +76 -97
  137. package/dist/planner.js.map +1 -1
  138. package/dist/plugin.d.ts +4 -3
  139. package/dist/plugin.d.ts.map +1 -1
  140. package/dist/plugin.js +311 -215
  141. package/dist/plugin.js.map +1 -1
  142. package/dist/queries.d.ts +21 -0
  143. package/dist/queries.d.ts.map +1 -0
  144. package/dist/queries.js +113 -0
  145. package/dist/queries.js.map +1 -0
  146. package/dist/runtime.d.ts +14 -0
  147. package/dist/runtime.d.ts.map +1 -1
  148. package/dist/runtime.js +162 -83
  149. package/dist/runtime.js.map +1 -1
  150. package/dist/sdk.d.ts +12 -0
  151. package/dist/sdk.d.ts.map +1 -0
  152. package/dist/sdk.js +9 -0
  153. package/dist/sdk.js.map +1 -0
  154. package/dist/state.d.ts +16 -28
  155. package/dist/state.d.ts.map +1 -1
  156. package/dist/state.js +73 -127
  157. package/dist/state.js.map +1 -1
  158. package/dist/table-config.d.ts +9 -0
  159. package/dist/table-config.d.ts.map +1 -0
  160. package/dist/table-config.js +2 -0
  161. package/dist/table-config.js.map +1 -0
  162. package/dist/types.d.ts +49 -114
  163. package/dist/types.d.ts.map +1 -1
  164. package/package.json +31 -2
@@ -1 +1 @@
1
- {"version":3,"file":"plugin.js","sourceRoot":"","sources":["../src/plugin.ts"],"names":[],"mappings":"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"}
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"}
@@ -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;
@@ -1 +1 @@
1
- {"version":3,"file":"runtime.d.ts","sourceRoot":"","sources":["../src/runtime.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,aAAa,CAAA;AAgBpD,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;AAkOD,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;CACrC,GAAG,OAAO,CAAC,wBAAwB,CAAC,CAmDpC;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;CACrC,GAAG,OAAO,CAAC,wBAAwB,CAAC,CAyCpC;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,CA+BjC;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"}
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
- if (!shouldSimulateFailure) {
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
- const errorMessage = `Simulated failure for chunk ${input.chunk.id} attempt ${input.chunk.attempts}`;
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: errorMessage,
147
+ message: attemptError,
131
148
  },
132
149
  });
133
- return { ok: false, error: errorMessage };
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
- input.run.status = 'running';
157
- input.run.replayDone = input.execution.replayDone ?? false;
158
- input.run.replayFailed = input.execution.replayFailed ?? false;
159
- await persistRunAndEvent({
160
- run: input.run,
161
- runPath: input.paths.runPath,
162
- eventPath: input.paths.eventPath,
163
- event: {
164
- type: 'run_started',
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
- simulation: input.execution.simulation,
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
- if (!executed.ok) {
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
- throw new BackfillConfigError(`Run already completed for plan ${plan.planId}. Use --replay-done to run completed chunks again.`);
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: input.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,