groundswell 0.0.2 → 1.0.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/LICENSE +21 -0
- package/README.md +26 -9
- package/dist/cache/cache-key.d.ts +86 -0
- package/dist/cache/cache-key.d.ts.map +1 -0
- package/dist/cache/cache-key.js +204 -0
- package/dist/cache/cache-key.js.map +1 -0
- package/dist/cache/cache.d.ts +104 -0
- package/dist/cache/cache.d.ts.map +1 -0
- package/dist/cache/cache.js +179 -0
- package/dist/cache/cache.js.map +1 -0
- package/{src/cache/index.ts → dist/cache/index.d.ts} +1 -1
- package/dist/cache/index.d.ts.map +1 -0
- package/dist/cache/index.js +6 -0
- package/dist/cache/index.js.map +1 -0
- package/dist/core/agent.d.ts +203 -0
- package/dist/core/agent.d.ts.map +1 -0
- package/dist/core/agent.js +833 -0
- package/dist/core/agent.js.map +1 -0
- package/{src/core/context.ts → dist/core/context.d.ts} +16 -67
- package/dist/core/context.d.ts.map +1 -0
- package/dist/core/context.js +80 -0
- package/dist/core/context.js.map +1 -0
- package/dist/core/event-tree.d.ts +72 -0
- package/dist/core/event-tree.d.ts.map +1 -0
- package/dist/core/event-tree.js +211 -0
- package/dist/core/event-tree.js.map +1 -0
- package/{src/core/factory.ts → dist/core/factory.d.ts} +6 -27
- package/dist/core/factory.d.ts.map +1 -0
- package/dist/core/factory.js +110 -0
- package/dist/core/factory.js.map +1 -0
- package/{src/core/index.ts → dist/core/index.d.ts} +2 -10
- package/dist/core/index.d.ts.map +1 -0
- package/dist/core/index.js +9 -0
- package/dist/core/index.js.map +1 -0
- package/dist/core/logger.d.ts +50 -0
- package/dist/core/logger.d.ts.map +1 -0
- package/dist/core/logger.js +91 -0
- package/dist/core/logger.js.map +1 -0
- package/dist/core/mcp-handler.d.ts +127 -0
- package/dist/core/mcp-handler.d.ts.map +1 -0
- package/dist/core/mcp-handler.js +323 -0
- package/dist/core/mcp-handler.js.map +1 -0
- package/dist/core/prompt.d.ts +80 -0
- package/dist/core/prompt.d.ts.map +1 -0
- package/dist/core/prompt.js +120 -0
- package/dist/core/prompt.js.map +1 -0
- package/dist/core/workflow-context.d.ts +61 -0
- package/dist/core/workflow-context.d.ts.map +1 -0
- package/dist/core/workflow-context.js +358 -0
- package/dist/core/workflow-context.js.map +1 -0
- package/dist/core/workflow.d.ts +543 -0
- package/dist/core/workflow.d.ts.map +1 -0
- package/dist/core/workflow.js +986 -0
- package/dist/core/workflow.js.map +1 -0
- package/dist/debugger/event-replayer.d.ts +422 -0
- package/dist/debugger/event-replayer.d.ts.map +1 -0
- package/dist/debugger/event-replayer.js +639 -0
- package/dist/debugger/event-replayer.js.map +1 -0
- package/dist/debugger/index.d.ts +2 -0
- package/dist/debugger/index.d.ts.map +1 -0
- package/{src/debugger/index.ts → dist/debugger/index.js} +1 -0
- package/dist/debugger/index.js.map +1 -0
- package/dist/debugger/tree-debugger.d.ts +240 -0
- package/dist/debugger/tree-debugger.d.ts.map +1 -0
- package/dist/debugger/tree-debugger.js +620 -0
- package/dist/debugger/tree-debugger.js.map +1 -0
- package/dist/decorators/index.d.ts +4 -0
- package/dist/decorators/index.d.ts.map +1 -0
- package/{src/decorators/index.ts → dist/decorators/index.js} +1 -0
- package/dist/decorators/index.js.map +1 -0
- package/dist/decorators/observed-state.d.ts +32 -0
- package/dist/decorators/observed-state.d.ts.map +1 -0
- package/dist/decorators/observed-state.js +79 -0
- package/dist/decorators/observed-state.js.map +1 -0
- package/dist/decorators/step.d.ts +15 -0
- package/dist/decorators/step.d.ts.map +1 -0
- package/dist/decorators/step.js +192 -0
- package/dist/decorators/step.js.map +1 -0
- package/dist/decorators/task.d.ts +50 -0
- package/dist/decorators/task.d.ts.map +1 -0
- package/dist/decorators/task.js +118 -0
- package/dist/decorators/task.js.map +1 -0
- package/dist/examples/index.d.ts +3 -0
- package/dist/examples/index.d.ts.map +1 -0
- package/{src/examples/index.ts → dist/examples/index.js} +1 -0
- package/dist/examples/index.js.map +1 -0
- package/dist/examples/tdd-orchestrator.d.ts +15 -0
- package/dist/examples/tdd-orchestrator.d.ts.map +1 -0
- package/dist/examples/tdd-orchestrator.js +121 -0
- package/dist/examples/tdd-orchestrator.js.map +1 -0
- package/dist/examples/test-cycle-workflow.d.ts +14 -0
- package/dist/examples/test-cycle-workflow.d.ts.map +1 -0
- package/dist/examples/test-cycle-workflow.js +116 -0
- package/dist/examples/test-cycle-workflow.js.map +1 -0
- package/dist/harnesses/claude-code-harness.d.ts +391 -0
- package/dist/harnesses/claude-code-harness.d.ts.map +1 -0
- package/dist/harnesses/claude-code-harness.js +1076 -0
- package/dist/harnesses/claude-code-harness.js.map +1 -0
- package/dist/harnesses/harness-registry.d.ts +440 -0
- package/dist/harnesses/harness-registry.d.ts.map +1 -0
- package/dist/harnesses/harness-registry.js +543 -0
- package/dist/harnesses/harness-registry.js.map +1 -0
- package/dist/harnesses/index.d.ts +12 -0
- package/dist/harnesses/index.d.ts.map +1 -0
- package/dist/harnesses/index.js +11 -0
- package/dist/harnesses/index.js.map +1 -0
- package/dist/harnesses/pi-harness.d.ts +219 -0
- package/dist/harnesses/pi-harness.d.ts.map +1 -0
- package/dist/harnesses/pi-harness.js +676 -0
- package/dist/harnesses/pi-harness.js.map +1 -0
- package/dist/harnesses/pi-schema-converter.d.ts +24 -0
- package/dist/harnesses/pi-schema-converter.d.ts.map +1 -0
- package/dist/harnesses/pi-schema-converter.js +81 -0
- package/dist/harnesses/pi-schema-converter.js.map +1 -0
- package/dist/harnesses/register-defaults.d.ts +24 -0
- package/dist/harnesses/register-defaults.d.ts.map +1 -0
- package/dist/harnesses/register-defaults.js +40 -0
- package/dist/harnesses/register-defaults.js.map +1 -0
- package/dist/harnesses/session-store.d.ts +201 -0
- package/dist/harnesses/session-store.d.ts.map +1 -0
- package/dist/harnesses/session-store.js +254 -0
- package/dist/harnesses/session-store.js.map +1 -0
- package/dist/index.d.ts +37 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +57 -0
- package/dist/index.js.map +1 -0
- package/dist/reflection/index.d.ts +5 -0
- package/dist/reflection/index.d.ts.map +1 -0
- package/{src/reflection/index.ts → dist/reflection/index.js} +1 -1
- package/dist/reflection/index.js.map +1 -0
- package/dist/reflection/reflection.d.ts +84 -0
- package/dist/reflection/reflection.d.ts.map +1 -0
- package/dist/reflection/reflection.js +344 -0
- package/dist/reflection/reflection.js.map +1 -0
- package/dist/tools/index.d.ts +6 -0
- package/dist/tools/index.d.ts.map +1 -0
- package/dist/tools/index.js +11 -0
- package/dist/tools/index.js.map +1 -0
- package/dist/tools/introspection.d.ts +165 -0
- package/dist/tools/introspection.d.ts.map +1 -0
- package/dist/tools/introspection.js +324 -0
- package/dist/tools/introspection.js.map +1 -0
- package/dist/types/agent.d.ts +1317 -0
- package/dist/types/agent.d.ts.map +1 -0
- package/dist/types/agent.js +423 -0
- package/dist/types/agent.js.map +1 -0
- package/dist/types/decorators.d.ts +40 -0
- package/dist/types/decorators.d.ts.map +1 -0
- package/dist/types/decorators.js +2 -0
- package/dist/types/decorators.js.map +1 -0
- package/dist/types/error-strategy.d.ts +13 -0
- package/dist/types/error-strategy.d.ts.map +1 -0
- package/dist/types/error-strategy.js +2 -0
- package/dist/types/error-strategy.js.map +1 -0
- package/dist/types/error.d.ts +20 -0
- package/dist/types/error.d.ts.map +1 -0
- package/dist/types/error.js +2 -0
- package/dist/types/error.js.map +1 -0
- package/dist/types/events.d.ts +113 -0
- package/dist/types/events.d.ts.map +1 -0
- package/dist/types/events.js +2 -0
- package/dist/types/events.js.map +1 -0
- package/dist/types/harnesses.d.ts +474 -0
- package/dist/types/harnesses.d.ts.map +1 -0
- package/dist/types/harnesses.js +2 -0
- package/dist/types/harnesses.js.map +1 -0
- package/dist/types/index.d.ts +23 -0
- package/dist/types/index.d.ts.map +1 -0
- package/dist/types/index.js +8 -0
- package/dist/types/index.js.map +1 -0
- package/dist/types/logging.d.ts +24 -0
- package/dist/types/logging.d.ts.map +1 -0
- package/dist/types/logging.js +2 -0
- package/dist/types/logging.js.map +1 -0
- package/dist/types/observer.d.ts +18 -0
- package/dist/types/observer.d.ts.map +1 -0
- package/dist/types/observer.js +2 -0
- package/dist/types/observer.js.map +1 -0
- package/dist/types/prompt.d.ts +31 -0
- package/dist/types/prompt.d.ts.map +1 -0
- package/dist/types/prompt.js +6 -0
- package/dist/types/prompt.js.map +1 -0
- package/dist/types/providers.d.ts +691 -0
- package/dist/types/providers.d.ts.map +1 -0
- package/dist/types/providers.js +14 -0
- package/dist/types/providers.js.map +1 -0
- package/dist/types/reflection.d.ts +96 -0
- package/dist/types/reflection.d.ts.map +1 -0
- package/dist/types/reflection.js +24 -0
- package/dist/types/reflection.js.map +1 -0
- package/dist/types/restart.d.ts +132 -0
- package/dist/types/restart.d.ts.map +1 -0
- package/dist/types/restart.js +2 -0
- package/dist/types/restart.js.map +1 -0
- package/dist/types/sdk-primitives.d.ts +118 -0
- package/dist/types/sdk-primitives.d.ts.map +1 -0
- package/dist/types/sdk-primitives.js +6 -0
- package/dist/types/sdk-primitives.js.map +1 -0
- package/{src/types/snapshot.ts → dist/types/snapshot.d.ts} +5 -5
- package/dist/types/snapshot.d.ts.map +1 -0
- package/dist/types/snapshot.js +2 -0
- package/dist/types/snapshot.js.map +1 -0
- package/dist/types/streaming.d.ts +194 -0
- package/dist/types/streaming.d.ts.map +1 -0
- package/dist/types/streaming.js +67 -0
- package/dist/types/streaming.js.map +1 -0
- package/dist/types/workflow-context.d.ts +275 -0
- package/dist/types/workflow-context.d.ts.map +1 -0
- package/dist/types/workflow-context.js +8 -0
- package/dist/types/workflow-context.js.map +1 -0
- package/dist/types/workflow.d.ts +30 -0
- package/dist/types/workflow.d.ts.map +1 -0
- package/dist/types/workflow.js +2 -0
- package/dist/types/workflow.js.map +1 -0
- package/dist/utils/agent-validation.d.ts +88 -0
- package/dist/utils/agent-validation.d.ts.map +1 -0
- package/dist/utils/agent-validation.js +87 -0
- package/dist/utils/agent-validation.js.map +1 -0
- package/dist/utils/delay.d.ts +7 -0
- package/dist/utils/delay.d.ts.map +1 -0
- package/dist/utils/delay.js +9 -0
- package/dist/utils/delay.js.map +1 -0
- package/dist/utils/harness-config.d.ts +180 -0
- package/dist/utils/harness-config.d.ts.map +1 -0
- package/dist/utils/harness-config.js +311 -0
- package/dist/utils/harness-config.js.map +1 -0
- package/dist/utils/id.d.ts +6 -0
- package/dist/utils/id.d.ts.map +1 -0
- package/dist/utils/id.js +12 -0
- package/dist/utils/id.js.map +1 -0
- package/dist/utils/index.d.ts +13 -0
- package/dist/utils/index.d.ts.map +1 -0
- package/dist/utils/index.js +11 -0
- package/dist/utils/index.js.map +1 -0
- package/dist/utils/model-spec.d.ts +110 -0
- package/dist/utils/model-spec.d.ts.map +1 -0
- package/dist/utils/model-spec.js +149 -0
- package/dist/utils/model-spec.js.map +1 -0
- package/dist/utils/observable.d.ts +54 -0
- package/dist/utils/observable.d.ts.map +1 -0
- package/dist/utils/observable.js +82 -0
- package/dist/utils/observable.js.map +1 -0
- package/dist/utils/provider-config.d.ts +10 -0
- package/dist/utils/provider-config.d.ts.map +1 -0
- package/dist/utils/provider-config.js +10 -0
- package/dist/utils/provider-config.js.map +1 -0
- package/dist/utils/restart-analysis.d.ts +202 -0
- package/dist/utils/restart-analysis.d.ts.map +1 -0
- package/dist/utils/restart-analysis.js +426 -0
- package/dist/utils/restart-analysis.js.map +1 -0
- package/dist/utils/session-serialization.d.ts +118 -0
- package/dist/utils/session-serialization.d.ts.map +1 -0
- package/dist/utils/session-serialization.js +217 -0
- package/dist/utils/session-serialization.js.map +1 -0
- package/dist/utils/workflow-error-utils.d.ts +22 -0
- package/dist/utils/workflow-error-utils.d.ts.map +1 -0
- package/dist/utils/workflow-error-utils.js +45 -0
- package/dist/utils/workflow-error-utils.js.map +1 -0
- package/package.json +34 -5
- package/.claude/commands/subtask-planning/prp-base-create.md +0 -120
- package/.claude/commands/subtask-planning/prp-base-execute.md +0 -65
- package/.claude/commands/task-breakdown.md +0 -94
- package/.claude/settings.local.json +0 -9
- package/.claude/system_prompts/task-breakdown.md +0 -101
- package/CHANGELOG.md +0 -188
- package/PRD.md +0 -543
- package/PRPs/001-hierarchical-workflow-engine.md +0 -2438
- package/PRPs/PRDs/002-agent-prompt.md +0 -390
- package/PRPs/PRDs/003-agent-prompt.md +0 -943
- package/PRPs/PRDs/004-agent-prompt.md +0 -1136
- package/PRPs/PRDs/tasks-001.json +0 -492
- package/PRPs/README.md +0 -83
- package/PRPs/templates/prp_base.md +0 -222
- package/docs/agent.md +0 -422
- package/docs/prompt.md +0 -419
- package/docs/workflow.md +0 -600
- package/examples/README.md +0 -258
- package/examples/examples/01-basic-workflow.ts +0 -100
- package/examples/examples/02-decorator-options.ts +0 -217
- package/examples/examples/03-parent-child.ts +0 -241
- package/examples/examples/04-observers-debugger.ts +0 -340
- package/examples/examples/05-error-handling.ts +0 -387
- package/examples/examples/06-concurrent-tasks.ts +0 -352
- package/examples/examples/07-agent-loops.ts +0 -432
- package/examples/examples/08-sdk-features.ts +0 -667
- package/examples/examples/09-reflection.ts +0 -573
- package/examples/examples/10-introspection.ts +0 -550
- package/examples/examples/11-reparenting-workflows.ts +0 -269
- package/examples/index.ts +0 -147
- package/examples/utils/helpers.ts +0 -57
- package/package-lock.json +0 -2398
- package/plan/001_d3bb02af4886/TEST_RESULTS.md +0 -259
- package/plan/001_d3bb02af4886/backlog.json +0 -867
- package/plan/001_d3bb02af4886/bug_fix_tasks.json +0 -484
- package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/P1M1T1S1/PRP.md +0 -488
- package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/P1M1T1S2/PRP.md +0 -581
- package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/P1M1T1S3/PRP.md +0 -687
- package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/P1M2T1S1/PRP.md +0 -492
- package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/P1M2T1S3/PRP.md +0 -932
- package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/P1M2T1S3/research/concurrent_error_testing_patterns.md +0 -1109
- package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/P1M2T1S3/research/vitest_concurrent_testing.md +0 -802
- package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/P1M2T1S3/research/workflow_engine_test_references.md +0 -603
- package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/P1M2T2S1/PRP.md +0 -564
- package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/P1M2T2S3/PRP.md +0 -518
- package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/P1M2T2S4/PRP.md +0 -1252
- package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/P1M2T3S1/PRP.md +0 -364
- package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/P1M2T3S1/research/CODEBASE_INVENTORY.md +0 -114
- package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/P1M2T3S1/research/DECORATOR_DOCUMENTATION_PATTERNS.md +0 -205
- package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/P1M2T3S1/research/PRD_LOCATION_ANALYSIS.md +0 -199
- package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/P1M2T3S1/research/ULTRATHINK_PRP_PLAN.md +0 -134
- package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/P1M3T1S1/PRP.md +0 -495
- package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/P1M3T1S1/research/console_error_inventory.md +0 -435
- package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/P1M3T1S2/PRP.md +0 -506
- package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/P1M3T1S3/PRP.md +0 -612
- package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/P1M3T2S2/PRP.md +0 -558
- package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/P1M3T2S2/research/external_research.md +0 -788
- package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/P1M3T3S2/PRP.md +0 -460
- package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/P1M3T3S3/PRP.md +0 -454
- package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/P1M3T4S1/PRP.md +0 -520
- package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/P1M3T4S1/RECOMMENDATION.md +0 -417
- package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/P1M3T4S1/research/external_workflow_engines_research.md +0 -760
- package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/P1M3T4S1/research/security_implications_analysis.md +0 -245
- package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/P1M3T4S2/PRP.md +0 -792
- package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/P1M4T1S1/PRP.md +0 -535
- package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/P1M4T1S1/TEST_EXECUTION_REPORT.md +0 -190
- package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/P1M4T1S2/PRP.md +0 -654
- package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/P1M4T1S2/TEST_FIX_REPORT.md +0 -227
- package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/P1M4T1S2/research/KEY_FINDINGS.md +0 -345
- package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/P1M4T1S2/research/QUICK_REFERENCE.md +0 -193
- package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/P1M4T1S2/research/test_maintenance_research.md +0 -1323
- package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/P1M4T3S1/BREAKING_CHANGES_AUDIT.md +0 -1011
- package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/P1M4T3S1/PRP.md +0 -927
- package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/P1M4T3S2/PRP.md +0 -505
- package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/architecture/logger_child_signature_analysis.md +0 -401
- package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/docs/P1M1T1S3/child_implementation_research.md +0 -142
- package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/docs/P1M1T1S3/test_patterns_research.md +0 -112
- package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/docs/P1M1T1S3/vitest_patterns_research.md +0 -159
- package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/docs/P1M1T1S4/PRP.md +0 -549
- package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/docs/P1M1T1S4/VERIFICATION_REPORT.md +0 -368
- package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/docs/P1M1T1S4/edge_case_analysis.md +0 -172
- package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/docs/P1M1T1S4/usage_inventory.md +0 -175
- package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/docs/P1M2T1S2/PRP.md +0 -696
- package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/docs/P1M2T1S4/PRP.md +0 -860
- package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/docs/P1M2T2S2/PRP.md +0 -1066
- package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/docs/P1M2T2S2/research/01-testing-aggregated-errors.md +0 -1103
- package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/docs/P1M2T2S2/research/01_typescript_error_aggregation_patterns.md +0 -789
- package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/docs/P1M2T2S2/research/02-error-merge-strategy-testing-guide.md +0 -1098
- package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/docs/P1M2T2S2/research/02_aggregate_error_patterns.md +0 -1037
- package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/docs/P1M2T2S2/research/03-promise-allsettled-testing-patterns.md +0 -916
- package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/docs/P1M2T2S2/research/03_error_merging_strategies.md +0 -1045
- package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/docs/P1M2T2S2/research/04_github_stackoverflow_examples.md +0 -890
- package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/docs/P1M2T2S2/research/05_comprehensive_summary.md +0 -822
- package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/docs/P1M2T2S2/research/INDEX.md +0 -668
- package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/docs/P1M2T2S2/research/QUICK_REFERENCE.md +0 -706
- package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/docs/P1M2T2S2/research/README.md +0 -265
- package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/docs/P1M2T2S2/research/RESEARCH_REPORT.md +0 -655
- package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/docs/P1M2T2S4/research/vitest_testing_patterns.md +0 -1103
- package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/docs/P1M2T3S2/PRP.md +0 -426
- package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/docs/P1M3T1S2/PRP.md +0 -506
- package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/docs/P1M3T1S2/research/QUICK_REFERENCE.md +0 -114
- package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/docs/P1M3T1S2/research/RESEARCH_SUMMARY.md +0 -316
- package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/docs/P1M3T1S2/research/vitest_observer_error_logging_best_practices.md +0 -754
- package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/docs/P1M3T1S3/PRP.md +0 -612
- package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/docs/P1M3T2S1/PRP.md +0 -719
- package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/docs/P1M3T2S1/README.md +0 -215
- package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/docs/P1M3T2S1/analysis.md +0 -765
- package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/docs/P1M3T2S3/PRP.md +0 -718
- package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/docs/P1M3T3S1/DECISION.md +0 -149
- package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/docs/P1M3T3S1/PRP.md +0 -470
- package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/docs/P1M3T3S1/research/ULTRATHINK_PLAN.md +0 -332
- package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/docs/P1M3T3S1/research/codebase_workflow_name_analysis.md +0 -167
- package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/docs/P1M3T3S1/research/external_best_practices.md +0 -265
- package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/docs/P1M3T3S1/research/validation_patterns.md +0 -273
- package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/docs/P1M3T4S1/workflow_engine_ancestry_api_research.md +0 -760
- package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/docs/P1M3T4S3-PRP.md +0 -434
- package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/docs/P1M4T2S1/PRP.md +0 -717
- package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/docs/P1M4T2S2/PRP.md +0 -472
- package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/docs/P1M4T2S2/VALIDATION_REPORT.md +0 -125
- package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/docs/P1M4T2S2/research/ULTRATHINK_PRP_PLAN.md +0 -301
- package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/docs/error-logging-best-practices.md +0 -1170
- package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/docs/research_typescript_partial_and_overloads.md +0 -940
- package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/docs/vitest-quick-reference.md +0 -151
- package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/docs/vitest-research.md +0 -650
- package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/prd_snapshot.md +0 -259
- package/plan/001_d3bb02af4886/bugfix/P1M1T1S1/PRP.md +0 -457
- package/plan/001_d3bb02af4886/bugfix/RESEARCH_SUMMARY.md +0 -346
- package/plan/001_d3bb02af4886/bugfix/architecture/codebase_structure.md +0 -311
- package/plan/001_d3bb02af4886/bugfix/architecture/concurrent_execution_best_practices.md +0 -1565
- package/plan/001_d3bb02af4886/bugfix/architecture/error_handling_patterns.md +0 -288
- package/plan/001_d3bb02af4886/bugfix/architecture/promise_all_analysis.md +0 -741
- package/plan/001_d3bb02af4886/docs/PRP/P1M1T1S4-functional-workflow-error-state-capture-test.md +0 -652
- package/plan/001_d3bb02af4886/docs/PRP/P1P2-PRP.md +0 -527
- package/plan/001_d3bb02af4886/docs/PRP/P3P4-PRP.md +0 -1388
- package/plan/001_d3bb02af4886/docs/PRP/P4P5-PRP.md +0 -1136
- package/plan/001_d3bb02af4886/docs/PRP/PRP.md +0 -527
- package/plan/001_d3bb02af4886/docs/PRP/bugfix/P1M1T2S1-PRP.md +0 -415
- package/plan/001_d3bb02af4886/docs/PRP/bugfix/P1M1T2S2-PRP.md +0 -378
- package/plan/001_d3bb02af4886/docs/PRP/bugfix/P1M1T2S4-PRP.md +0 -713
- package/plan/001_d3bb02af4886/docs/PRP/bugfix/P1M2T1S4-PRP.md +0 -370
- package/plan/001_d3bb02af4886/docs/PRP_P1M3T1S3.md +0 -499
- package/plan/001_d3bb02af4886/docs/TEST_RESULTS.md +0 -230
- package/plan/001_d3bb02af4886/docs/architecture/external_deps.md +0 -358
- package/plan/001_d3bb02af4886/docs/architecture/system_context.md +0 -242
- package/plan/001_d3bb02af4886/docs/bugfix/ANALYSIS_PRD_VS_IMPLEMENTATION.md +0 -1134
- package/plan/001_d3bb02af4886/docs/bugfix/GAP_ANALYSIS_SUMMARY.md +0 -179
- package/plan/001_d3bb02af4886/docs/bugfix/P1M4T2S1/PRP.md +0 -629
- package/plan/001_d3bb02af4886/docs/bugfix/P1M4T2S1/validation-report.md +0 -214
- package/plan/001_d3bb02af4886/docs/bugfix/PRP_P1M4T2S3.md +0 -629
- package/plan/001_d3bb02af4886/docs/bugfix/bugfix_PRP.md +0 -529
- package/plan/001_d3bb02af4886/docs/bugfix/bugfix_QUICK_REFERENCE.md +0 -142
- package/plan/001_d3bb02af4886/docs/bugfix/bugfix_README.md +0 -304
- package/plan/001_d3bb02af4886/docs/bugfix/bugfix_TEST_RESULTS.md +0 -558
- package/plan/001_d3bb02af4886/docs/bugfix/bugfix_VALIDATION_SUMMARY.md +0 -256
- package/plan/001_d3bb02af4886/docs/bugfix/system_context.md +0 -346
- package/plan/001_d3bb02af4886/docs/bugfix-architecture/bug_analysis.md +0 -415
- package/plan/001_d3bb02af4886/docs/bugfix-architecture/implementation_patterns.md +0 -489
- package/plan/001_d3bb02af4886/docs/bugfix-architecture/system_context.md +0 -218
- package/plan/001_d3bb02af4886/docs/bugfix_INITIATION_SUMMARY.md +0 -380
- package/plan/001_d3bb02af4886/docs/research/CYCLE_DETECTION_PATTERNS.md +0 -1923
- package/plan/001_d3bb02af4886/docs/research/CYCLE_DETECTION_QUICK_REF.md +0 -319
- package/plan/001_d3bb02af4886/docs/research/P1M1T2S1/codebase-context.md +0 -115
- package/plan/001_d3bb02af4886/docs/research/P1M1T2S1/cycle-detection-algorithms.md +0 -134
- package/plan/001_d3bb02af4886/docs/research/P1M1T2S1/test-patterns.md +0 -153
- package/plan/001_d3bb02af4886/docs/research/P1M1T2S1/workflow-class.md +0 -132
- package/plan/001_d3bb02af4886/docs/research/P1M2T1S4/DECORATOR_DOCUMENTATION_BEST_PRACTICES.md +0 -716
- package/plan/001_d3bb02af4886/docs/research/P1M2T1S4/DECORATOR_DOCUMENTATION_QUICK_REF.md +0 -186
- package/plan/001_d3bb02af4886/docs/research/P1M2T1S4/GROUNDSWELL_DECORATOR_EXAMPLES.md +0 -604
- package/plan/001_d3bb02af4886/docs/research/P1M2T1S4/INDEX.md +0 -213
- package/plan/001_d3bb02af4886/docs/research/P1M2T1S4/codebase_structure.md +0 -30
- package/plan/001_d3bb02af4886/docs/research/P1M2T1S4/existing_test_pattern.md +0 -56
- package/plan/001_d3bb02af4886/docs/research/P1M2T1S4/getRootObservers_implementation.md +0 -53
- package/plan/001_d3bb02af4886/docs/research/P1M2T1S4/test_conventions.md +0 -49
- package/plan/001_d3bb02af4886/docs/research/P1M3T1S4/PRP.md +0 -958
- package/plan/001_d3bb02af4886/docs/research/P1M3T1S4/QUICK_REFERENCE.md +0 -339
- package/plan/001_d3bb02af4886/docs/research/P1M3T1S4/README.md +0 -305
- package/plan/001_d3bb02af4886/docs/research/P1M3T1S4/SUMMARY.md +0 -433
- package/plan/001_d3bb02af4886/docs/research/P1M3T1S4/bidirectional-tree-consistency-testing.md +0 -1574
- package/plan/001_d3bb02af4886/docs/research/P1M3T1S4/test-pattern-examples.md +0 -1014
- package/plan/001_d3bb02af4886/docs/research/P1P2/LRU_CACHE_BEST_PRACTICES.md +0 -1929
- package/plan/001_d3bb02af4886/docs/research/P1P2/LRU_CACHE_CODE_PATTERNS.md +0 -857
- package/plan/001_d3bb02af4886/docs/research/P1P2/LRU_CACHE_INTEGRATION_GUIDE.md +0 -738
- package/plan/001_d3bb02af4886/docs/research/P1P2/LRU_CACHE_RESEARCH_INDEX.md +0 -424
- package/plan/001_d3bb02af4886/docs/research/P1P2/REFLECTION_INDEX.md +0 -291
- package/plan/001_d3bb02af4886/docs/research/P1P2/REFLECTION_RESEARCH_REPORT.md +0 -1342
- package/plan/001_d3bb02af4886/docs/research/P1P2/RESEARCH_SUMMARY.md +0 -342
- package/plan/001_d3bb02af4886/docs/research/P1P2/anthropic-sdk.md +0 -174
- package/plan/001_d3bb02af4886/docs/research/P1P2/async-local-storage.md +0 -200
- package/plan/001_d3bb02af4886/docs/research/P1P2/reflection-code-patterns.md +0 -1205
- package/plan/001_d3bb02af4886/docs/research/P1P2/reflection-decision-matrix.md +0 -421
- package/plan/001_d3bb02af4886/docs/research/P1P2/reflection-implementation-guide.md +0 -1341
- package/plan/001_d3bb02af4886/docs/research/P1P2/reflection-integration-guide.md +0 -834
- package/plan/001_d3bb02af4886/docs/research/P1P2/reflection-patterns.md +0 -1468
- package/plan/001_d3bb02af4886/docs/research/P1P2/reflection-quick-reference.md +0 -558
- package/plan/001_d3bb02af4886/docs/research/P1P2/zod-schema.md +0 -152
- package/plan/001_d3bb02af4886/docs/research/P3P4/caching-lru.md +0 -116
- package/plan/001_d3bb02af4886/docs/research/P3P4/introspection-tools.md +0 -177
- package/plan/001_d3bb02af4886/docs/research/P3P4/reflection-patterns.md +0 -117
- package/plan/001_d3bb02af4886/docs/research/P4P5/RESEARCH_SUMMARY.md +0 -151
- package/plan/001_d3bb02af4886/docs/research/PROMISE_ALLSETTLED_QUICK_REF.md +0 -376
- package/plan/001_d3bb02af4886/docs/research/PROMISE_ALLSETTLED_RESEARCH.md +0 -1507
- package/plan/001_d3bb02af4886/docs/research/bugfix_typescript_patterns.md +0 -949
- package/plan/001_d3bb02af4886/docs/research/error-testing-research.md +0 -619
- package/plan/001_d3bb02af4886/docs/research/error_handling_patterns.md +0 -723
- package/plan/001_d3bb02af4886/docs/research/general/INTROSPECTION_RESEARCH_SUMMARY.md +0 -378
- package/plan/001_d3bb02af4886/docs/research/general/README-INTROSPECTION.md +0 -352
- package/plan/001_d3bb02af4886/docs/research/general/agent-introspection-patterns.md +0 -1085
- package/plan/001_d3bb02af4886/docs/research/general/introspection-security-guide.md +0 -984
- package/plan/001_d3bb02af4886/docs/research/general/introspection-tool-examples.md +0 -875
- package/plan/001_d3bb02af4886/docs/research/incremental-tree-map-updates/PRP_TEMPLATE.md +0 -460
- package/plan/001_d3bb02af4886/docs/research/incremental-tree-map-updates/QUICK_REFERENCE.md +0 -324
- package/plan/001_d3bb02af4886/docs/research/incremental-tree-map-updates/README.md +0 -175
- package/plan/001_d3bb02af4886/docs/research/incremental-tree-map-updates/RESEARCH_REPORT.md +0 -499
- package/plan/001_d3bb02af4886/docs/research/incremental-tree-map-updates/SUMMARY.md +0 -163
- package/plan/001_d3bb02af4886/prd_snapshot.md +0 -543
- package/plan/bugfix/BUG_FIX_SUMMARY.md +0 -961
- package/scripts/generate-llms-full.ts +0 -206
- package/src/__tests__/adversarial/attachChild-performance.test.ts +0 -216
- package/src/__tests__/adversarial/circular-reference.test.ts +0 -101
- package/src/__tests__/adversarial/complex-circular-reference.test.ts +0 -139
- package/src/__tests__/adversarial/concurrent-task-failures.test.ts +0 -571
- package/src/__tests__/adversarial/deep-analysis.test.ts +0 -729
- package/src/__tests__/adversarial/deep-hierarchy-stress.test.ts +0 -213
- package/src/__tests__/adversarial/e2e-prd-validation.test.ts +0 -448
- package/src/__tests__/adversarial/edge-case.test.ts +0 -703
- package/src/__tests__/adversarial/error-merge-strategy.test.ts +0 -760
- package/src/__tests__/adversarial/incremental-performance.test.ts +0 -140
- package/src/__tests__/adversarial/node-map-update-benchmarks.test.ts +0 -457
- package/src/__tests__/adversarial/observer-propagation.test.ts +0 -487
- package/src/__tests__/adversarial/parent-validation.test.ts +0 -143
- package/src/__tests__/adversarial/prd-12-2-compliance.test.ts +0 -611
- package/src/__tests__/adversarial/prd-compliance.test.ts +0 -731
- package/src/__tests__/compatibility/backward-compatibility.test.ts +0 -1572
- package/src/__tests__/helpers/index.ts +0 -18
- package/src/__tests__/helpers/tree-verification.ts +0 -257
- package/src/__tests__/integration/agent-workflow.test.ts +0 -256
- package/src/__tests__/integration/bidirectional-consistency.test.ts +0 -847
- package/src/__tests__/integration/observer-logging.test.ts +0 -643
- package/src/__tests__/integration/tree-mirroring.test.ts +0 -151
- package/src/__tests__/integration/workflow-reparenting.test.ts +0 -303
- package/src/__tests__/unit/agent.test.ts +0 -169
- package/src/__tests__/unit/cache-key.test.ts +0 -182
- package/src/__tests__/unit/cache.test.ts +0 -172
- package/src/__tests__/unit/context.test.ts +0 -217
- package/src/__tests__/unit/decorators.test.ts +0 -100
- package/src/__tests__/unit/introspection-tools.test.ts +0 -277
- package/src/__tests__/unit/logger.test.ts +0 -293
- package/src/__tests__/unit/observable.test.ts +0 -321
- package/src/__tests__/unit/prompt.test.ts +0 -135
- package/src/__tests__/unit/reflection.test.ts +0 -210
- package/src/__tests__/unit/tree-debugger-incremental.test.ts +0 -170
- package/src/__tests__/unit/tree-debugger.test.ts +0 -85
- package/src/__tests__/unit/utils/workflow-error-utils.test.ts +0 -209
- package/src/__tests__/unit/workflow-detachChild.test.ts +0 -100
- package/src/__tests__/unit/workflow-emitEvent-childDetached.test.ts +0 -153
- package/src/__tests__/unit/workflow-isDescendantOf.test.ts +0 -180
- package/src/__tests__/unit/workflow.test.ts +0 -357
- package/src/cache/cache-key.ts +0 -244
- package/src/cache/cache.ts +0 -236
- package/src/core/agent.ts +0 -593
- package/src/core/event-tree.ts +0 -260
- package/src/core/logger.ts +0 -112
- package/src/core/mcp-handler.ts +0 -184
- package/src/core/prompt.ts +0 -150
- package/src/core/workflow-context.ts +0 -351
- package/src/core/workflow.ts +0 -540
- package/src/debugger/tree-debugger.ts +0 -255
- package/src/decorators/observed-state.ts +0 -95
- package/src/decorators/step.ts +0 -139
- package/src/decorators/task.ts +0 -159
- package/src/examples/tdd-orchestrator.ts +0 -65
- package/src/examples/test-cycle-workflow.ts +0 -64
- package/src/index.ts +0 -142
- package/src/reflection/reflection.ts +0 -407
- package/src/tools/index.ts +0 -36
- package/src/tools/introspection.ts +0 -464
- package/src/types/agent.ts +0 -90
- package/src/types/decorators.ts +0 -32
- package/src/types/error-strategy.ts +0 -13
- package/src/types/error.ts +0 -20
- package/src/types/events.ts +0 -75
- package/src/types/index.ts +0 -55
- package/src/types/logging.ts +0 -24
- package/src/types/observer.ts +0 -18
- package/src/types/prompt.ts +0 -40
- package/src/types/reflection.ts +0 -117
- package/src/types/sdk-primitives.ts +0 -128
- package/src/types/workflow-context.ts +0 -163
- package/src/types/workflow.ts +0 -37
- package/src/utils/id.ts +0 -11
- package/src/utils/index.ts +0 -4
- package/src/utils/observable.ts +0 -106
- package/src/utils/workflow-error-utils.ts +0 -56
- package/tsconfig.json +0 -22
- package/vitest.config.ts +0 -16
package/plan/001_d3bb02af4886/bugfix/001_e8e04329daf3/P1M2T1S3/research/vitest_concurrent_testing.md
DELETED
|
@@ -1,802 +0,0 @@
|
|
|
1
|
-
# Vitest Concurrent Testing Research for Promise.allSettled
|
|
2
|
-
|
|
3
|
-
**Research Date:** 2026-01-12
|
|
4
|
-
**Status:** Vitest Testing Patterns Research
|
|
5
|
-
**Target:** P1.M2.T1.S3 - Testing Promise.allSettled Implementation
|
|
6
|
-
|
|
7
|
-
---
|
|
8
|
-
|
|
9
|
-
## Table of Contents
|
|
10
|
-
|
|
11
|
-
1. [Official Vitest Documentation](#1-official-vitest-documentation)
|
|
12
|
-
2. [Async Testing Patterns in Vitest](#2-async-testing-patterns-in-vitest)
|
|
13
|
-
3. [Promise.allSettled Testing Patterns](#3-promiseallsettled-testing-patterns)
|
|
14
|
-
4. [Error Handling and Collection Testing](#4-error-handling-and-collection-testing)
|
|
15
|
-
5. [Concurrent Operations Testing](#5-concurrent-operations-testing)
|
|
16
|
-
6. [Event Emission Verification](#6-event-emission-verification)
|
|
17
|
-
7. [Best Practices Summary](#7-best-practices-summary)
|
|
18
|
-
8. [Real-World Patterns from Groundswell](#8-real-world-patterns-from-groundswell)
|
|
19
|
-
|
|
20
|
-
---
|
|
21
|
-
|
|
22
|
-
## 1. Official Vitest Documentation
|
|
23
|
-
|
|
24
|
-
### Primary Resources
|
|
25
|
-
|
|
26
|
-
**Main Documentation**
|
|
27
|
-
- URL: https://vitest.dev
|
|
28
|
-
- Coverage: Async testing, assertions, mocking, test organization
|
|
29
|
-
|
|
30
|
-
**API Reference**
|
|
31
|
-
- URL: https://vitest.dev/api/
|
|
32
|
-
- Coverage: Complete API reference for all vitest functions
|
|
33
|
-
|
|
34
|
-
**Async Testing Guide**
|
|
35
|
-
- URL: https://vitest.dev/guide/async.html
|
|
36
|
-
- Coverage: Async/await patterns, promise testing, timeouts
|
|
37
|
-
|
|
38
|
-
**Mocking Guide**
|
|
39
|
-
- URL: https://vitest.dev/guide/mocking.html
|
|
40
|
-
- Coverage: Mock functions, spies, timers, modules
|
|
41
|
-
|
|
42
|
-
**Expect API**
|
|
43
|
-
- URL: https://vitest.dev/api/expect.html
|
|
44
|
-
- Coverage: All assertion methods including `.resolves` and `.rejects`
|
|
45
|
-
|
|
46
|
-
### Key Vitest Features for Concurrent Testing
|
|
47
|
-
|
|
48
|
-
1. **Native Async/Await Support**: First-class async/await in tests
|
|
49
|
-
2. **Promise Assertions**: `.resolves` and `.rejects` modifiers
|
|
50
|
-
3. **Mock Functions**: `vi.fn()`, `vi.spyOn()`, `vi.mocked()`
|
|
51
|
-
4. **Test Isolation**: Each test runs in isolated context
|
|
52
|
-
5. **Concurrent Test Execution**: `test.concurrent()` for parallel test runs
|
|
53
|
-
|
|
54
|
-
---
|
|
55
|
-
|
|
56
|
-
## 2. Async Testing Patterns in Vitest
|
|
57
|
-
|
|
58
|
-
### 2.1 Basic Async Test Structure
|
|
59
|
-
|
|
60
|
-
```typescript
|
|
61
|
-
import { describe, it, expect } from 'vitest';
|
|
62
|
-
|
|
63
|
-
describe('Async operations', () => {
|
|
64
|
-
it('should handle async/await', async () => {
|
|
65
|
-
const result = await fetchData();
|
|
66
|
-
expect(result).toBeDefined();
|
|
67
|
-
});
|
|
68
|
-
|
|
69
|
-
it('should handle promises', () => {
|
|
70
|
-
return fetchData().then(result => {
|
|
71
|
-
expect(result).toBeDefined();
|
|
72
|
-
});
|
|
73
|
-
});
|
|
74
|
-
});
|
|
75
|
-
```
|
|
76
|
-
|
|
77
|
-
### 2.2 Promise Resolution Testing
|
|
78
|
-
|
|
79
|
-
```typescript
|
|
80
|
-
describe('Promise resolution', () => {
|
|
81
|
-
it('should resolve successfully', async () => {
|
|
82
|
-
await expect(Promise.resolve('success')).resolves.toBe('success');
|
|
83
|
-
});
|
|
84
|
-
|
|
85
|
-
it('should reject with error', async () => {
|
|
86
|
-
await expect(Promise.reject(new Error('failure'))).rejects.toThrow('failure');
|
|
87
|
-
});
|
|
88
|
-
|
|
89
|
-
it('should match error shape', async () => {
|
|
90
|
-
await expect(Promise.reject({ message: 'error', code: 500 }))
|
|
91
|
-
.rejects.toMatchObject({
|
|
92
|
-
message: 'error',
|
|
93
|
-
code: 500
|
|
94
|
-
});
|
|
95
|
-
});
|
|
96
|
-
});
|
|
97
|
-
```
|
|
98
|
-
|
|
99
|
-
### 2.3 Multiple Async Operations
|
|
100
|
-
|
|
101
|
-
```typescript
|
|
102
|
-
describe('Multiple async operations', () => {
|
|
103
|
-
it('should complete multiple operations', async () => {
|
|
104
|
-
const results = await Promise.all([
|
|
105
|
-
fetchItem(1),
|
|
106
|
-
fetchItem(2),
|
|
107
|
-
fetchItem(3)
|
|
108
|
-
]);
|
|
109
|
-
|
|
110
|
-
expect(results).toHaveLength(3);
|
|
111
|
-
expect(results[0]).toBeDefined();
|
|
112
|
-
});
|
|
113
|
-
|
|
114
|
-
it('should handle mixed success/failure with allSettled', async () => {
|
|
115
|
-
const results = await Promise.allSettled([
|
|
116
|
-
Promise.resolve('success'),
|
|
117
|
-
Promise.reject(new Error('failure')),
|
|
118
|
-
Promise.resolve(42)
|
|
119
|
-
]);
|
|
120
|
-
|
|
121
|
-
expect(results).toHaveLength(3);
|
|
122
|
-
});
|
|
123
|
-
});
|
|
124
|
-
```
|
|
125
|
-
|
|
126
|
-
---
|
|
127
|
-
|
|
128
|
-
## 3. Promise.allSettled Testing Patterns
|
|
129
|
-
|
|
130
|
-
### 3.1 Basic Promise.allSettled Testing
|
|
131
|
-
|
|
132
|
-
```typescript
|
|
133
|
-
import { describe, it, expect } from 'vitest';
|
|
134
|
-
|
|
135
|
-
describe('Promise.allSettled basics', () => {
|
|
136
|
-
it('should return all results regardless of fulfillment', async () => {
|
|
137
|
-
const promises = [
|
|
138
|
-
Promise.resolve('success'),
|
|
139
|
-
Promise.reject(new Error('failure')),
|
|
140
|
-
Promise.resolve(42)
|
|
141
|
-
];
|
|
142
|
-
|
|
143
|
-
const results = await Promise.allSettled(promises);
|
|
144
|
-
|
|
145
|
-
expect(results).toHaveLength(3);
|
|
146
|
-
});
|
|
147
|
-
|
|
148
|
-
it('should contain status for each result', async () => {
|
|
149
|
-
const results = await Promise.allSettled([
|
|
150
|
-
Promise.resolve('value'),
|
|
151
|
-
Promise.reject(new Error('error'))
|
|
152
|
-
]);
|
|
153
|
-
|
|
154
|
-
expect(results[0].status).toBe('fulfilled');
|
|
155
|
-
expect(results[1].status).toBe('rejected');
|
|
156
|
-
});
|
|
157
|
-
});
|
|
158
|
-
```
|
|
159
|
-
|
|
160
|
-
### 3.2 Type-Safe Result Testing
|
|
161
|
-
|
|
162
|
-
```typescript
|
|
163
|
-
describe('Type-safe Promise.allSettled testing', () => {
|
|
164
|
-
it('should handle fulfilled results with type guard', async () => {
|
|
165
|
-
const results = await Promise.allSettled([
|
|
166
|
-
Promise.resolve('success'),
|
|
167
|
-
Promise.resolve(42)
|
|
168
|
-
]);
|
|
169
|
-
|
|
170
|
-
const fulfilled = results.filter(
|
|
171
|
-
(r): r is PromiseFulfilledResult<unknown> => r.status === 'fulfilled'
|
|
172
|
-
);
|
|
173
|
-
|
|
174
|
-
expect(fulfilled).toHaveLength(2);
|
|
175
|
-
expect(fulfilled[0].value).toBe('success');
|
|
176
|
-
expect(fulfilled[1].value).toBe(42);
|
|
177
|
-
});
|
|
178
|
-
|
|
179
|
-
it('should handle rejected results with type guard', async () => {
|
|
180
|
-
const results = await Promise.allSettled([
|
|
181
|
-
Promise.reject(new Error('error1')),
|
|
182
|
-
Promise.reject(new Error('error2'))
|
|
183
|
-
]);
|
|
184
|
-
|
|
185
|
-
const rejected = results.filter(
|
|
186
|
-
(r): r is PromiseRejectedResult => r.status === 'rejected'
|
|
187
|
-
);
|
|
188
|
-
|
|
189
|
-
expect(rejected).toHaveLength(2);
|
|
190
|
-
expect(rejected[0].reason).toBeInstanceOf(Error);
|
|
191
|
-
expect(rejected[0].reason.message).toBe('error1');
|
|
192
|
-
});
|
|
193
|
-
});
|
|
194
|
-
```
|
|
195
|
-
|
|
196
|
-
### 3.3 Counting Success vs Failure
|
|
197
|
-
|
|
198
|
-
```typescript
|
|
199
|
-
describe('Counting results from Promise.allSettled', () => {
|
|
200
|
-
it('should count successful operations', async () => {
|
|
201
|
-
const results = await Promise.allSettled([
|
|
202
|
-
Promise.resolve('a'),
|
|
203
|
-
Promise.reject(new Error('b')),
|
|
204
|
-
Promise.resolve('c'),
|
|
205
|
-
Promise.reject(new Error('d'))
|
|
206
|
-
]);
|
|
207
|
-
|
|
208
|
-
const successful = results.filter(r => r.status === 'fulfilled');
|
|
209
|
-
const failed = results.filter(r => r.status === 'rejected');
|
|
210
|
-
|
|
211
|
-
expect(successful).toHaveLength(2);
|
|
212
|
-
expect(failed).toHaveLength(2);
|
|
213
|
-
});
|
|
214
|
-
|
|
215
|
-
it('should calculate success rate', async () => {
|
|
216
|
-
const results = await Promise.allSettled([
|
|
217
|
-
Promise.resolve('a'),
|
|
218
|
-
Promise.reject(new Error('b')),
|
|
219
|
-
Promise.resolve('c')
|
|
220
|
-
]);
|
|
221
|
-
|
|
222
|
-
const successRate = results.filter(r => r.status === 'fulfilled').length / results.length;
|
|
223
|
-
|
|
224
|
-
expect(successRate).toBeCloseTo(0.667, 2);
|
|
225
|
-
});
|
|
226
|
-
});
|
|
227
|
-
```
|
|
228
|
-
|
|
229
|
-
---
|
|
230
|
-
|
|
231
|
-
## 4. Error Handling and Collection Testing
|
|
232
|
-
|
|
233
|
-
### 4.1 Error Aggregation Testing
|
|
234
|
-
|
|
235
|
-
```typescript
|
|
236
|
-
describe('Error aggregation with Promise.allSettled', () => {
|
|
237
|
-
it('should collect all errors from rejected promises', async () => {
|
|
238
|
-
const results = await Promise.allSettled([
|
|
239
|
-
Promise.reject(new Error('Error 1')),
|
|
240
|
-
Promise.resolve('success'),
|
|
241
|
-
Promise.reject(new Error('Error 2'))
|
|
242
|
-
]);
|
|
243
|
-
|
|
244
|
-
const errors = results
|
|
245
|
-
.filter(r => r.status === 'rejected')
|
|
246
|
-
.map(r => (r as PromiseRejectedResult).reason);
|
|
247
|
-
|
|
248
|
-
expect(errors).toHaveLength(2);
|
|
249
|
-
expect(errors[0].message).toBe('Error 1');
|
|
250
|
-
expect(errors[1].message).toBe('Error 2');
|
|
251
|
-
});
|
|
252
|
-
|
|
253
|
-
it('should preserve error stack traces', async () => {
|
|
254
|
-
const results = await Promise.allSettled([
|
|
255
|
-
Promise.reject(new Error('Stack trace test'))
|
|
256
|
-
]);
|
|
257
|
-
|
|
258
|
-
const rejected = results.find(r => r.status === 'rejected') as PromiseRejectedResult;
|
|
259
|
-
|
|
260
|
-
expect(rejected.reason.stack).toBeDefined();
|
|
261
|
-
expect(rejected.reason.stack).toContain('Stack trace test');
|
|
262
|
-
});
|
|
263
|
-
});
|
|
264
|
-
```
|
|
265
|
-
|
|
266
|
-
### 4.2 Error Message Validation
|
|
267
|
-
|
|
268
|
-
```typescript
|
|
269
|
-
describe('Error message validation', () => {
|
|
270
|
-
it('should validate error messages', async () => {
|
|
271
|
-
const results = await Promise.allSettled([
|
|
272
|
-
Promise.reject(new Error('Validation failed')),
|
|
273
|
-
Promise.reject(new Error('Network error'))
|
|
274
|
-
]);
|
|
275
|
-
|
|
276
|
-
const errorMessages = results
|
|
277
|
-
.filter(r => r.status === 'rejected')
|
|
278
|
-
.map(r => (r as PromiseRejectedResult).reason.message);
|
|
279
|
-
|
|
280
|
-
expect(errorMessages).toContain('Validation failed');
|
|
281
|
-
expect(errorMessages).toContain('Network error');
|
|
282
|
-
});
|
|
283
|
-
|
|
284
|
-
it('should match error patterns', async () => {
|
|
285
|
-
const results = await Promise.allSettled([
|
|
286
|
-
Promise.reject(new Error('Error: Code 500')),
|
|
287
|
-
Promise.reject(new Error('Error: Code 404'))
|
|
288
|
-
]);
|
|
289
|
-
|
|
290
|
-
const errorMessages = results
|
|
291
|
-
.filter(r => r.status === 'rejected')
|
|
292
|
-
.map(r => (r as PromiseRejectedResult).reason.message);
|
|
293
|
-
|
|
294
|
-
errorMessages.forEach(msg => {
|
|
295
|
-
expect(msg).toMatch(/^Error: Code \d+$/);
|
|
296
|
-
});
|
|
297
|
-
});
|
|
298
|
-
});
|
|
299
|
-
```
|
|
300
|
-
|
|
301
|
-
### 4.3 Custom Error Objects
|
|
302
|
-
|
|
303
|
-
```typescript
|
|
304
|
-
interface WorkflowError {
|
|
305
|
-
message: string;
|
|
306
|
-
workflowId: string;
|
|
307
|
-
code?: number;
|
|
308
|
-
}
|
|
309
|
-
|
|
310
|
-
describe('Custom error handling', () => {
|
|
311
|
-
it('should handle custom error objects', async () => {
|
|
312
|
-
const errors: WorkflowError[] = [
|
|
313
|
-
{ message: 'Task failed', workflowId: 'wf-1', code: 500 },
|
|
314
|
-
{ message: 'Timeout', workflowId: 'wf-2' }
|
|
315
|
-
];
|
|
316
|
-
|
|
317
|
-
const results = await Promise.allSettled(
|
|
318
|
-
errors.map(e => Promise.reject(e))
|
|
319
|
-
);
|
|
320
|
-
|
|
321
|
-
const rejected = results.filter(r => r.status === 'rejected') as PromiseRejectedResult[];
|
|
322
|
-
|
|
323
|
-
expect(rejected[0].reason).toMatchObject({
|
|
324
|
-
message: 'Task failed',
|
|
325
|
-
workflowId: 'wf-1'
|
|
326
|
-
});
|
|
327
|
-
});
|
|
328
|
-
});
|
|
329
|
-
```
|
|
330
|
-
|
|
331
|
-
---
|
|
332
|
-
|
|
333
|
-
## 5. Concurrent Operations Testing
|
|
334
|
-
|
|
335
|
-
### 5.1 Testing Concurrent Execution
|
|
336
|
-
|
|
337
|
-
```typescript
|
|
338
|
-
describe('Concurrent operations', () => {
|
|
339
|
-
it('should execute operations concurrently', async () => {
|
|
340
|
-
let operation1Complete = false;
|
|
341
|
-
let operation2Complete = false;
|
|
342
|
-
|
|
343
|
-
const results = await Promise.allSettled([
|
|
344
|
-
(async () => {
|
|
345
|
-
await delay(100);
|
|
346
|
-
operation1Complete = true;
|
|
347
|
-
return 'op1';
|
|
348
|
-
})(),
|
|
349
|
-
(async () => {
|
|
350
|
-
await delay(50);
|
|
351
|
-
operation2Complete = true;
|
|
352
|
-
return 'op2';
|
|
353
|
-
})()
|
|
354
|
-
]);
|
|
355
|
-
|
|
356
|
-
// Both should complete despite different delays
|
|
357
|
-
expect(operation1Complete).toBe(true);
|
|
358
|
-
expect(operation2Complete).toBe(true);
|
|
359
|
-
expect(results).toHaveLength(2);
|
|
360
|
-
});
|
|
361
|
-
});
|
|
362
|
-
```
|
|
363
|
-
|
|
364
|
-
### 5.2 Testing Ordering Guarantees
|
|
365
|
-
|
|
366
|
-
```typescript
|
|
367
|
-
describe('Result ordering with Promise.allSettled', () => {
|
|
368
|
-
it('should maintain input order regardless of completion time', async () => {
|
|
369
|
-
const results = await Promise.allSettled([
|
|
370
|
-
delay(100).then(() => 'first'),
|
|
371
|
-
delay(10).then(() => 'second'),
|
|
372
|
-
delay(50).then(() => 'third')
|
|
373
|
-
]);
|
|
374
|
-
|
|
375
|
-
const values = results
|
|
376
|
-
.filter(r => r.status === 'fulfilled')
|
|
377
|
-
.map(r => (r as PromiseFulfilledResult<string>).value);
|
|
378
|
-
|
|
379
|
-
expect(values).toEqual(['first', 'second', 'third']);
|
|
380
|
-
});
|
|
381
|
-
});
|
|
382
|
-
```
|
|
383
|
-
|
|
384
|
-
### 5.3 Testing Race Conditions
|
|
385
|
-
|
|
386
|
-
```typescript
|
|
387
|
-
describe('Race condition testing', () => {
|
|
388
|
-
it('should handle concurrent modifications safely', async () => {
|
|
389
|
-
const counter = { value: 0 };
|
|
390
|
-
const operations = 10;
|
|
391
|
-
|
|
392
|
-
const results = await Promise.allSettled(
|
|
393
|
-
Array.from({ length: operations }, (_, i) =>
|
|
394
|
-
Promise.resolve().then(() => {
|
|
395
|
-
counter.value += 1;
|
|
396
|
-
return i;
|
|
397
|
-
})
|
|
398
|
-
)
|
|
399
|
-
);
|
|
400
|
-
|
|
401
|
-
expect(counter.value).toBe(operations);
|
|
402
|
-
expect(results.filter(r => r.status === 'fulfilled')).toHaveLength(operations);
|
|
403
|
-
});
|
|
404
|
-
});
|
|
405
|
-
```
|
|
406
|
-
|
|
407
|
-
---
|
|
408
|
-
|
|
409
|
-
## 6. Event Emission Verification
|
|
410
|
-
|
|
411
|
-
### 6.1 Testing Event Collection
|
|
412
|
-
|
|
413
|
-
```typescript
|
|
414
|
-
describe('Event emission verification', () => {
|
|
415
|
-
it('should collect events from concurrent operations', async () => {
|
|
416
|
-
const events: string[] = [];
|
|
417
|
-
|
|
418
|
-
const results = await Promise.allSettled([
|
|
419
|
-
emitEvent('start', events),
|
|
420
|
-
emitEvent('middle', events),
|
|
421
|
-
emitEvent('end', events)
|
|
422
|
-
]);
|
|
423
|
-
|
|
424
|
-
expect(events).toHaveLength(3);
|
|
425
|
-
expect(events).toContain('start');
|
|
426
|
-
expect(events).toContain('middle');
|
|
427
|
-
expect(events).toContain('end');
|
|
428
|
-
});
|
|
429
|
-
});
|
|
430
|
-
|
|
431
|
-
async function emitEvent(name: string, events: string[]): Promise<void> {
|
|
432
|
-
await Promise.resolve();
|
|
433
|
-
events.push(name);
|
|
434
|
-
}
|
|
435
|
-
```
|
|
436
|
-
|
|
437
|
-
### 6.2 Verifying Event Ordering
|
|
438
|
-
|
|
439
|
-
```typescript
|
|
440
|
-
describe('Event ordering verification', () => {
|
|
441
|
-
it('should maintain event order across concurrent operations', async () => {
|
|
442
|
-
const events: { timestamp: number; name: string }[] = [];
|
|
443
|
-
|
|
444
|
-
await Promise.allSettled([
|
|
445
|
-
recordEvent('event1', events),
|
|
446
|
-
recordEvent('event2', events),
|
|
447
|
-
recordEvent('event3', events)
|
|
448
|
-
]);
|
|
449
|
-
|
|
450
|
-
// Verify events were recorded in order
|
|
451
|
-
const timestamps = events.map(e => e.timestamp);
|
|
452
|
-
const sortedTimestamps = [...timestamps].sort((a, b) => a - b);
|
|
453
|
-
|
|
454
|
-
expect(timestamps).toEqual(sortedTimestamps);
|
|
455
|
-
});
|
|
456
|
-
});
|
|
457
|
-
|
|
458
|
-
async function recordEvent(name: string, events: any[]): Promise<void> {
|
|
459
|
-
events.push({ timestamp: Date.now(), name });
|
|
460
|
-
await Promise.resolve();
|
|
461
|
-
}
|
|
462
|
-
```
|
|
463
|
-
|
|
464
|
-
### 6.3 Error Event Verification
|
|
465
|
-
|
|
466
|
-
```typescript
|
|
467
|
-
describe('Error event verification', () => {
|
|
468
|
-
it('should emit error events for failed operations', async () => {
|
|
469
|
-
const errorEvents: Error[] = [];
|
|
470
|
-
|
|
471
|
-
const results = await Promise.allSettled([
|
|
472
|
-
Promise.resolve('success'),
|
|
473
|
-
Promise.reject(new Error('Operation failed')).catch(e => {
|
|
474
|
-
errorEvents.push(e);
|
|
475
|
-
throw e;
|
|
476
|
-
})
|
|
477
|
-
]);
|
|
478
|
-
|
|
479
|
-
expect(errorEvents).toHaveLength(1);
|
|
480
|
-
expect(errorEvents[0].message).toBe('Operation failed');
|
|
481
|
-
});
|
|
482
|
-
});
|
|
483
|
-
```
|
|
484
|
-
|
|
485
|
-
---
|
|
486
|
-
|
|
487
|
-
## 7. Best Practices Summary
|
|
488
|
-
|
|
489
|
-
### 7.1 Test Organization
|
|
490
|
-
|
|
491
|
-
1. **Group related tests with `describe` blocks**
|
|
492
|
-
- Organize by feature or functionality
|
|
493
|
-
- Use nested describes for hierarchical testing
|
|
494
|
-
|
|
495
|
-
2. **Use descriptive test names**
|
|
496
|
-
- Test names should describe what is being tested
|
|
497
|
-
- Include the expected outcome
|
|
498
|
-
|
|
499
|
-
3. **Follow AAA pattern** (Arrange, Act, Assert)
|
|
500
|
-
```typescript
|
|
501
|
-
it('should handle error correctly', async () => {
|
|
502
|
-
// Arrange
|
|
503
|
-
const error = new Error('Test error');
|
|
504
|
-
|
|
505
|
-
// Act
|
|
506
|
-
const result = await Promise.allSettled([
|
|
507
|
-
Promise.reject(error)
|
|
508
|
-
]);
|
|
509
|
-
|
|
510
|
-
// Assert
|
|
511
|
-
expect(result[0].status).toBe('rejected');
|
|
512
|
-
});
|
|
513
|
-
```
|
|
514
|
-
|
|
515
|
-
### 7.2 Async Testing Best Practices
|
|
516
|
-
|
|
517
|
-
1. **Always use async/await for async operations**
|
|
518
|
-
```typescript
|
|
519
|
-
it('good - using async/await', async () => {
|
|
520
|
-
const result = await fetchData();
|
|
521
|
-
expect(result).toBeDefined();
|
|
522
|
-
});
|
|
523
|
-
```
|
|
524
|
-
|
|
525
|
-
2. **Use `.resolves` and `.rejects` for promise assertions**
|
|
526
|
-
```typescript
|
|
527
|
-
await expect(promise).resolves.toBe(value);
|
|
528
|
-
await expect(promise).rejects.toThrow(error);
|
|
529
|
-
```
|
|
530
|
-
|
|
531
|
-
3. **Return promises when not using async/await**
|
|
532
|
-
```typescript
|
|
533
|
-
it('good - returning promise', () => {
|
|
534
|
-
return fetchData().then(result => {
|
|
535
|
-
expect(result).toBeDefined();
|
|
536
|
-
});
|
|
537
|
-
});
|
|
538
|
-
```
|
|
539
|
-
|
|
540
|
-
### 7.3 Mocking Best Practices
|
|
541
|
-
|
|
542
|
-
1. **Use `vi.spyOn()` for existing functions**
|
|
543
|
-
```typescript
|
|
544
|
-
const consoleSpy = vi.spyOn(console, 'log').mockImplementation(() => {});
|
|
545
|
-
// test code
|
|
546
|
-
consoleSpy.mockRestore();
|
|
547
|
-
```
|
|
548
|
-
|
|
549
|
-
2. **Use `vi.fn()` for new mock functions**
|
|
550
|
-
```typescript
|
|
551
|
-
const mockFn = vi.fn().mockResolvedValue('result');
|
|
552
|
-
```
|
|
553
|
-
|
|
554
|
-
3. **Always restore mocks in cleanup**
|
|
555
|
-
```typescript
|
|
556
|
-
afterEach(() => {
|
|
557
|
-
vi.restoreAllMocks();
|
|
558
|
-
});
|
|
559
|
-
```
|
|
560
|
-
|
|
561
|
-
### 7.4 Concurrent Testing Best Practices
|
|
562
|
-
|
|
563
|
-
1. **Test with mixed success/failure scenarios**
|
|
564
|
-
```typescript
|
|
565
|
-
const results = await Promise.allSettled([
|
|
566
|
-
Promise.resolve('success'),
|
|
567
|
-
Promise.reject(new Error('failure'))
|
|
568
|
-
]);
|
|
569
|
-
```
|
|
570
|
-
|
|
571
|
-
2. **Verify all operations complete**
|
|
572
|
-
```typescript
|
|
573
|
-
expect(results).toHaveLength(expectedCount);
|
|
574
|
-
```
|
|
575
|
-
|
|
576
|
-
3. **Validate error collection**
|
|
577
|
-
```typescript
|
|
578
|
-
const errors = results
|
|
579
|
-
.filter(r => r.status === 'rejected')
|
|
580
|
-
.map(r => r.reason);
|
|
581
|
-
|
|
582
|
-
expect(errors).toHaveLength(expectedErrorCount);
|
|
583
|
-
```
|
|
584
|
-
|
|
585
|
-
4. **Use type guards for type safety**
|
|
586
|
-
```typescript
|
|
587
|
-
const fulfilled = results.filter(
|
|
588
|
-
(r): r is PromiseFulfilledResult<T> => r.status === 'fulfilled'
|
|
589
|
-
);
|
|
590
|
-
```
|
|
591
|
-
|
|
592
|
-
---
|
|
593
|
-
|
|
594
|
-
## 8. Real-World Patterns from Groundswell
|
|
595
|
-
|
|
596
|
-
### 8.1 Current Test Patterns in Groundswell
|
|
597
|
-
|
|
598
|
-
Based on analysis of `/home/dustin/projects/groundswell/src/__tests__/`:
|
|
599
|
-
|
|
600
|
-
**Location:** `/home/dustin/projects/groundswell/src/__tests__/unit/decorators.test.ts`
|
|
601
|
-
|
|
602
|
-
```typescript
|
|
603
|
-
describe('@Step decorator', () => {
|
|
604
|
-
it('should wrap errors in WorkflowError', async () => {
|
|
605
|
-
class FailingWorkflow extends Workflow {
|
|
606
|
-
@Step()
|
|
607
|
-
async failingStep(): Promise<void> {
|
|
608
|
-
throw new Error('Step failed');
|
|
609
|
-
}
|
|
610
|
-
|
|
611
|
-
async run(): Promise<void> {
|
|
612
|
-
await this.failingStep();
|
|
613
|
-
}
|
|
614
|
-
}
|
|
615
|
-
|
|
616
|
-
const wf = new FailingWorkflow();
|
|
617
|
-
|
|
618
|
-
await expect(wf.run()).rejects.toMatchObject({
|
|
619
|
-
message: 'Step failed',
|
|
620
|
-
workflowId: wf.id,
|
|
621
|
-
});
|
|
622
|
-
});
|
|
623
|
-
});
|
|
624
|
-
```
|
|
625
|
-
|
|
626
|
-
### 8.2 Event Testing Pattern
|
|
627
|
-
|
|
628
|
-
**Location:** `/home/dustin/projects/groundswell/src/__tests__/unit/decorators.test.ts`
|
|
629
|
-
|
|
630
|
-
```typescript
|
|
631
|
-
it('should emit stepStart and stepEnd events', async () => {
|
|
632
|
-
const wf = new StepTestWorkflow();
|
|
633
|
-
const events: WorkflowEvent[] = [];
|
|
634
|
-
|
|
635
|
-
wf.addObserver({
|
|
636
|
-
onLog: () => {},
|
|
637
|
-
onEvent: (e) => events.push(e),
|
|
638
|
-
onStateUpdated: () => {},
|
|
639
|
-
onTreeChanged: () => {},
|
|
640
|
-
});
|
|
641
|
-
|
|
642
|
-
await wf.run();
|
|
643
|
-
|
|
644
|
-
const startEvent = events.find((e) => e.type === 'stepStart');
|
|
645
|
-
const endEvent = events.find((e) => e.type === 'stepEnd');
|
|
646
|
-
|
|
647
|
-
expect(startEvent).toBeDefined();
|
|
648
|
-
expect(endEvent).toBeDefined();
|
|
649
|
-
});
|
|
650
|
-
```
|
|
651
|
-
|
|
652
|
-
### 8.3 Async Error Handling Pattern
|
|
653
|
-
|
|
654
|
-
**Common pattern across Groundswell tests:**
|
|
655
|
-
|
|
656
|
-
```typescript
|
|
657
|
-
await expect(workflow.run()).rejects.toThrow('Test error from step');
|
|
658
|
-
await expect(workflow.run()).rejects.toMatchObject({
|
|
659
|
-
message: 'Error message',
|
|
660
|
-
workflowId: workflow.id,
|
|
661
|
-
});
|
|
662
|
-
```
|
|
663
|
-
|
|
664
|
-
### 8.4 Vitest Configuration
|
|
665
|
-
|
|
666
|
-
**Location:** `/home/dustin/projects/groundswell/vitest.config.ts`
|
|
667
|
-
|
|
668
|
-
```typescript
|
|
669
|
-
import { defineConfig } from 'vitest/config';
|
|
670
|
-
|
|
671
|
-
export default defineConfig({
|
|
672
|
-
test: {
|
|
673
|
-
include: ['src/__tests__/**/*.test.ts'],
|
|
674
|
-
globals: true,
|
|
675
|
-
},
|
|
676
|
-
resolve: {
|
|
677
|
-
alias: {
|
|
678
|
-
// Handle .js extensions in imports for TypeScript files
|
|
679
|
-
},
|
|
680
|
-
},
|
|
681
|
-
esbuild: {
|
|
682
|
-
target: 'node18',
|
|
683
|
-
},
|
|
684
|
-
});
|
|
685
|
-
```
|
|
686
|
-
|
|
687
|
-
---
|
|
688
|
-
|
|
689
|
-
## 9. Testing Checklist for Promise.allSettled Implementation
|
|
690
|
-
|
|
691
|
-
### 9.1 Core Functionality Tests
|
|
692
|
-
|
|
693
|
-
- [ ] All operations complete regardless of success/failure
|
|
694
|
-
- [ ] Results array matches input promise order
|
|
695
|
-
- [ ] Status is correctly set ('fulfilled' or 'rejected')
|
|
696
|
-
- [ ] Values are preserved for fulfilled promises
|
|
697
|
-
- [ ] Reasons are preserved for rejected promises
|
|
698
|
-
|
|
699
|
-
### 9.2 Error Collection Tests
|
|
700
|
-
|
|
701
|
-
- [ ] All errors are collected from rejected promises
|
|
702
|
-
- [ ] Error objects maintain their structure
|
|
703
|
-
- [ ] Error stack traces are preserved
|
|
704
|
-
- [ ] Error messages are accessible
|
|
705
|
-
- [ ] Custom error objects are handled correctly
|
|
706
|
-
|
|
707
|
-
### 9.3 Concurrent Execution Tests
|
|
708
|
-
|
|
709
|
-
- [ ] Operations run concurrently (not sequentially)
|
|
710
|
-
- [ ] All operations complete even if some fail
|
|
711
|
-
- [ ] No race conditions in result collection
|
|
712
|
-
- [ ] Result order is maintained regardless of completion time
|
|
713
|
-
|
|
714
|
-
### 9.4 Integration Tests
|
|
715
|
-
|
|
716
|
-
- [ ] Event emissions occur for all operations
|
|
717
|
-
- [ ] Logs are collected from all operations
|
|
718
|
-
- [ ] State snapshots are captured for failures
|
|
719
|
-
- [ ] Error aggregation works in production scenarios
|
|
720
|
-
|
|
721
|
-
### 9.5 Edge Cases
|
|
722
|
-
|
|
723
|
-
- [ ] Empty promise array
|
|
724
|
-
- [ ] All promises fail
|
|
725
|
-
- [ ] All promises succeed
|
|
726
|
-
- [ ] Mixed error types
|
|
727
|
-
- [ ] Rejected promises with undefined reasons
|
|
728
|
-
|
|
729
|
-
---
|
|
730
|
-
|
|
731
|
-
## 10. Recommended Test File Structure
|
|
732
|
-
|
|
733
|
-
```typescript
|
|
734
|
-
import { describe, it, expect, beforeEach, afterEach, vi } from 'vitest';
|
|
735
|
-
import { Workflow, Task, Step } from '../../index.js';
|
|
736
|
-
|
|
737
|
-
describe('Promise.allSettled in @Task decorator', () => {
|
|
738
|
-
describe('Concurrent execution', () => {
|
|
739
|
-
describe('Basic functionality', () => {
|
|
740
|
-
it('should execute all workflows concurrently', async () => {
|
|
741
|
-
// Test implementation
|
|
742
|
-
});
|
|
743
|
-
|
|
744
|
-
it('should complete all operations regardless of failures', async () => {
|
|
745
|
-
// Test implementation
|
|
746
|
-
});
|
|
747
|
-
});
|
|
748
|
-
|
|
749
|
-
describe('Error collection', () => {
|
|
750
|
-
it('should collect all errors from failed workflows', async () => {
|
|
751
|
-
// Test implementation
|
|
752
|
-
});
|
|
753
|
-
|
|
754
|
-
it('should preserve error details', async () => {
|
|
755
|
-
// Test implementation
|
|
756
|
-
});
|
|
757
|
-
});
|
|
758
|
-
|
|
759
|
-
describe('Event emission', () => {
|
|
760
|
-
it('should emit events for all workflows', async () => {
|
|
761
|
-
// Test implementation
|
|
762
|
-
});
|
|
763
|
-
|
|
764
|
-
it('should maintain event order', async () => {
|
|
765
|
-
// Test implementation
|
|
766
|
-
});
|
|
767
|
-
});
|
|
768
|
-
|
|
769
|
-
describe('State management', () => {
|
|
770
|
-
it('should capture state for all workflows', async () => {
|
|
771
|
-
// Test implementation
|
|
772
|
-
});
|
|
773
|
-
|
|
774
|
-
it('should handle partial failures gracefully', async () => {
|
|
775
|
-
// Test implementation
|
|
776
|
-
});
|
|
777
|
-
});
|
|
778
|
-
});
|
|
779
|
-
});
|
|
780
|
-
```
|
|
781
|
-
|
|
782
|
-
---
|
|
783
|
-
|
|
784
|
-
## Additional Resources
|
|
785
|
-
|
|
786
|
-
### Community Resources
|
|
787
|
-
|
|
788
|
-
- **Vitest GitHub Discussions**: https://github.com/vitest-dev/vitest/discussions
|
|
789
|
-
- **Stack Overflow [vitest tag]**: https://stackoverflow.com/questions/tagged/vitest
|
|
790
|
-
- **Vitest Awesome List**: https://github.com/vitest-dev/vitest/issues
|
|
791
|
-
|
|
792
|
-
### Related Documentation
|
|
793
|
-
|
|
794
|
-
- **Testing Library**: https://testing-library.com/
|
|
795
|
-
- **JavaScript Promises**: https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Promise
|
|
796
|
-
- **TypeScript Promise Types**: https://www.typescriptlang.org/docs/handbook/2/types-from-types.html#promise-types
|
|
797
|
-
|
|
798
|
-
---
|
|
799
|
-
|
|
800
|
-
**Document Version:** 1.0
|
|
801
|
-
**Last Updated:** 2026-01-12
|
|
802
|
-
**Maintained By:** P1.M2.T1.S3 Research Team
|