edsger 0.45.0 → 0.46.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.
Files changed (116) hide show
  1. package/dist/commands/workflow/executors/phase-executor.js +3 -1
  2. package/dist/commands/workflow/phase-orchestrator.js +1 -2
  3. package/dist/phases/app-store-generation/index.js +1 -2
  4. package/dist/phases/branch-planning/index.js +1 -2
  5. package/dist/phases/bug-fixing/analyzer.js +1 -2
  6. package/dist/phases/code-implementation/index.js +1 -2
  7. package/dist/phases/code-refine/index.js +1 -2
  8. package/dist/phases/code-review/index.js +1 -2
  9. package/dist/phases/code-testing/analyzer.js +1 -2
  10. package/dist/phases/feature-analysis/index.js +1 -2
  11. package/dist/phases/functional-testing/analyzer.js +1 -2
  12. package/dist/phases/growth-analysis/index.js +1 -2
  13. package/dist/phases/pr-execution/index.js +1 -0
  14. package/dist/phases/pr-splitting/index.js +1 -2
  15. package/dist/phases/run-sheet/index.js +7 -7
  16. package/dist/phases/run-sheet/render.js +3 -1
  17. package/dist/phases/smoke-test/agent.js +2 -4
  18. package/dist/phases/smoke-test/index.js +11 -6
  19. package/dist/phases/technical-design/index.js +1 -2
  20. package/dist/phases/test-cases-analysis/index.js +1 -2
  21. package/dist/phases/user-stories-analysis/index.js +1 -2
  22. package/package.json +3 -3
  23. package/tsconfig.build.json +4 -0
  24. package/tsconfig.json +3 -9
  25. package/dist/api/__tests__/app-store.test.d.ts +0 -7
  26. package/dist/api/__tests__/app-store.test.js +0 -60
  27. package/dist/api/__tests__/intelligence.test.d.ts +0 -11
  28. package/dist/api/__tests__/intelligence.test.js +0 -315
  29. package/dist/api/features/__tests__/feature-utils.test.d.ts +0 -4
  30. package/dist/api/features/__tests__/feature-utils.test.js +0 -370
  31. package/dist/api/features/__tests__/status-updater.test.d.ts +0 -4
  32. package/dist/api/features/__tests__/status-updater.test.js +0 -88
  33. package/dist/commands/build/__tests__/build.test.d.ts +0 -5
  34. package/dist/commands/build/__tests__/build.test.js +0 -206
  35. package/dist/commands/build/__tests__/detect-project.test.d.ts +0 -6
  36. package/dist/commands/build/__tests__/detect-project.test.js +0 -160
  37. package/dist/commands/build/__tests__/run-build.test.d.ts +0 -6
  38. package/dist/commands/build/__tests__/run-build.test.js +0 -433
  39. package/dist/commands/intelligence/__tests__/command.test.d.ts +0 -4
  40. package/dist/commands/intelligence/__tests__/command.test.js +0 -48
  41. package/dist/commands/workflow/core/__tests__/feature-filter.test.d.ts +0 -5
  42. package/dist/commands/workflow/core/__tests__/feature-filter.test.js +0 -316
  43. package/dist/commands/workflow/core/__tests__/pipeline-evaluator.test.d.ts +0 -4
  44. package/dist/commands/workflow/core/__tests__/pipeline-evaluator.test.js +0 -397
  45. package/dist/commands/workflow/core/__tests__/state-manager.test.d.ts +0 -4
  46. package/dist/commands/workflow/core/__tests__/state-manager.test.js +0 -384
  47. package/dist/config/__tests__/config.test.d.ts +0 -4
  48. package/dist/config/__tests__/config.test.js +0 -286
  49. package/dist/config/__tests__/feature-status.test.d.ts +0 -4
  50. package/dist/config/__tests__/feature-status.test.js +0 -111
  51. package/dist/errors/__tests__/index.test.d.ts +0 -4
  52. package/dist/errors/__tests__/index.test.js +0 -349
  53. package/dist/phases/app-store-generation/__tests__/agent.test.d.ts +0 -5
  54. package/dist/phases/app-store-generation/__tests__/agent.test.js +0 -142
  55. package/dist/phases/app-store-generation/__tests__/context.test.d.ts +0 -4
  56. package/dist/phases/app-store-generation/__tests__/context.test.js +0 -284
  57. package/dist/phases/app-store-generation/__tests__/prompts.test.d.ts +0 -4
  58. package/dist/phases/app-store-generation/__tests__/prompts.test.js +0 -122
  59. package/dist/phases/app-store-generation/__tests__/screenshot-composer.test.d.ts +0 -5
  60. package/dist/phases/app-store-generation/__tests__/screenshot-composer.test.js +0 -826
  61. package/dist/phases/code-review/__tests__/diff-utils.test.d.ts +0 -1
  62. package/dist/phases/code-review/__tests__/diff-utils.test.js +0 -101
  63. package/dist/phases/intelligence-analysis/__tests__/context.test.d.ts +0 -4
  64. package/dist/phases/intelligence-analysis/__tests__/context.test.js +0 -192
  65. package/dist/phases/intelligence-analysis/__tests__/matching.test.d.ts +0 -13
  66. package/dist/phases/intelligence-analysis/__tests__/matching.test.js +0 -154
  67. package/dist/phases/intelligence-analysis/__tests__/orchestration.test.d.ts +0 -5
  68. package/dist/phases/intelligence-analysis/__tests__/orchestration.test.js +0 -378
  69. package/dist/phases/intelligence-analysis/__tests__/prompts.test.d.ts +0 -4
  70. package/dist/phases/intelligence-analysis/__tests__/prompts.test.js +0 -33
  71. package/dist/phases/pr-execution/__tests__/file-assigner.test.d.ts +0 -1
  72. package/dist/phases/pr-execution/__tests__/file-assigner.test.js +0 -303
  73. package/dist/phases/pr-resolve/__tests__/checklist-learner.test.d.ts +0 -1
  74. package/dist/phases/pr-resolve/__tests__/checklist-learner.test.js +0 -157
  75. package/dist/phases/pr-resolve/__tests__/prompts.test.d.ts +0 -1
  76. package/dist/phases/pr-resolve/__tests__/prompts.test.js +0 -116
  77. package/dist/phases/pr-resolve/__tests__/resolve-mapping.test.d.ts +0 -1
  78. package/dist/phases/pr-resolve/__tests__/resolve-mapping.test.js +0 -138
  79. package/dist/phases/pr-resolve/__tests__/types.test.d.ts +0 -1
  80. package/dist/phases/pr-resolve/__tests__/types.test.js +0 -43
  81. package/dist/phases/pr-resolve/__tests__/workspace.test.d.ts +0 -1
  82. package/dist/phases/pr-resolve/__tests__/workspace.test.js +0 -111
  83. package/dist/phases/pr-review/__tests__/prompts.test.d.ts +0 -1
  84. package/dist/phases/pr-review/__tests__/prompts.test.js +0 -49
  85. package/dist/phases/pr-review/__tests__/review-comments.test.d.ts +0 -1
  86. package/dist/phases/pr-review/__tests__/review-comments.test.js +0 -110
  87. package/dist/phases/pr-shared/__tests__/agent-utils.test.d.ts +0 -1
  88. package/dist/phases/pr-shared/__tests__/agent-utils.test.js +0 -91
  89. package/dist/phases/pr-shared/__tests__/context.test.d.ts +0 -1
  90. package/dist/phases/pr-shared/__tests__/context.test.js +0 -94
  91. package/dist/phases/pr-splitting/__tests__/import-dep-validator.test.d.ts +0 -1
  92. package/dist/phases/pr-splitting/__tests__/import-dep-validator.test.js +0 -331
  93. package/dist/phases/release-sync/__tests__/github.test.d.ts +0 -9
  94. package/dist/phases/release-sync/__tests__/github.test.js +0 -123
  95. package/dist/phases/release-sync/__tests__/snapshot.test.d.ts +0 -8
  96. package/dist/phases/release-sync/__tests__/snapshot.test.js +0 -93
  97. package/dist/phases/smoke-test/__tests__/agent.test.d.ts +0 -4
  98. package/dist/phases/smoke-test/__tests__/agent.test.js +0 -85
  99. package/dist/services/coaching/__tests__/coaching-agent.test.d.ts +0 -1
  100. package/dist/services/coaching/__tests__/coaching-agent.test.js +0 -74
  101. package/dist/services/coaching/__tests__/coaching-loop.test.d.ts +0 -1
  102. package/dist/services/coaching/__tests__/coaching-loop.test.js +0 -59
  103. package/dist/services/coaching/__tests__/self-rating.test.d.ts +0 -1
  104. package/dist/services/coaching/__tests__/self-rating.test.js +0 -188
  105. package/dist/services/phase-hooks/__tests__/bindings-fetcher.test.d.ts +0 -1
  106. package/dist/services/phase-hooks/__tests__/bindings-fetcher.test.js +0 -122
  107. package/dist/services/phase-hooks/__tests__/hook-executor.test.d.ts +0 -1
  108. package/dist/services/phase-hooks/__tests__/hook-executor.test.js +0 -321
  109. package/dist/services/phase-hooks/__tests__/hook-runner.test.d.ts +0 -1
  110. package/dist/services/phase-hooks/__tests__/hook-runner.test.js +0 -261
  111. package/dist/services/phase-hooks/__tests__/plugin-loader.test.d.ts +0 -1
  112. package/dist/services/phase-hooks/__tests__/plugin-loader.test.js +0 -158
  113. package/dist/services/video/__tests__/video-pipeline.test.d.ts +0 -6
  114. package/dist/services/video/__tests__/video-pipeline.test.js +0 -249
  115. package/dist/workspace/__tests__/workspace-manager.test.d.ts +0 -7
  116. package/dist/workspace/__tests__/workspace-manager.test.js +0 -52
