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.
- package/dist/commands/workflow/executors/phase-executor.js +3 -1
- package/dist/commands/workflow/phase-orchestrator.js +1 -2
- package/dist/phases/app-store-generation/index.js +1 -2
- package/dist/phases/branch-planning/index.js +1 -2
- package/dist/phases/bug-fixing/analyzer.js +1 -2
- package/dist/phases/code-implementation/index.js +1 -2
- package/dist/phases/code-refine/index.js +1 -2
- package/dist/phases/code-review/index.js +1 -2
- package/dist/phases/code-testing/analyzer.js +1 -2
- package/dist/phases/feature-analysis/index.js +1 -2
- package/dist/phases/functional-testing/analyzer.js +1 -2
- package/dist/phases/growth-analysis/index.js +1 -2
- package/dist/phases/pr-execution/index.js +1 -0
- package/dist/phases/pr-splitting/index.js +1 -2
- package/dist/phases/run-sheet/index.js +7 -7
- package/dist/phases/run-sheet/render.js +3 -1
- package/dist/phases/smoke-test/agent.js +2 -4
- package/dist/phases/smoke-test/index.js +11 -6
- package/dist/phases/technical-design/index.js +1 -2
- package/dist/phases/test-cases-analysis/index.js +1 -2
- package/dist/phases/user-stories-analysis/index.js +1 -2
- package/package.json +3 -3
- package/tsconfig.build.json +4 -0
- package/tsconfig.json +3 -9
- package/dist/api/__tests__/app-store.test.d.ts +0 -7
- package/dist/api/__tests__/app-store.test.js +0 -60
- package/dist/api/__tests__/intelligence.test.d.ts +0 -11
- package/dist/api/__tests__/intelligence.test.js +0 -315
- package/dist/api/features/__tests__/feature-utils.test.d.ts +0 -4
- package/dist/api/features/__tests__/feature-utils.test.js +0 -370
- package/dist/api/features/__tests__/status-updater.test.d.ts +0 -4
- package/dist/api/features/__tests__/status-updater.test.js +0 -88
- package/dist/commands/build/__tests__/build.test.d.ts +0 -5
- package/dist/commands/build/__tests__/build.test.js +0 -206
- package/dist/commands/build/__tests__/detect-project.test.d.ts +0 -6
- package/dist/commands/build/__tests__/detect-project.test.js +0 -160
- package/dist/commands/build/__tests__/run-build.test.d.ts +0 -6
- package/dist/commands/build/__tests__/run-build.test.js +0 -433
- package/dist/commands/intelligence/__tests__/command.test.d.ts +0 -4
- package/dist/commands/intelligence/__tests__/command.test.js +0 -48
- package/dist/commands/workflow/core/__tests__/feature-filter.test.d.ts +0 -5
- package/dist/commands/workflow/core/__tests__/feature-filter.test.js +0 -316
- package/dist/commands/workflow/core/__tests__/pipeline-evaluator.test.d.ts +0 -4
- package/dist/commands/workflow/core/__tests__/pipeline-evaluator.test.js +0 -397
- package/dist/commands/workflow/core/__tests__/state-manager.test.d.ts +0 -4
- package/dist/commands/workflow/core/__tests__/state-manager.test.js +0 -384
- package/dist/config/__tests__/config.test.d.ts +0 -4
- package/dist/config/__tests__/config.test.js +0 -286
- package/dist/config/__tests__/feature-status.test.d.ts +0 -4
- package/dist/config/__tests__/feature-status.test.js +0 -111
- package/dist/errors/__tests__/index.test.d.ts +0 -4
- package/dist/errors/__tests__/index.test.js +0 -349
- package/dist/phases/app-store-generation/__tests__/agent.test.d.ts +0 -5
- package/dist/phases/app-store-generation/__tests__/agent.test.js +0 -142
- package/dist/phases/app-store-generation/__tests__/context.test.d.ts +0 -4
- package/dist/phases/app-store-generation/__tests__/context.test.js +0 -284
- package/dist/phases/app-store-generation/__tests__/prompts.test.d.ts +0 -4
- package/dist/phases/app-store-generation/__tests__/prompts.test.js +0 -122
- package/dist/phases/app-store-generation/__tests__/screenshot-composer.test.d.ts +0 -5
- package/dist/phases/app-store-generation/__tests__/screenshot-composer.test.js +0 -826
- package/dist/phases/code-review/__tests__/diff-utils.test.d.ts +0 -1
- package/dist/phases/code-review/__tests__/diff-utils.test.js +0 -101
- package/dist/phases/intelligence-analysis/__tests__/context.test.d.ts +0 -4
- package/dist/phases/intelligence-analysis/__tests__/context.test.js +0 -192
- package/dist/phases/intelligence-analysis/__tests__/matching.test.d.ts +0 -13
- package/dist/phases/intelligence-analysis/__tests__/matching.test.js +0 -154
- package/dist/phases/intelligence-analysis/__tests__/orchestration.test.d.ts +0 -5
- package/dist/phases/intelligence-analysis/__tests__/orchestration.test.js +0 -378
- package/dist/phases/intelligence-analysis/__tests__/prompts.test.d.ts +0 -4
- package/dist/phases/intelligence-analysis/__tests__/prompts.test.js +0 -33
- package/dist/phases/pr-execution/__tests__/file-assigner.test.d.ts +0 -1
- package/dist/phases/pr-execution/__tests__/file-assigner.test.js +0 -303
- package/dist/phases/pr-resolve/__tests__/checklist-learner.test.d.ts +0 -1
- package/dist/phases/pr-resolve/__tests__/checklist-learner.test.js +0 -157
- package/dist/phases/pr-resolve/__tests__/prompts.test.d.ts +0 -1
- package/dist/phases/pr-resolve/__tests__/prompts.test.js +0 -116
- package/dist/phases/pr-resolve/__tests__/resolve-mapping.test.d.ts +0 -1
- package/dist/phases/pr-resolve/__tests__/resolve-mapping.test.js +0 -138
- package/dist/phases/pr-resolve/__tests__/types.test.d.ts +0 -1
- package/dist/phases/pr-resolve/__tests__/types.test.js +0 -43
- package/dist/phases/pr-resolve/__tests__/workspace.test.d.ts +0 -1
- package/dist/phases/pr-resolve/__tests__/workspace.test.js +0 -111
- package/dist/phases/pr-review/__tests__/prompts.test.d.ts +0 -1
- package/dist/phases/pr-review/__tests__/prompts.test.js +0 -49
- package/dist/phases/pr-review/__tests__/review-comments.test.d.ts +0 -1
- package/dist/phases/pr-review/__tests__/review-comments.test.js +0 -110
- package/dist/phases/pr-shared/__tests__/agent-utils.test.d.ts +0 -1
- package/dist/phases/pr-shared/__tests__/agent-utils.test.js +0 -91
- package/dist/phases/pr-shared/__tests__/context.test.d.ts +0 -1
- package/dist/phases/pr-shared/__tests__/context.test.js +0 -94
- package/dist/phases/pr-splitting/__tests__/import-dep-validator.test.d.ts +0 -1
- package/dist/phases/pr-splitting/__tests__/import-dep-validator.test.js +0 -331
- package/dist/phases/release-sync/__tests__/github.test.d.ts +0 -9
- package/dist/phases/release-sync/__tests__/github.test.js +0 -123
- package/dist/phases/release-sync/__tests__/snapshot.test.d.ts +0 -8
- package/dist/phases/release-sync/__tests__/snapshot.test.js +0 -93
- package/dist/phases/smoke-test/__tests__/agent.test.d.ts +0 -4
- package/dist/phases/smoke-test/__tests__/agent.test.js +0 -85
- package/dist/services/coaching/__tests__/coaching-agent.test.d.ts +0 -1
- package/dist/services/coaching/__tests__/coaching-agent.test.js +0 -74
- package/dist/services/coaching/__tests__/coaching-loop.test.d.ts +0 -1
- package/dist/services/coaching/__tests__/coaching-loop.test.js +0 -59
- package/dist/services/coaching/__tests__/self-rating.test.d.ts +0 -1
- package/dist/services/coaching/__tests__/self-rating.test.js +0 -188
- package/dist/services/phase-hooks/__tests__/bindings-fetcher.test.d.ts +0 -1
- package/dist/services/phase-hooks/__tests__/bindings-fetcher.test.js +0 -122
- package/dist/services/phase-hooks/__tests__/hook-executor.test.d.ts +0 -1
- package/dist/services/phase-hooks/__tests__/hook-executor.test.js +0 -321
- package/dist/services/phase-hooks/__tests__/hook-runner.test.d.ts +0 -1
- package/dist/services/phase-hooks/__tests__/hook-runner.test.js +0 -261
- package/dist/services/phase-hooks/__tests__/plugin-loader.test.d.ts +0 -1
- package/dist/services/phase-hooks/__tests__/plugin-loader.test.js +0 -158
- package/dist/services/video/__tests__/video-pipeline.test.d.ts +0 -6
- package/dist/services/video/__tests__/video-pipeline.test.js +0 -249
- package/dist/workspace/__tests__/workspace-manager.test.d.ts +0 -7
- 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
|
-
});
|