edsger 0.45.0 → 0.45.1

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 (95) hide show
  1. package/package.json +3 -3
  2. package/tsconfig.build.json +4 -0
  3. package/tsconfig.json +3 -9
  4. package/dist/api/__tests__/app-store.test.d.ts +0 -7
  5. package/dist/api/__tests__/app-store.test.js +0 -60
  6. package/dist/api/__tests__/intelligence.test.d.ts +0 -11
  7. package/dist/api/__tests__/intelligence.test.js +0 -315
  8. package/dist/api/features/__tests__/feature-utils.test.d.ts +0 -4
  9. package/dist/api/features/__tests__/feature-utils.test.js +0 -370
  10. package/dist/api/features/__tests__/status-updater.test.d.ts +0 -4
  11. package/dist/api/features/__tests__/status-updater.test.js +0 -88
  12. package/dist/commands/build/__tests__/build.test.d.ts +0 -5
  13. package/dist/commands/build/__tests__/build.test.js +0 -206
  14. package/dist/commands/build/__tests__/detect-project.test.d.ts +0 -6
  15. package/dist/commands/build/__tests__/detect-project.test.js +0 -160
  16. package/dist/commands/build/__tests__/run-build.test.d.ts +0 -6
  17. package/dist/commands/build/__tests__/run-build.test.js +0 -433
  18. package/dist/commands/intelligence/__tests__/command.test.d.ts +0 -4
  19. package/dist/commands/intelligence/__tests__/command.test.js +0 -48
  20. package/dist/commands/workflow/core/__tests__/feature-filter.test.d.ts +0 -5
  21. package/dist/commands/workflow/core/__tests__/feature-filter.test.js +0 -316
  22. package/dist/commands/workflow/core/__tests__/pipeline-evaluator.test.d.ts +0 -4
  23. package/dist/commands/workflow/core/__tests__/pipeline-evaluator.test.js +0 -397
  24. package/dist/commands/workflow/core/__tests__/state-manager.test.d.ts +0 -4
  25. package/dist/commands/workflow/core/__tests__/state-manager.test.js +0 -384
  26. package/dist/config/__tests__/config.test.d.ts +0 -4
  27. package/dist/config/__tests__/config.test.js +0 -286
  28. package/dist/config/__tests__/feature-status.test.d.ts +0 -4
  29. package/dist/config/__tests__/feature-status.test.js +0 -111
  30. package/dist/errors/__tests__/index.test.d.ts +0 -4
  31. package/dist/errors/__tests__/index.test.js +0 -349
  32. package/dist/phases/app-store-generation/__tests__/agent.test.d.ts +0 -5
  33. package/dist/phases/app-store-generation/__tests__/agent.test.js +0 -142
  34. package/dist/phases/app-store-generation/__tests__/context.test.d.ts +0 -4
  35. package/dist/phases/app-store-generation/__tests__/context.test.js +0 -284
  36. package/dist/phases/app-store-generation/__tests__/prompts.test.d.ts +0 -4
  37. package/dist/phases/app-store-generation/__tests__/prompts.test.js +0 -122
  38. package/dist/phases/app-store-generation/__tests__/screenshot-composer.test.d.ts +0 -5
  39. package/dist/phases/app-store-generation/__tests__/screenshot-composer.test.js +0 -826
  40. package/dist/phases/code-review/__tests__/diff-utils.test.d.ts +0 -1
  41. package/dist/phases/code-review/__tests__/diff-utils.test.js +0 -101
  42. package/dist/phases/intelligence-analysis/__tests__/context.test.d.ts +0 -4
  43. package/dist/phases/intelligence-analysis/__tests__/context.test.js +0 -192
  44. package/dist/phases/intelligence-analysis/__tests__/matching.test.d.ts +0 -13
  45. package/dist/phases/intelligence-analysis/__tests__/matching.test.js +0 -154
  46. package/dist/phases/intelligence-analysis/__tests__/orchestration.test.d.ts +0 -5
  47. package/dist/phases/intelligence-analysis/__tests__/orchestration.test.js +0 -378
  48. package/dist/phases/intelligence-analysis/__tests__/prompts.test.d.ts +0 -4
  49. package/dist/phases/intelligence-analysis/__tests__/prompts.test.js +0 -33
  50. package/dist/phases/pr-execution/__tests__/file-assigner.test.d.ts +0 -1
  51. package/dist/phases/pr-execution/__tests__/file-assigner.test.js +0 -303
  52. package/dist/phases/pr-resolve/__tests__/checklist-learner.test.d.ts +0 -1
  53. package/dist/phases/pr-resolve/__tests__/checklist-learner.test.js +0 -157
  54. package/dist/phases/pr-resolve/__tests__/prompts.test.d.ts +0 -1
  55. package/dist/phases/pr-resolve/__tests__/prompts.test.js +0 -116
  56. package/dist/phases/pr-resolve/__tests__/resolve-mapping.test.d.ts +0 -1
  57. package/dist/phases/pr-resolve/__tests__/resolve-mapping.test.js +0 -138
  58. package/dist/phases/pr-resolve/__tests__/types.test.d.ts +0 -1
  59. package/dist/phases/pr-resolve/__tests__/types.test.js +0 -43
  60. package/dist/phases/pr-resolve/__tests__/workspace.test.d.ts +0 -1
  61. package/dist/phases/pr-resolve/__tests__/workspace.test.js +0 -111
  62. package/dist/phases/pr-review/__tests__/prompts.test.d.ts +0 -1
  63. package/dist/phases/pr-review/__tests__/prompts.test.js +0 -49
  64. package/dist/phases/pr-review/__tests__/review-comments.test.d.ts +0 -1
  65. package/dist/phases/pr-review/__tests__/review-comments.test.js +0 -110
  66. package/dist/phases/pr-shared/__tests__/agent-utils.test.d.ts +0 -1
  67. package/dist/phases/pr-shared/__tests__/agent-utils.test.js +0 -91
  68. package/dist/phases/pr-shared/__tests__/context.test.d.ts +0 -1
  69. package/dist/phases/pr-shared/__tests__/context.test.js +0 -94
  70. package/dist/phases/pr-splitting/__tests__/import-dep-validator.test.d.ts +0 -1
  71. package/dist/phases/pr-splitting/__tests__/import-dep-validator.test.js +0 -331
  72. package/dist/phases/release-sync/__tests__/github.test.d.ts +0 -9
  73. package/dist/phases/release-sync/__tests__/github.test.js +0 -123
  74. package/dist/phases/release-sync/__tests__/snapshot.test.d.ts +0 -8
  75. package/dist/phases/release-sync/__tests__/snapshot.test.js +0 -93
  76. package/dist/phases/smoke-test/__tests__/agent.test.d.ts +0 -4
  77. package/dist/phases/smoke-test/__tests__/agent.test.js +0 -85
  78. package/dist/services/coaching/__tests__/coaching-agent.test.d.ts +0 -1
  79. package/dist/services/coaching/__tests__/coaching-agent.test.js +0 -74
  80. package/dist/services/coaching/__tests__/coaching-loop.test.d.ts +0 -1
  81. package/dist/services/coaching/__tests__/coaching-loop.test.js +0 -59
  82. package/dist/services/coaching/__tests__/self-rating.test.d.ts +0 -1
  83. package/dist/services/coaching/__tests__/self-rating.test.js +0 -188
  84. package/dist/services/phase-hooks/__tests__/bindings-fetcher.test.d.ts +0 -1
  85. package/dist/services/phase-hooks/__tests__/bindings-fetcher.test.js +0 -122
  86. package/dist/services/phase-hooks/__tests__/hook-executor.test.d.ts +0 -1
  87. package/dist/services/phase-hooks/__tests__/hook-executor.test.js +0 -321
  88. package/dist/services/phase-hooks/__tests__/hook-runner.test.d.ts +0 -1
  89. package/dist/services/phase-hooks/__tests__/hook-runner.test.js +0 -261
  90. package/dist/services/phase-hooks/__tests__/plugin-loader.test.d.ts +0 -1
  91. package/dist/services/phase-hooks/__tests__/plugin-loader.test.js +0 -158
  92. package/dist/services/video/__tests__/video-pipeline.test.d.ts +0 -6
  93. package/dist/services/video/__tests__/video-pipeline.test.js +0 -249
  94. package/dist/workspace/__tests__/workspace-manager.test.d.ts +0 -7
  95. 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 {};