@@ -1,397 +0,0 @@
1
- /**
2
- * Unit tests for pipeline result evaluation utilities
3
- */
4
- import assert from 'node:assert';
5
- import { describe, it } from 'node:test';
6
- import { calculatePipelineStats, countFailedPhases, countSuccessfulPhases, evaluatePipelineResults, getFailedPhases, getFirstFailure, getLastPhaseResult, getSuccessfulPhases, hasAnyPipelineFailures, isPipelineCompleteFailure, isPipelineEmpty, isPipelineFullySuccessful, isPipelinePartiallySuccessful, } from '../pipeline-evaluator.js';
7
- // Helper factory for creating test results
8
- const makeResult = (overrides) => ({
9
- featureId: 'feat-1',
10
- status: 'success',
11
- message: `Phase ${overrides.phase} completed`,
12
- ...overrides,
13
- });
14
- const successResult = (phase) => makeResult({ phase, status: 'success', message: `${phase} succeeded` });
15
- const errorResult = (phase) => makeResult({ phase, status: 'error', message: `${phase} failed` });
16
- const blockedResult = (phase) => makeResult({ phase, status: 'blocked', message: `${phase} blocked` });
17
- void describe('Pipeline Evaluator', () => {
18
- void describe('evaluatePipelineResults', () => {
19
- void it('should return true for empty results', () => {
20
- assert.strictEqual(evaluatePipelineResults([]), true, 'Empty array should vacuously satisfy every()');
21
- });
22
- void it('should return true when all results are successful', () => {
23
- const results = [
24
- successResult('analysis'),
25
- successResult('design'),
26
- successResult('implementation'),
27
- ];
28
- assert.strictEqual(evaluatePipelineResults(results), true);
29
- });
30
- void it('should return false when any result is an error', () => {
31
- const results = [
32
- successResult('analysis'),
33
- errorResult('design'),
34
- successResult('implementation'),
35
- ];
36
- assert.strictEqual(evaluatePipelineResults(results), false);
37
- });
38
- void it('should return false when any result is blocked', () => {
39
- const results = [successResult('analysis'), blockedResult('design')];
40
- assert.strictEqual(evaluatePipelineResults(results), false, 'Blocked status should cause evaluation to fail');
41
- });
42
- void it('should return false when all results are errors', () => {
43
- const results = [errorResult('analysis'), errorResult('design')];
44
- assert.strictEqual(evaluatePipelineResults(results), false);
45
- });
46
- });
47
- void describe('hasAnyPipelineFailures', () => {
48
- void it('should return false for empty results', () => {
49
- assert.strictEqual(hasAnyPipelineFailures([]), false);
50
- });
51
- void it('should return false when all results are successful', () => {
52
- const results = [successResult('analysis'), successResult('design')];
53
- assert.strictEqual(hasAnyPipelineFailures(results), false);
54
- });
55
- void it('should return true when at least one result is an error', () => {
56
- const results = [successResult('analysis'), errorResult('design')];
57
- assert.strictEqual(hasAnyPipelineFailures(results), true);
58
- });
59
- void it('should return true when at least one result is blocked', () => {
60
- const results = [successResult('analysis'), blockedResult('design')];
61
- assert.strictEqual(hasAnyPipelineFailures(results), true);
62
- });
63
- });
64
- void describe('countSuccessfulPhases', () => {
65
- void it('should return 0 for empty results', () => {
66
- assert.strictEqual(countSuccessfulPhases([]), 0);
67
- });
68
- void it('should count only successful phases', () => {
69
- const results = [
70
- successResult('analysis'),
71
- errorResult('design'),
72
- successResult('implementation'),
73
- blockedResult('testing'),
74
- ];
75
- assert.strictEqual(countSuccessfulPhases(results), 2);
76
- });
77
- void it('should return total count when all are successful', () => {
78
- const results = [
79
- successResult('analysis'),
80
- successResult('design'),
81
- successResult('implementation'),
82
- ];
83
- assert.strictEqual(countSuccessfulPhases(results), 3);
84
- });
85
- });
86
- void describe('countFailedPhases', () => {
87
- void it('should return 0 for empty results', () => {
88
- assert.strictEqual(countFailedPhases([]), 0);
89
- });
90
- void it('should count error and blocked phases as failed', () => {
91
- const results = [
92
- successResult('analysis'),
93
- errorResult('design'),
94
- blockedResult('implementation'),
95
- successResult('testing'),
96
- ];
97
- assert.strictEqual(countFailedPhases(results), 2, 'Both error and blocked should count as failed');
98
- });
99
- void it('should return 0 when all are successful', () => {
100
- const results = [successResult('analysis'), successResult('design')];
101
- assert.strictEqual(countFailedPhases(results), 0);
102
- });
103
- });
104
- void describe('getFailedPhases', () => {
105
- void it('should return empty array for empty results', () => {
106
- assert.deepStrictEqual(getFailedPhases([]), []);
107
- });
108
- void it('should return only non-success phases', () => {
109
- const results = [
110
- successResult('analysis'),
111
- errorResult('design'),
112
- blockedResult('implementation'),
113
- successResult('testing'),
114
- ];
115
- const failed = getFailedPhases(results);
116
- assert.strictEqual(failed.length, 2);
117
- assert.strictEqual(failed[0].phase, 'design');
118
- assert.strictEqual(failed[0].status, 'error');
119
- assert.strictEqual(failed[1].phase, 'implementation');
120
- assert.strictEqual(failed[1].status, 'blocked');
121
- });
122
- void it('should return empty array when all are successful', () => {
123
- const results = [successResult('analysis'), successResult('design')];
124
- assert.deepStrictEqual(getFailedPhases(results), []);
125
- });
126
- });
127
- void describe('getSuccessfulPhases', () => {
128
- void it('should return empty array for empty results', () => {
129
- assert.deepStrictEqual(getSuccessfulPhases([]), []);
130
- });
131
- void it('should return only successful phases', () => {
132
- const results = [
133
- successResult('analysis'),
134
- errorResult('design'),
135
- successResult('implementation'),
136
- ];
137
- const successful = getSuccessfulPhases(results);
138
- assert.strictEqual(successful.length, 2);
139
- assert.strictEqual(successful[0].phase, 'analysis');
140
- assert.strictEqual(successful[1].phase, 'implementation');
141
- });
142
- });
143
- void describe('getFirstFailure', () => {
144
- void it('should return undefined for empty results', () => {
145
- assert.strictEqual(getFirstFailure([]), undefined);
146
- });
147
- void it('should return undefined when all are successful', () => {
148
- const results = [successResult('analysis'), successResult('design')];
149
- assert.strictEqual(getFirstFailure(results), undefined);
150
- });
151
- void it('should return the first error result', () => {
152
- const results = [
153
- successResult('analysis'),
154
- errorResult('design'),
155
- errorResult('implementation'),
156
- ];
157
- const first = getFirstFailure(results);
158
- assert.strictEqual(first?.phase, 'design', 'Should return the first failure');
159
- });
160
- void it('should return blocked result as a failure', () => {
161
- const results = [
162
- successResult('analysis'),
163
- blockedResult('design'),
164
- errorResult('implementation'),
165
- ];
166
- const first = getFirstFailure(results);
167
- assert.strictEqual(first?.phase, 'design', 'Blocked should be treated as a failure');
168
- assert.strictEqual(first?.status, 'blocked');
169
- });
170
- void it('should return the only result if it is a failure', () => {
171
- const results = [errorResult('analysis')];
172
- const first = getFirstFailure(results);
173
- assert.strictEqual(first?.phase, 'analysis');
174
- });
175
- });
176
- void describe('getLastPhaseResult', () => {
177
- void it('should return undefined for empty results', () => {
178
- assert.strictEqual(getLastPhaseResult([]), undefined);
179
- });
180
- void it('should return the last result regardless of status', () => {
181
- const results = [
182
- successResult('analysis'),
183
- errorResult('design'),
184
- successResult('implementation'),
185
- ];
186
- const last = getLastPhaseResult(results);
187
- assert.strictEqual(last?.phase, 'implementation');
188
- assert.strictEqual(last?.status, 'success');
189
- });
190
- void it('should return the single result for a single-element array', () => {
191
- const results = [errorResult('analysis')];
192
- const last = getLastPhaseResult(results);
193
- assert.strictEqual(last?.phase, 'analysis');
194
- assert.strictEqual(last?.status, 'error');
195
- });
196
- });
197
- void describe('isPipelineFullySuccessful', () => {
198
- void it('should return false for empty results', () => {
199
- assert.strictEqual(isPipelineFullySuccessful([]), false, 'Empty pipeline is not fully successful');
200
- });
201
- void it('should return true when all results are successful', () => {
202
- const results = [
203
- successResult('analysis'),
204
- successResult('design'),
205
- successResult('implementation'),
206
- ];
207
- assert.strictEqual(isPipelineFullySuccessful(results), true);
208
- });
209
- void it('should return false when any result failed', () => {
210
- const results = [
211
- successResult('analysis'),
212
- errorResult('design'),
213
- successResult('implementation'),
214
- ];
215
- assert.strictEqual(isPipelineFullySuccessful(results), false);
216
- });
217
- void it('should return true for a single successful result', () => {
218
- assert.strictEqual(isPipelineFullySuccessful([successResult('analysis')]), true);
219
- });
220
- });
221
- void describe('isPipelinePartiallySuccessful', () => {
222
- void it('should return false for empty results', () => {
223
- assert.strictEqual(isPipelinePartiallySuccessful([]), false);
224
- });
225
- void it('should return false when all results are successful', () => {
226
- const results = [successResult('analysis'), successResult('design')];
227
- assert.strictEqual(isPipelinePartiallySuccessful(results), false, 'Fully successful is not partially successful');
228
- });
229
- void it('should return false when all results failed', () => {
230
- const results = [errorResult('analysis'), errorResult('design')];
231
- assert.strictEqual(isPipelinePartiallySuccessful(results), false, 'Complete failure is not partially successful');
232
- });
233
- void it('should return true when some succeed and some fail', () => {
234
- const results = [
235
- successResult('analysis'),
236
- errorResult('design'),
237
- successResult('implementation'),
238
- ];
239
- assert.strictEqual(isPipelinePartiallySuccessful(results), true);
240
- });
241
- void it('should return true with a mix of success and blocked', () => {
242
- const results = [successResult('analysis'), blockedResult('design')];
243
- assert.strictEqual(isPipelinePartiallySuccessful(results), true);
244
- });
245
- });
246
- void describe('isPipelineCompleteFailure', () => {
247
- void it('should return false for empty results', () => {
248
- assert.strictEqual(isPipelineCompleteFailure([]), false);
249
- });
250
- void it('should return true when no results are successful', () => {
251
- const results = [
252
- errorResult('analysis'),
253
- blockedResult('design'),
254
- errorResult('implementation'),
255
- ];
256
- assert.strictEqual(isPipelineCompleteFailure(results), true);
257
- });
258
- void it('should return false when at least one result is successful', () => {
259
- const results = [
260
- successResult('analysis'),
261
- errorResult('design'),
262
- errorResult('implementation'),
263
- ];
264
- assert.strictEqual(isPipelineCompleteFailure(results), false);
265
- });
266
- void it('should return true for a single error result', () => {
267
- assert.strictEqual(isPipelineCompleteFailure([errorResult('analysis')]), true);
268
- });
269
- });
270
- void describe('isPipelineEmpty', () => {
271
- void it('should return true for empty results', () => {
272
- assert.strictEqual(isPipelineEmpty([]), true);
273
- });
274
- void it('should return false when results exist', () => {
275
- assert.strictEqual(isPipelineEmpty([successResult('analysis')]), false);
276
- });
277
- });
278
- void describe('calculatePipelineStats', () => {
279
- void it('should return zeros for empty results', () => {
280
- const stats = calculatePipelineStats([]);
281
- assert.deepStrictEqual(stats, {
282
- total: 0,
283
- successful: 0,
284
- failed: 0,
285
- successRate: 0,
286
- });
287
- });
288
- void it('should calculate stats for all successful results', () => {
289
- const results = [
290
- successResult('analysis'),
291
- successResult('design'),
292
- successResult('implementation'),
293
- ];
294
- const stats = calculatePipelineStats(results);
295
- assert.strictEqual(stats.total, 3);
296
- assert.strictEqual(stats.successful, 3);
297
- assert.strictEqual(stats.failed, 0);
298
- assert.strictEqual(stats.successRate, 1);
299
- });
300
- void it('should calculate stats for all failed results', () => {
301
- const results = [errorResult('analysis'), errorResult('design')];
302
- const stats = calculatePipelineStats(results);
303
- assert.strictEqual(stats.total, 2);
304
- assert.strictEqual(stats.successful, 0);
305
- assert.strictEqual(stats.failed, 2);
306
- assert.strictEqual(stats.successRate, 0);
307
- });
308
- void it('should calculate correct successRate for mixed results', () => {
309
- const results = [
310
- successResult('analysis'),
311
- errorResult('design'),
312
- successResult('implementation'),
313
- blockedResult('testing'),
314
- ];
315
- const stats = calculatePipelineStats(results);
316
- assert.strictEqual(stats.total, 4);
317
- assert.strictEqual(stats.successful, 2);
318
- assert.strictEqual(stats.failed, 2);
319
- assert.strictEqual(stats.successRate, 0.5);
320
- });
321
- void it('should treat blocked as failed in stats', () => {
322
- const results = [
323
- successResult('analysis'),
324
- blockedResult('design'),
325
- blockedResult('implementation'),
326
- ];
327
- const stats = calculatePipelineStats(results);
328
- assert.strictEqual(stats.successful, 1);
329
- assert.strictEqual(stats.failed, 2);
330
- assert.ok(Math.abs(stats.successRate - 1 / 3) < 0.0001, 'successRate should be approximately 1/3');
331
- });
332
- void it('should calculate successRate for a single successful result', () => {
333
- const stats = calculatePipelineStats([successResult('analysis')]);
334
- assert.strictEqual(stats.total, 1);
335
- assert.strictEqual(stats.successful, 1);
336
- assert.strictEqual(stats.failed, 0);
337
- assert.strictEqual(stats.successRate, 1);
338
- });
339
- void it('should have total equal to successful plus failed', () => {
340
- const results = [
341
- successResult('analysis'),
342
- errorResult('design'),
343
- successResult('implementation'),
344
- blockedResult('testing'),
345
- successResult('review'),
346
- ];
347
- const stats = calculatePipelineStats(results);
348
- assert.strictEqual(stats.total, stats.successful + stats.failed, 'total should equal successful + failed');
349
- });
350
- });
351
- void describe('Integration - pipeline status categories are mutually exclusive', () => {
352
- void it('should have exactly one category true for all-success pipeline', () => {
353
- const results = [successResult('analysis'), successResult('design')];
354
- const full = isPipelineFullySuccessful(results);
355
- const partial = isPipelinePartiallySuccessful(results);
356
- const complete = isPipelineCompleteFailure(results);
357
- const empty = isPipelineEmpty(results);
358
- assert.strictEqual(full, true);
359
- assert.strictEqual(partial, false);
360
- assert.strictEqual(complete, false);
361
- assert.strictEqual(empty, false);
362
- });
363
- void it('should have exactly one category true for mixed pipeline', () => {
364
- const results = [successResult('analysis'), errorResult('design')];
365
- const full = isPipelineFullySuccessful(results);
366
- const partial = isPipelinePartiallySuccessful(results);
367
- const complete = isPipelineCompleteFailure(results);
368
- const empty = isPipelineEmpty(results);
369
- assert.strictEqual(full, false);
370
- assert.strictEqual(partial, true);
371
- assert.strictEqual(complete, false);
372
- assert.strictEqual(empty, false);
373
- });
374
- void it('should have exactly one category true for all-failure pipeline', () => {
375
- const results = [errorResult('analysis'), errorResult('design')];
376
- const full = isPipelineFullySuccessful(results);
377
- const partial = isPipelinePartiallySuccessful(results);
378
- const complete = isPipelineCompleteFailure(results);
379
- const empty = isPipelineEmpty(results);
380
- assert.strictEqual(full, false);
381
- assert.strictEqual(partial, false);
382
- assert.strictEqual(complete, true);
383
- assert.strictEqual(empty, false);
384
- });
385
- void it('should have exactly one category true for empty pipeline', () => {
386
- const results = [];
387
- const full = isPipelineFullySuccessful(results);
388
- const partial = isPipelinePartiallySuccessful(results);
389
- const complete = isPipelineCompleteFailure(results);
390
- const empty = isPipelineEmpty(results);
391
- assert.strictEqual(full, false);
392
- assert.strictEqual(partial, false);
393
- assert.strictEqual(complete, false);
394
- assert.strictEqual(empty, true);
395
- });
396
- });
397
- });
@@ -1,4 +0,0 @@
1
- /**
2
- * Unit tests for workflow state management utilities
3
- */
4
- export {};