claude-flow-novice 2.5.2 → 2.8.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.
- package/.claude/adaptive-context/cfn-v3-reflection.json +21 -0
- package/.claude/agents/AGENT_LIFECYCLE.md +495 -0
- package/.claude/agents/CLAUDE.md +1002 -1233
- package/.claude/agents/accessibility-advocate.md +457 -0
- package/.claude/agents/agent-principles/README.md +226 -226
- package/.claude/agents/agent-principles/agent-type-guidelines.md +10 -0
- package/.claude/agents/agent-principles/format-selection.md +10 -0
- package/.claude/agents/agent-principles/phase4-template-optimization.md +502 -494
- package/.claude/agents/agent-principles/prompt-engineering.md +8 -0
- package/.claude/agents/agent-principles/quality-metrics.md +8 -0
- package/.claude/agents/analysis/code-analyzer.md +7 -17
- package/.claude/agents/analysis/code-review/analyze-code-quality.md +2 -104
- package/.claude/agents/analysis/perf-analyzer.md +2 -196
- package/.claude/agents/context/context-curator.md +78 -84
- package/.claude/agents/context/context-reflector.md +27 -81
- package/.claude/agents/coordinators/README.md +42 -0
- package/.claude/agents/coordinators/cfn-v3-coordinator.md +440 -0
- package/.claude/agents/{product-owner-team → coordinators}/cto-agent.md +154 -187
- package/.claude/agents/coordinators/multi-sprint-coordinator.md +50 -0
- package/.claude/agents/{product-owner-team → coordinators}/product-owner-agent.md +6 -39
- package/.claude/agents/{cfn-loop → coordinators}/product-owner.md +72 -17
- package/.claude/agents/core-agents/reviewer.md +114 -135
- package/.claude/agents/custom/agent-builder.md +637 -0
- package/.claude/agents/developers/README.md +69 -0
- package/.claude/agents/developers/backend-dev.md +77 -0
- package/.claude/agents/{core-agents → developers}/coder.md +131 -26
- package/.claude/agents/developers/react-frontend-engineer.md +121 -0
- package/.claude/agents/{frontend → developers}/state-architect.md +1 -0
- package/.claude/agents/{frontend → developers}/ui-designer.md +1 -0
- package/.claude/agents/development/backend/dev-backend-api.md +0 -29
- package/.claude/agents/development/npm-package-specialist.md +355 -347
- package/.claude/agents/documentation/api-docs/docs-api-openapi.md +8 -0
- package/.claude/agents/documentation/api-docs.md +8 -0
- package/.claude/agents/github/github-commit-agent.md +125 -117
- package/.claude/agents/goal/goal-planner.md +8 -0
- package/.claude/agents/infrastructure/README.md +100 -0
- package/.claude/agents/{specialized → infrastructure}/devops-engineer.md +131 -150
- package/.claude/agents/planners/README.md +94 -0
- package/.claude/agents/{core-agents → planners}/analyst.md +1 -22
- package/.claude/agents/{planning-team → planners}/api-designer-persona.md +8 -0
- package/.claude/agents/{core-agents → planners}/architect.md +7 -20
- package/.claude/agents/{core-agents → planners}/planner.md +0 -21
- package/.claude/agents/{planning-team → planners}/security-architect-persona.md +8 -28
- package/.claude/agents/{planning-team → planners}/system-architect-persona.md +6 -38
- package/.claude/agents/{architecture → planners}/system-architect.md +12 -17
- package/.claude/agents/product-owner-team/accessibility-advocate-persona.md +132 -161
- package/.claude/agents/product-owner-team/power-user-persona.md +149 -182
- package/.claude/agents/retrospective-analyst.md +84 -0
- package/.claude/agents/reviewers/README.md +58 -0
- package/.claude/agents/{analysis → reviewers}/code-quality-validator.md +8 -17
- package/.claude/agents/reviewers/reviewer.md +181 -0
- package/.claude/agents/sparc/architecture.md +6 -25
- package/.claude/agents/sparc/pseudocode.md +6 -0
- package/.claude/agents/sparc/refinement.md +6 -0
- package/.claude/agents/sparc/specification.md +1 -0
- package/.claude/agents/specialists/README.md +60 -0
- package/.claude/agents/{core-agents → specialists}/base-template-generator.md +8 -21
- package/.claude/agents/{specialized → specialists}/cli-agent-optimizer.md +1 -1
- package/.claude/agents/{specialized → specialists}/code-booster.md +1 -0
- package/.claude/agents/{consensus → specialists}/consensus-builder.md +1 -17
- package/.claude/agents/{specialized/mobile → specialists}/mobile-dev.md +0 -20
- package/.claude/agents/{core-agents → specialists}/performance-benchmarker.md +134 -148
- package/.claude/agents/{specialized → specialists}/rust-developer.md +1 -20
- package/.claude/agents/{specialized → specialists}/rust-enterprise-developer.md +1 -20
- package/.claude/agents/{specialized → specialists}/rust-mvp-developer.md +1 -20
- package/.claude/agents/{core-agents → specialists}/security-manager.md +68 -88
- package/.claude/agents/{security → specialists}/security-specialist-existing.md +6 -57
- package/.claude/agents/{security → specialists}/security-specialist.md +6 -30
- package/.claude/agents/{specialized/mobile → specialists}/spec-mobile-react-native.md +2 -21
- package/.claude/agents/testers/README.md +94 -0
- package/.claude/agents/{testing → testers}/e2e/playwright-agent.md +1 -20
- package/.claude/agents/{testing → testers}/interaction-tester.md +1 -20
- package/.claude/agents/{testing → testers}/playwright-tester.md +1 -1
- package/.claude/agents/testers/tester.md +139 -0
- package/.claude/agents/testers/unit/tdd-london-swarm.md +49 -0
- package/.claude/agents/testers/validation/production-validator.md +33 -0
- package/.claude/agents-ignore/cfn-loop-coordinator.md +157 -0
- package/.claude/agents-ignore/cfn-loop-coordinator.md.backup +156 -0
- package/.claude/agents-ignore/coordinator.md.backup +182 -0
- package/.claude/agents-ignore/cost-savings-cfn-loop-coordinator.md +760 -0
- package/.claude/agents-ignore/cost-savings-coordinator.md +173 -0
- package/.claude/artifacts/ace-reflections/REFLECT-001-summary.json +39 -0
- package/.claude/artifacts/ace-reflections/sprint-7_$(date -u +/"%Y%m%d_%H%M%S/").json" +47 -0
- package/.claude/artifacts/reflection-merge-logs/cli-agent-spawning-v2.5.2-merge-report.md +61 -0
- package/.claude/commands/CFN_COORDINATOR_PARAMETERS.md +10 -10
- package/.claude/commands/cfn-loop-epic.md +43 -19
- package/.claude/commands/cfn-loop-single.md +3 -3
- package/.claude/commands/cfn-loop-sprints.md +1 -1
- package/.claude/commands/cfn-loop.md +45 -32
- package/.claude/commands/cfn-mode.md +20 -0
- package/.claude/commands/custom-routing-activate.md +37 -123
- package/.claude/commands/custom-routing-deactivate.md +27 -124
- package/.claude/commands/switch-api.md +41 -16
- package/.claude/commands/write-plan.md +104 -0
- package/.claude/data/cfn-loop.db +0 -0
- package/.claude/data/cfn_loop_logs.db +0 -0
- package/.claude/hooks/BACKUP_USAGE.md +243 -0
- package/.claude/hooks/post-edit-cfn-retrospective.sh +79 -0
- package/.claude/hooks/post-edit.sh +21 -0
- package/.claude/hooks/pre-edit-backup.sh +71 -0
- package/.claude/hooks/restore-from-backup.sh +37 -0
- package/.claude/prompts/cfn-loop-context.md +115 -0
- package/.claude/prompts/loop-specific/loop2.md +50 -0
- package/.claude/prompts/loop-specific/loop3.md +43 -0
- package/.claude/prompts/loop-specific/loop4.md +54 -0
- package/.claude/root-claude-distribute/CLAUDE.md +76 -2
- package/.claude/skills/ace-system/sprint-7-lessons.json +46 -0
- package/.claude/skills/ace-system/store-reflection.sh +33 -136
- package/.claude/skills/agent-discovery/SKILL.md +40 -0
- package/.claude/skills/agent-discovery/agents-registry-clean.json +0 -0
- package/.claude/skills/agent-discovery/agents-registry-fixed.json +19 -0
- package/.claude/skills/agent-discovery/agents-registry.json +718 -0
- package/.claude/skills/agent-discovery/discover-agents.py +175 -0
- package/.claude/skills/agent-discovery/discover-agents.sh +87 -0
- package/.claude/skills/agent-discovery/invoke-registry.sh +11 -0
- package/.claude/skills/agent-discovery/temp_script.py +0 -0
- package/.claude/skills/agent-execution/execute-agent.sh +126 -0
- package/.claude/skills/agent-output-processing/SKILL.md +359 -0
- package/.claude/skills/agent-selector/SKILL.md +90 -0
- package/.claude/skills/agent-selector/select-agents.sh +96 -0
- package/.claude/skills/agent-spawning/agent-selection-guide.md +1 -1
- package/.claude/skills/agent-swap/SKILL.md +36 -0
- package/.claude/skills/agent-swap/recommend-swap.sh +60 -0
- package/.claude/skills/api-validation/test-endpoints.sh +54 -0
- package/.claude/skills/automatic-memory-persistence/SKILL.md +73 -0
- package/.claude/skills/automatic-memory-persistence/persist-agent-output.sh +49 -0
- package/.claude/skills/automatic-memory-persistence/query-agent-history.sh +35 -0
- package/.claude/skills/automatic-memory-persistence/test-memory-persistence.sh +235 -0
- package/.claude/skills/cfn-loop-orchestration/README.md +41 -0
- package/.claude/skills/cfn-loop-orchestration/SKILL.md +299 -0
- package/.claude/skills/cfn-loop-orchestration/helpers/auto-tune-timeouts.sh +228 -0
- package/.claude/skills/cfn-loop-orchestration/helpers/consensus.sh +84 -0
- package/.claude/skills/cfn-loop-orchestration/helpers/deliverable-verifier.sh +71 -0
- package/.claude/skills/cfn-loop-orchestration/helpers/gate-check.sh +90 -0
- package/.claude/skills/cfn-loop-orchestration/helpers/iteration-manager.sh +87 -0
- package/.claude/skills/cfn-loop-orchestration/helpers/timeout-calculator.sh +51 -0
- package/.claude/skills/cfn-loop-orchestration/inject-loop-context.sh +41 -0
- package/.claude/skills/cfn-loop-orchestration/monitor-execution.sh +156 -0
- package/.claude/skills/cfn-loop-orchestration/orchestrate.sh +840 -0
- package/.claude/skills/cfn-loop-orchestration/security_utils.sh +99 -0
- package/.claude/skills/cfn-loop-orchestration/test-cfn-orchestration.sh +281 -0
- package/.claude/skills/cfn-loop-orchestration/test-edge-cases.sh +188 -0
- package/.claude/skills/cfn-loop-validation/SKILL.md +307 -217
- package/.claude/skills/complexity-estimator/SKILL.md +96 -0
- package/.claude/skills/complexity-estimator/estimate-complexity.sh +144 -0
- package/.claude/skills/context-pruner/SKILL.md +75 -0
- package/.claude/skills/context-pruner/prune-context.sh +73 -0
- package/.claude/skills/defense-in-depth/SKILL.md +133 -0
- package/.claude/skills/dependency-extractor/SKILL.md +35 -0
- package/.claude/skills/dependency-extractor/extract-dependencies.sh +66 -0
- package/.claude/skills/epic-decomposer/SKILL.md +44 -0
- package/.claude/skills/epic-decomposer/decompose-epic.sh +104 -0
- package/.claude/skills/improvement-recommender/SKILL.md +33 -0
- package/.claude/skills/improvement-recommender/recommend-improvements.sh +92 -0
- package/.claude/skills/intervention-detector/SKILL.md +39 -0
- package/.claude/skills/intervention-detector/detect-intervention.sh +111 -0
- package/.claude/skills/intervention-orchestrator/SKILL.md +43 -0
- package/.claude/skills/intervention-orchestrator/execute-intervention.sh +59 -0
- package/.claude/skills/loop2-output-processing/SKILL.md +163 -0
- package/.claude/skills/loop2-output-processing/execute-and-extract.sh +77 -0
- package/.claude/skills/loop2-output-processing/execute-and-extract.sh.backup +36 -0
- package/.claude/skills/loop2-output-processing/parse-feedback.sh +147 -0
- package/.claude/skills/loop2-output-processing/process-validator-output.sh +275 -0
- package/.claude/skills/loop2-output-processing/test-bug27-fix.sh +200 -0
- package/.claude/skills/loop2-output-processing/test-loop2-processing.sh +113 -0
- package/.claude/skills/loop3-output-processing/AGENT_COMPLETION_PROTOCOL.md +206 -0
- package/.claude/skills/loop3-output-processing/SKILL.md +421 -0
- package/.claude/skills/loop3-output-processing/calculate-confidence.sh +28 -0
- package/.claude/skills/loop3-output-processing/execute-and-extract.sh +85 -0
- package/.claude/skills/loop3-output-processing/parse-confidence.sh +31 -0
- package/.claude/skills/loop3-output-processing/test-agent-timeout.sh +327 -0
- package/.claude/skills/loop3-output-processing/test-loop3-processing.sh +155 -0
- package/.claude/skills/loop3-output-processing/verify-deliverables.sh +42 -0
- package/.claude/skills/pattern-extraction/SKILL.md +30 -0
- package/.claude/skills/pattern-extraction/extract-patterns.sh +80 -0
- package/.claude/skills/playbook/SKILL.md +113 -0
- package/.claude/skills/playbook/init-playbook.sh +54 -0
- package/.claude/skills/playbook/playbook.db +0 -0
- package/.claude/skills/playbook/query-playbook.sh +79 -0
- package/.claude/skills/playbook/update-playbook.sh +69 -0
- package/.claude/skills/playbook-auto-update/SKILL.md +29 -0
- package/.claude/skills/playbook-auto-update/auto-update-playbook.sh +86 -0
- package/.claude/skills/product-owner-decision/SKILL.md +332 -0
- package/.claude/skills/product-owner-decision/execute-decision.sh +176 -0
- package/.claude/skills/product-owner-decision/parse-decision.sh +66 -0
- package/.claude/skills/product-owner-decision/validate-deliverables.sh +82 -0
- package/.claude/skills/redis-coordination/AGENT_LOGGING.md +280 -0
- package/.claude/skills/redis-coordination/LOGGING.md +260 -0
- package/.claude/skills/redis-coordination/README.md +30 -29
- package/.claude/skills/redis-coordination/SKILL.md +685 -83
- package/.claude/skills/redis-coordination/agent-log.sh +124 -0
- package/.claude/skills/redis-coordination/analyze-task-complexity.sh +277 -0
- package/.claude/skills/redis-coordination/cfn-loop-exec.sh +468 -0
- package/.claude/skills/redis-coordination/collect-confidence-scores.sh +179 -0
- package/.claude/skills/redis-coordination/collect-results.sh +75 -0
- package/.claude/skills/redis-coordination/data/cfn-loop.db +0 -0
- package/.claude/skills/redis-coordination/demos/test-iteration-feedback.sh +320 -0
- package/.claude/skills/redis-coordination/{test-orchestrator.sh → demos/test-orchestrator.sh} +25 -0
- package/.claude/skills/redis-coordination/execute-product-owner-decision.sh +258 -0
- package/.claude/skills/redis-coordination/get-agent-timeout.sh +176 -176
- package/.claude/skills/redis-coordination/init-swarm.sh +6 -1
- package/.claude/skills/redis-coordination/invoke-waiting-mode.sh +106 -183
- package/.claude/skills/redis-coordination/invoke-waiting-mode.sh.backup-p7 +423 -0
- package/.claude/skills/redis-coordination/log-event.sh +109 -0
- package/.claude/skills/redis-coordination/monitor-cfn-violations.sh +391 -0
- package/.claude/skills/redis-coordination/orchestrate-cfn-loop-v3.sh +141 -0
- package/.claude/skills/redis-coordination/orchestrate-cfn-loop.sh +31 -933
- package/.claude/skills/redis-coordination/orchestrate-cfn-loop.sh.backup +38 -0
- package/.claude/skills/redis-coordination/orchestrate-cfn-loop.sh.backup-1761167675 +1672 -0
- package/.claude/skills/redis-coordination/orchestrate-cfn-loop.sh.backup-p5 +1604 -0
- package/.claude/skills/redis-coordination/orchestrate-cfn-loop.sh.backup-phase1 +1550 -0
- package/.claude/skills/redis-coordination/orchestrate-cfn-loop.sh.backup-phase2 +1621 -0
- package/.claude/skills/redis-coordination/orchestrate-cfn-loop.sh.backup-phase3 +1621 -0
- package/.claude/skills/redis-coordination/orchestrate-cfn-loop.sh.bak +0 -0
- package/.claude/skills/redis-coordination/orchestrate-cfn-loop.sh.broken +1627 -0
- package/.claude/skills/redis-coordination/orchestrate-cfn-loop.sh.corrupted +80 -0
- package/.claude/skills/redis-coordination/orchestrate-cfn-loop.sh.deprecated +1864 -0
- package/.claude/skills/redis-coordination/query-logs.sh +103 -0
- package/.claude/skills/redis-coordination/retrieve-context.sh +58 -0
- package/.claude/skills/redis-coordination/select-specialist-agent.sh +371 -0
- package/.claude/skills/redis-coordination/semantic-match-tfidf.py +252 -0
- package/.claude/skills/redis-coordination/send-heartbeat.sh +164 -72
- package/.claude/skills/redis-coordination/signal.sh +38 -0
- package/.claude/skills/redis-coordination/store-context.sh +86 -0
- package/.claude/skills/redis-coordination/store-epic-context.sh +123 -0
- package/.claude/skills/redis-coordination/test-context-injection.sh +354 -0
- package/.claude/skills/redis-coordination/test-timeout-enforcement.sh +513 -0
- package/.claude/skills/redis-coordination/tests/convert-line-endings.sh +15 -0
- package/.claude/skills/redis-coordination/tests/dlq-functionality-test.sh +101 -101
- package/.claude/skills/redis-coordination/tests/edge-cases-test.sh +98 -98
- package/.claude/skills/redis-coordination/tests/integration-test.sh +169 -169
- package/.claude/skills/redis-coordination/tests/retry-mechanism-test.sh +81 -81
- package/.claude/skills/redis-coordination/tests/run-test-suite.sh +91 -91
- package/.claude/skills/redis-coordination/tests/run-tests.sh +4 -0
- package/.claude/skills/redis-coordination/tests/test-primitives.sh +166 -0
- package/.claude/skills/redis-coordination/tests/test-utils.sh +53 -121
- package/.claude/skills/redis-coordination/tests/test_coordination_primitives.sh.deprecated +20 -0
- package/.claude/skills/redis-coordination/tests/test_utils.sh +49 -0
- package/.claude/skills/redis-coordination/v2_modularization/core_orchestration.sh +76 -0
- package/.claude/skills/redis-coordination/validate-parameters.sh +492 -0
- package/.claude/skills/retrospective-report/SKILL.md +31 -0
- package/.claude/skills/retrospective-report/generate-report.sh +101 -0
- package/.claude/skills/run-all-skill-tests.sh +124 -0
- package/.claude/skills/scope-simplifier/SKILL.md +37 -0
- package/.claude/skills/scope-simplifier/simplify-scope.sh +68 -0
- package/.claude/skills/simplified-agent-lifecycle/COST_ANALYSIS.md +49 -0
- package/.claude/skills/simplified-agent-lifecycle/DESIGN.md +98 -0
- package/.claude/skills/simplified-agent-lifecycle/MIGRATION_PLAN.md +74 -0
- package/.claude/skills/skill-builder/SKILL.md +910 -0
- package/.claude/skills/specialist-injection/SKILL.md +41 -0
- package/.claude/skills/specialist-injection/recommend-specialist.sh +57 -0
- package/.claude/skills/sprint-execution/SKILL.md +27 -0
- package/.claude/skills/sprint-execution/execute-sprint-task.sh +59 -0
- package/.claude/skills/sprint-execution/execute-sprint.sh +65 -0
- package/.claude/skills/sprint-planner/SKILL.md +37 -0
- package/.claude/skills/sprint-planner/plan-sprint.sh +85 -0
- package/.claude/skills/standardized-error-handling/SKILL.md +56 -0
- package/.claude/skills/standardized-error-handling/capture-agent-error.sh +87 -0
- package/.claude/skills/standardized-error-handling/test-error-handling.sh +166 -0
- package/.claude/skills/task-classifier/SKILL.md +94 -0
- package/.claude/skills/task-classifier/classify-task.sh +115 -0
- package/.claude/skills/validation-templates/SKILL.md +47 -0
- package/.claude/skills/validation-templates/content.json +38 -0
- package/.claude/skills/validation-templates/data.json +38 -0
- package/.claude/skills/validation-templates/design.json +38 -0
- package/.claude/skills/validation-templates/infrastructure.json +38 -0
- package/.claude/skills/validation-templates/research.json +38 -0
- package/.claude/skills/validation-templates/software.json +38 -0
- package/.claude/skills/webapp-testing/README.md +142 -0
- package/.claude/skills/webapp-testing/SCREENSHOT_NAMING_CONVENTION.md +547 -0
- package/.claude/skills/webapp-testing/SKILL.md +877 -0
- package/.claude/skills/webapp-testing/capture-screenshot.sh +238 -0
- package/.claude/skills/webapp-testing/cfn-loop-integration.sh +265 -0
- package/.claude/skills/webapp-testing/compare-screenshots.sh +199 -0
- package/.claude/skills/webapp-testing/init-storage.sh +150 -0
- package/.claude/skills/webapp-testing/set-baseline.sh +196 -0
- package/.claude/skills/webapp-testing/test-webapp-testing.sh +233 -0
- package/.claude/spawn-pattern-examples.md +3 -3
- package/CLAUDE.md +364 -16
- package/README.md +598 -251
- package/dist/agents/agent-loader.js +146 -165
- package/dist/agents/agent-loader.js.map +1 -1
- package/dist/cli/agent-command.js +153 -0
- package/dist/cli/agent-command.js.map +1 -0
- package/dist/cli/agent-definition-parser.js +183 -0
- package/dist/cli/agent-definition-parser.js.map +1 -0
- package/dist/cli/agent-executor.js +310 -0
- package/dist/cli/agent-executor.js.map +1 -0
- package/dist/cli/agent-prompt-builder.js +268 -0
- package/dist/cli/agent-prompt-builder.js.map +1 -0
- package/dist/cli/agent-spawn.js +56 -2
- package/dist/cli/agent-spawn.js.map +1 -1
- package/dist/cli/anthropic-client.js +421 -0
- package/dist/cli/anthropic-client.js.map +1 -0
- package/dist/cli/cfn-context.js +150 -0
- package/dist/cli/cfn-context.js.map +1 -1
- package/dist/cli/cfn-fork.js +159 -0
- package/dist/cli/cfn-fork.js.map +1 -0
- package/dist/cli/cli-agent-context.js +358 -0
- package/dist/cli/cli-agent-context.js.map +1 -0
- package/dist/cli/config-manager.js +109 -91
- package/dist/cli/config-manager.js.map +1 -1
- package/dist/cli/conversation-fork.js +201 -0
- package/dist/cli/conversation-fork.js.map +1 -0
- package/dist/cli/index.js +119 -2
- package/dist/cli/index.js.map +1 -1
- package/dist/cli/iteration-history.js +188 -0
- package/dist/cli/iteration-history.js.map +1 -0
- package/dist/cli/tool-definitions.js +263 -0
- package/dist/cli/tool-definitions.js.map +1 -0
- package/dist/cli/tool-executor.js +247 -0
- package/dist/cli/tool-executor.js.map +1 -0
- package/dist/hello.js +8 -0
- package/dist/hello.js.map +1 -0
- package/package.json +16 -6
- package/scripts/README.md +68 -0
- package/scripts/cfn-intervention-example.sh +21 -0
- package/scripts/migrate-test-infrastructure.sh +40 -0
- package/scripts/switch-api.sh +233 -0
- package/scripts/validate-test-migration.sh +49 -0
- package/scripts/verify-no-secrets.sh +55 -0
- package/.claude/agents/architecture/system-architect.md.backup +0 -603
- package/.claude/agents/code-booster.md +0 -131
- package/.claude/agents/consensus/performance-benchmarker.md +0 -101
- package/.claude/agents/consensus/security-manager.md +0 -107
- package/.claude/agents/context-curator.md +0 -167
- package/.claude/agents/context-reflector.md +0 -65
- package/.claude/agents/core-agents/cfn-loop-coordinator.md +0 -134
- package/.claude/agents/core-agents/code-quality-validator.md +0 -149
- package/.claude/agents/core-agents/context-curator.md +0 -452
- package/.claude/agents/core-agents/context-reflector.md +0 -273
- package/.claude/agents/core-agents/cost-savings-cfn-loop-coordinator.md +0 -190
- package/.claude/agents/core-agents/tester.md +0 -170
- package/.claude/agents/development/backend-dev.md +0 -165
- package/.claude/agents/devops/devops-engineer.md +0 -148
- package/.claude/agents/frontend/interaction-tester.md +0 -139
- package/.claude/agents/frontend/react-frontend-engineer.md +0 -9
- package/.claude/agents/personas/accessibility-advocate-persona.md +0 -107
- package/.claude/agents/testing/production-validator.md +0 -179
- package/.claude/agents/testing/tdd-london-swarm.md +0 -209
- package/.claude/agents/testing/unit/tdd-london-swarm.md +0 -43
- package/.claude/agents/testing/validation/production-validator.md +0 -43
- package/dist/coordination/fleet-manager.test.js +0 -141
- package/dist/coordination/fleet-manager.test.js.map +0 -1
- package/dist/middleware/transparency-middleware.test.js +0 -184
- package/dist/middleware/transparency-middleware.test.js.map +0 -1
- /package/.claude/agents/{core-agents → developers}/researcher.md +0 -0
- /package/.claude/agents/{consensus → specialists}/crdt-synchronizer.md +0 -0
- /package/.claude/agents/{consensus → specialists}/quorum-manager.md +0 -0
- /package/.claude/agents/{consensus → specialists}/raft-manager.md +0 -0
- /package/.claude/{agents/core-agents → agents-ignore}/coordinator.md +0 -0
- /package/.claude/{agents/core-agents/cost-savings-coordinator.md → agents-ignore/cost-savings-coordinator.md.backup} +0 -0
- /package/.claude/skills/redis-coordination/{phase4-wake-queue-test-report.md → demos/phase4-wake-queue-test-report.md} +0 -0
- /package/.claude/skills/redis-coordination/{test-bzpopmin-fix.sh → demos/test-bzpopmin-fix.sh} +0 -0
- /package/.claude/skills/redis-coordination/{test-cancel-swarm.sh → demos/test-cancel-swarm.sh} +0 -0
- /package/.claude/skills/redis-coordination/{test-dlq.sh → demos/test-dlq.sh} +0 -0
- /package/.claude/skills/redis-coordination/{test-priority-wake-phase4-unix.sh → demos/test-priority-wake-phase4-unix.sh} +0 -0
- /package/.claude/skills/redis-coordination/{test-priority-wake-phase4.sh → demos/test-priority-wake-phase4.sh} +0 -0
- /package/.claude/skills/redis-coordination/{test-priority-wake.sh → demos/test-priority-wake.sh} +0 -0
- /package/.claude/skills/redis-coordination/{test-quick-fix.sh → demos/test-quick-fix.sh} +0 -0
- /package/.claude/skills/redis-coordination/{test-quorum-absolute.sh → demos/test-quorum-absolute.sh} +0 -0
- /package/.claude/skills/redis-coordination/{test-quorum-fallback.sh → demos/test-quorum-fallback.sh} +0 -0
- /package/.claude/skills/redis-coordination/{test-quorum-percentage.sh → demos/test-quorum-percentage.sh} +0 -0
- /package/.claude/skills/redis-coordination/{test-quorum-with-retry.sh → demos/test-quorum-with-retry.sh} +0 -0
- /package/.claude/skills/redis-coordination/{test-quorum.sh → demos/test-quorum.sh} +0 -0
- /package/.claude/skills/redis-coordination/{test-shutdown-handling.sh → demos/test-shutdown-handling.sh} +0 -0
- /package/.claude/skills/redis-coordination/{test-shutdown.sh → demos/test-shutdown.sh} +0 -0
- /package/.claude/skills/redis-coordination/{test-utils-unix.sh → demos/test-utils-unix.sh} +0 -0
- /package/.claude/skills/redis-coordination/{test-utils.sh → demos/test-utils.sh} +0 -0
- /package/.claude/skills/redis-coordination/{test-waiting-mode.sh → demos/test-waiting-mode.sh} +0 -0
|
@@ -1,92 +1,92 @@
|
|
|
1
|
-
#!/bin/bash
|
|
2
|
-
# Master Test Runner for Redis Phase 1 Error Recovery & Resilience
|
|
3
|
-
|
|
4
|
-
set -euo pipefail
|
|
5
|
-
|
|
6
|
-
# Source test utilities
|
|
7
|
-
source "$(dirname "$0")/test-utils.sh"
|
|
8
|
-
|
|
9
|
-
# Test suites to run
|
|
10
|
-
test_suites=(
|
|
11
|
-
"./retry-mechanism-test.sh"
|
|
12
|
-
"./dlq-functionality-test.sh"
|
|
13
|
-
"./edge-cases-test.sh"
|
|
14
|
-
"./integration-test.sh"
|
|
15
|
-
)
|
|
16
|
-
|
|
17
|
-
# Global tracking
|
|
18
|
-
total_tests=0
|
|
19
|
-
passed_tests=0
|
|
20
|
-
failed_test_suites=()
|
|
21
|
-
|
|
22
|
-
# Run individual test suite
|
|
23
|
-
run_test_suite() {
|
|
24
|
-
local suite_path="$1"
|
|
25
|
-
local suite_name=$(basename "$suite_path")
|
|
26
|
-
|
|
27
|
-
echo "Running test suite: $suite_name"
|
|
28
|
-
|
|
29
|
-
set +e # Disable immediate exit on error
|
|
30
|
-
"$suite_path"
|
|
31
|
-
local exit_code=$?
|
|
32
|
-
set -e
|
|
33
|
-
|
|
34
|
-
if [ $exit_code -eq 0 ]; then
|
|
35
|
-
((passed_tests++))
|
|
36
|
-
echo "✅ $suite_name: PASSED"
|
|
37
|
-
else
|
|
38
|
-
failed_test_suites+=("$suite_name")
|
|
39
|
-
echo "❌ $suite_name: FAILED"
|
|
40
|
-
fi
|
|
41
|
-
|
|
42
|
-
((total_tests++))
|
|
43
|
-
}
|
|
44
|
-
|
|
45
|
-
# Main execution
|
|
46
|
-
main() {
|
|
47
|
-
echo "Starting Redis Phase 1 Error Recovery & Resilience Test Suite"
|
|
48
|
-
|
|
49
|
-
# Run all test suites
|
|
50
|
-
for suite in "${test_suites[@]}"; do
|
|
51
|
-
chmod +x "$suite"
|
|
52
|
-
run_test_suite "$suite"
|
|
53
|
-
done
|
|
54
|
-
|
|
55
|
-
# Calculate confidence
|
|
56
|
-
local confidence=$(compute_confidence_score "$passed_tests" "$total_tests")
|
|
57
|
-
|
|
58
|
-
# Report results
|
|
59
|
-
echo -e "\n--- Test Suite Summary ---"
|
|
60
|
-
echo "Total Test Suites: $total_tests"
|
|
61
|
-
echo "Passed: $passed_tests"
|
|
62
|
-
echo "Failed: $((total_tests - passed_tests))"
|
|
63
|
-
echo "Confidence Score: $confidence"
|
|
64
|
-
|
|
65
|
-
if [ ${#failed_test_suites[@]} -gt 0 ]; then
|
|
66
|
-
echo -e "\nFailed Test Suites:"
|
|
67
|
-
for failed_suite in "${failed_test_suites[@]}"; do
|
|
68
|
-
echo " - $failed_suite"
|
|
69
|
-
done
|
|
70
|
-
fi
|
|
71
|
-
|
|
72
|
-
# CFN Loop reporting
|
|
73
|
-
./.claude/skills/redis-coordination/invoke-waiting-mode.sh report \
|
|
74
|
-
--task-id "redis-phase1-1760875302" \
|
|
75
|
-
--agent-id "tester-1" \
|
|
76
|
-
--confidence "$confidence" \
|
|
77
|
-
--iteration 1
|
|
78
|
-
|
|
79
|
-
# Signal test completion
|
|
80
|
-
redis-cli lpush "swarm:redis-phase1-1760875302:tester-1:done" "complete"
|
|
81
|
-
|
|
82
|
-
# Enter waiting mode
|
|
83
|
-
./.claude/skills/redis-coordination/invoke-waiting-mode.sh enter \
|
|
84
|
-
--task-id "redis-phase1-1760875302" \
|
|
85
|
-
--agent-id "tester-1" \
|
|
86
|
-
--context "phase1-testing-complete"
|
|
87
|
-
|
|
88
|
-
# Ensure exit code reflects overall test success
|
|
89
|
-
[ $passed_tests -eq $total_tests ]
|
|
90
|
-
}
|
|
91
|
-
|
|
1
|
+
#!/bin/bash
|
|
2
|
+
# Master Test Runner for Redis Phase 1 Error Recovery & Resilience
|
|
3
|
+
|
|
4
|
+
set -euo pipefail
|
|
5
|
+
|
|
6
|
+
# Source test utilities
|
|
7
|
+
source "$(dirname "$0")/test-utils.sh"
|
|
8
|
+
|
|
9
|
+
# Test suites to run
|
|
10
|
+
test_suites=(
|
|
11
|
+
"./retry-mechanism-test.sh"
|
|
12
|
+
"./dlq-functionality-test.sh"
|
|
13
|
+
"./edge-cases-test.sh"
|
|
14
|
+
"./integration-test.sh"
|
|
15
|
+
)
|
|
16
|
+
|
|
17
|
+
# Global tracking
|
|
18
|
+
total_tests=0
|
|
19
|
+
passed_tests=0
|
|
20
|
+
failed_test_suites=()
|
|
21
|
+
|
|
22
|
+
# Run individual test suite
|
|
23
|
+
run_test_suite() {
|
|
24
|
+
local suite_path="$1"
|
|
25
|
+
local suite_name=$(basename "$suite_path")
|
|
26
|
+
|
|
27
|
+
echo "Running test suite: $suite_name"
|
|
28
|
+
|
|
29
|
+
set +e # Disable immediate exit on error
|
|
30
|
+
"$suite_path"
|
|
31
|
+
local exit_code=$?
|
|
32
|
+
set -e
|
|
33
|
+
|
|
34
|
+
if [ $exit_code -eq 0 ]; then
|
|
35
|
+
((passed_tests++))
|
|
36
|
+
echo "✅ $suite_name: PASSED"
|
|
37
|
+
else
|
|
38
|
+
failed_test_suites+=("$suite_name")
|
|
39
|
+
echo "❌ $suite_name: FAILED"
|
|
40
|
+
fi
|
|
41
|
+
|
|
42
|
+
((total_tests++))
|
|
43
|
+
}
|
|
44
|
+
|
|
45
|
+
# Main execution
|
|
46
|
+
main() {
|
|
47
|
+
echo "Starting Redis Phase 1 Error Recovery & Resilience Test Suite"
|
|
48
|
+
|
|
49
|
+
# Run all test suites
|
|
50
|
+
for suite in "${test_suites[@]}"; do
|
|
51
|
+
chmod +x "$suite"
|
|
52
|
+
run_test_suite "$suite"
|
|
53
|
+
done
|
|
54
|
+
|
|
55
|
+
# Calculate confidence
|
|
56
|
+
local confidence=$(compute_confidence_score "$passed_tests" "$total_tests")
|
|
57
|
+
|
|
58
|
+
# Report results
|
|
59
|
+
echo -e "\n--- Test Suite Summary ---"
|
|
60
|
+
echo "Total Test Suites: $total_tests"
|
|
61
|
+
echo "Passed: $passed_tests"
|
|
62
|
+
echo "Failed: $((total_tests - passed_tests))"
|
|
63
|
+
echo "Confidence Score: $confidence"
|
|
64
|
+
|
|
65
|
+
if [ ${#failed_test_suites[@]} -gt 0 ]; then
|
|
66
|
+
echo -e "\nFailed Test Suites:"
|
|
67
|
+
for failed_suite in "${failed_test_suites[@]}"; do
|
|
68
|
+
echo " - $failed_suite"
|
|
69
|
+
done
|
|
70
|
+
fi
|
|
71
|
+
|
|
72
|
+
# CFN Loop reporting
|
|
73
|
+
./.claude/skills/redis-coordination/invoke-waiting-mode.sh report \
|
|
74
|
+
--task-id "redis-phase1-1760875302" \
|
|
75
|
+
--agent-id "tester-1" \
|
|
76
|
+
--confidence "$confidence" \
|
|
77
|
+
--iteration 1
|
|
78
|
+
|
|
79
|
+
# Signal test completion
|
|
80
|
+
redis-cli lpush "swarm:redis-phase1-1760875302:tester-1:done" "complete"
|
|
81
|
+
|
|
82
|
+
# Enter waiting mode
|
|
83
|
+
./.claude/skills/redis-coordination/invoke-waiting-mode.sh enter \
|
|
84
|
+
--task-id "redis-phase1-1760875302" \
|
|
85
|
+
--agent-id "tester-1" \
|
|
86
|
+
--context "phase1-testing-complete"
|
|
87
|
+
|
|
88
|
+
# Ensure exit code reflects overall test success
|
|
89
|
+
[ $passed_tests -eq $total_tests ]
|
|
90
|
+
}
|
|
91
|
+
|
|
92
92
|
main
|
|
@@ -0,0 +1,166 @@
|
|
|
1
|
+
#!/bin/bash
|
|
2
|
+
|
|
3
|
+
# Fail on any error
|
|
4
|
+
set -e
|
|
5
|
+
|
|
6
|
+
# Load test utilities
|
|
7
|
+
source "$(dirname "$0")/test-utils.sh"
|
|
8
|
+
|
|
9
|
+
# Ensure Redis is running before tests
|
|
10
|
+
check_redis_connection() {
|
|
11
|
+
if ! redis-cli ping &>/dev/null; then
|
|
12
|
+
echo "ERROR: Redis is not running"
|
|
13
|
+
exit 1
|
|
14
|
+
fi
|
|
15
|
+
}
|
|
16
|
+
|
|
17
|
+
# Clean up Redis test keys after each test
|
|
18
|
+
cleanup_redis_keys() {
|
|
19
|
+
redis-cli del "test:context:key" "test:signal:key" "test:results:key"
|
|
20
|
+
}
|
|
21
|
+
|
|
22
|
+
# Path to scripts under test
|
|
23
|
+
STORE_CONTEXT_SCRIPT="$(dirname "$0")/../store-context.sh"
|
|
24
|
+
RETRIEVE_CONTEXT_SCRIPT="$(dirname "$0")/../retrieve-context.sh"
|
|
25
|
+
SIGNAL_SCRIPT="$(dirname "$0")/../signal.sh"
|
|
26
|
+
COLLECT_RESULTS_SCRIPT="$(dirname "$0")/../collect-results.sh"
|
|
27
|
+
|
|
28
|
+
# 1. Test store-context.sh
|
|
29
|
+
test_store_context_happy_path() {
|
|
30
|
+
local test_json='{"key": "value", "nested": {"a": 1}}'
|
|
31
|
+
|
|
32
|
+
# Execute store context
|
|
33
|
+
bash "$STORE_CONTEXT_SCRIPT" \
|
|
34
|
+
--key "test:context:key" \
|
|
35
|
+
--context "$test_json" \
|
|
36
|
+
--ttl 3600
|
|
37
|
+
|
|
38
|
+
# Verify stored context
|
|
39
|
+
stored_context=$(redis-cli get "test:context:key")
|
|
40
|
+
assert_equals "$stored_context" "$test_json" "Context should be stored correctly"
|
|
41
|
+
}
|
|
42
|
+
|
|
43
|
+
test_store_context_empty_data() {
|
|
44
|
+
# Test with empty JSON
|
|
45
|
+
bash "$STORE_CONTEXT_SCRIPT" \
|
|
46
|
+
--key "test:context:key" \
|
|
47
|
+
--context "{}" \
|
|
48
|
+
--ttl 3600
|
|
49
|
+
|
|
50
|
+
stored_context=$(redis-cli get "test:context:key")
|
|
51
|
+
assert_equals "$stored_context" "{}" "Empty context should be stored"
|
|
52
|
+
}
|
|
53
|
+
|
|
54
|
+
test_store_context_special_chars() {
|
|
55
|
+
local test_json='{"special": "value with !@#$%^&*()_+ chars"}'
|
|
56
|
+
|
|
57
|
+
bash "$STORE_CONTEXT_SCRIPT" \
|
|
58
|
+
--key "test:context:key" \
|
|
59
|
+
--context "$test_json" \
|
|
60
|
+
--ttl 3600
|
|
61
|
+
|
|
62
|
+
stored_context=$(redis-cli get "test:context:key")
|
|
63
|
+
assert_equals "$stored_context" "$test_json" "Context with special characters should store correctly"
|
|
64
|
+
}
|
|
65
|
+
|
|
66
|
+
# 2. Test retrieve-context.sh
|
|
67
|
+
test_retrieve_context_existing_key() {
|
|
68
|
+
local test_json='{"key": "retrieve-test"}'
|
|
69
|
+
|
|
70
|
+
# First store the context
|
|
71
|
+
redis-cli set "test:context:key" "$test_json"
|
|
72
|
+
|
|
73
|
+
# Retrieve context
|
|
74
|
+
retrieved_context=$(bash "$RETRIEVE_CONTEXT_SCRIPT" --key "test:context:key")
|
|
75
|
+
|
|
76
|
+
assert_equals "$retrieved_context" "$test_json" "Should retrieve existing context"
|
|
77
|
+
}
|
|
78
|
+
|
|
79
|
+
test_retrieve_context_missing_key() {
|
|
80
|
+
# Ensure key doesn't exist
|
|
81
|
+
redis-cli del "nonexistent:key"
|
|
82
|
+
|
|
83
|
+
# Try to retrieve missing context
|
|
84
|
+
retrieved_context=$(bash "$RETRIEVE_CONTEXT_SCRIPT" --key "nonexistent:key" || echo "")
|
|
85
|
+
|
|
86
|
+
assert_equals "$retrieved_context" "" "Missing key should return empty string"
|
|
87
|
+
}
|
|
88
|
+
|
|
89
|
+
# 3. Test signal.sh
|
|
90
|
+
test_signal_happy_path() {
|
|
91
|
+
bash "$SIGNAL_SCRIPT" \
|
|
92
|
+
--key "test:signal:key" \
|
|
93
|
+
--value "completed" \
|
|
94
|
+
--ttl 3600
|
|
95
|
+
|
|
96
|
+
signaled_value=$(redis-cli get "test:signal:key")
|
|
97
|
+
assert_equals "$signaled_value" "completed" "Signal should be stored correctly"
|
|
98
|
+
}
|
|
99
|
+
|
|
100
|
+
test_signal_empty_value() {
|
|
101
|
+
bash "$SIGNAL_SCRIPT" \
|
|
102
|
+
--key "test:signal:key" \
|
|
103
|
+
--value "" \
|
|
104
|
+
--ttl 3600
|
|
105
|
+
|
|
106
|
+
signaled_value=$(redis-cli get "test:signal:key")
|
|
107
|
+
assert_equals "$signaled_value" "" "Empty signal should be allowed"
|
|
108
|
+
}
|
|
109
|
+
|
|
110
|
+
# 4. Test collect-results.sh
|
|
111
|
+
test_collect_results_multiple_agents() {
|
|
112
|
+
# Clear any existing list
|
|
113
|
+
redis-cli del "test:results:key"
|
|
114
|
+
|
|
115
|
+
# Simulate multiple agent results
|
|
116
|
+
redis-cli rpush "test:results:key" '{"agent1": 0.9}'
|
|
117
|
+
redis-cli rpush "test:results:key" '{"agent2": 0.85}'
|
|
118
|
+
|
|
119
|
+
# Collect results
|
|
120
|
+
results=$(bash "$COLLECT_RESULTS_SCRIPT" --key "test:results:key")
|
|
121
|
+
|
|
122
|
+
# Check if results are correctly collected
|
|
123
|
+
assert_contains "$results" "agent1" "Should collect agent1 result"
|
|
124
|
+
assert_contains "$results" "agent2" "Should collect agent2 result"
|
|
125
|
+
}
|
|
126
|
+
|
|
127
|
+
# Main test runner
|
|
128
|
+
run_tests() {
|
|
129
|
+
check_redis_connection
|
|
130
|
+
|
|
131
|
+
echo "Running Redis Coordination Primitive Tests"
|
|
132
|
+
echo "----------------------------------------"
|
|
133
|
+
|
|
134
|
+
# Run store-context tests
|
|
135
|
+
test_store_context_happy_path
|
|
136
|
+
test_store_context_empty_data
|
|
137
|
+
test_store_context_special_chars
|
|
138
|
+
|
|
139
|
+
# Run retrieve-context tests
|
|
140
|
+
test_retrieve_context_existing_key
|
|
141
|
+
test_retrieve_context_missing_key
|
|
142
|
+
|
|
143
|
+
# Run signal tests
|
|
144
|
+
test_signal_happy_path
|
|
145
|
+
test_signal_empty_value
|
|
146
|
+
|
|
147
|
+
# Run collect results tests
|
|
148
|
+
test_collect_results_multiple_agents
|
|
149
|
+
|
|
150
|
+
# Clean up after tests
|
|
151
|
+
cleanup_redis_keys
|
|
152
|
+
|
|
153
|
+
echo "----------------------------------------"
|
|
154
|
+
echo "All tests passed successfully!"
|
|
155
|
+
}
|
|
156
|
+
|
|
157
|
+
# Execute tests and capture results
|
|
158
|
+
{
|
|
159
|
+
run_tests
|
|
160
|
+
} > /tmp/primitive-test-results.md 2>&1
|
|
161
|
+
|
|
162
|
+
# Confidence calculation (simplistic based on test coverage)
|
|
163
|
+
CONFIDENCE=$(echo "scale=2; 0.9" | bc)
|
|
164
|
+
echo "Test Confidence: $CONFIDENCE" >> /tmp/primitive-test-results.md
|
|
165
|
+
|
|
166
|
+
exit 0
|
|
@@ -1,122 +1,54 @@
|
|
|
1
|
-
#!/bin/bash
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
echo "
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
local
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
if ! echo "$json" | jq empty >/dev/null 2>&1; then
|
|
56
|
-
echo "❌ $message"
|
|
57
|
-
return 1
|
|
58
|
-
fi
|
|
59
|
-
echo "✅ $message"
|
|
60
|
-
}
|
|
61
|
-
|
|
62
|
-
assert_empty() {
|
|
63
|
-
local value="$1"
|
|
64
|
-
local message="${2:-Value is not empty}"
|
|
65
|
-
|
|
66
|
-
if [ -n "$value" ]; then
|
|
67
|
-
echo "❌ $message"
|
|
68
|
-
return 1
|
|
69
|
-
fi
|
|
70
|
-
echo "✅ $message"
|
|
71
|
-
}
|
|
72
|
-
|
|
73
|
-
# Test suite runner
|
|
74
|
-
run_tests() {
|
|
75
|
-
local tests=("$@")
|
|
76
|
-
local passed=0
|
|
77
|
-
local failed=0
|
|
78
|
-
local total=${#tests[@]}
|
|
79
|
-
|
|
80
|
-
echo "Running $total test cases..."
|
|
81
|
-
|
|
82
|
-
for test in "${tests[@]}"; do
|
|
83
|
-
if "$test"; then
|
|
84
|
-
((passed++))
|
|
85
|
-
else
|
|
86
|
-
((failed++))
|
|
87
|
-
fi
|
|
88
|
-
done
|
|
89
|
-
|
|
90
|
-
echo "Test Summary: $passed/$total passed, $failed failed"
|
|
91
|
-
|
|
92
|
-
if [ $failed -gt 0 ]; then
|
|
93
|
-
return 1
|
|
94
|
-
fi
|
|
95
|
-
return 0
|
|
96
|
-
}
|
|
97
|
-
|
|
98
|
-
# Compute confidence score based on test results
|
|
99
|
-
compute_confidence_score() {
|
|
100
|
-
local passed="$1"
|
|
101
|
-
local total="$2"
|
|
102
|
-
|
|
103
|
-
# Compute percentage, convert to 0-1 range
|
|
104
|
-
local confidence=$(echo "scale=2; $passed / $total" | bc)
|
|
105
|
-
echo "$confidence"
|
|
106
|
-
}
|
|
107
|
-
|
|
108
|
-
# Prepare for CFN Loop reporting
|
|
109
|
-
report_test_results() {
|
|
110
|
-
local task_id="$1"
|
|
111
|
-
local agent_id="$2"
|
|
112
|
-
local passed="$3"
|
|
113
|
-
local total="$4"
|
|
114
|
-
|
|
115
|
-
local confidence=$(compute_confidence_score "$passed" "$total")
|
|
116
|
-
|
|
117
|
-
./.claude/skills/redis-coordination/invoke-waiting-mode.sh report \
|
|
118
|
-
--task-id "$task_id" \
|
|
119
|
-
--agent-id "$agent_id" \
|
|
120
|
-
--confidence "$confidence" \
|
|
121
|
-
--iteration 1
|
|
1
|
+
#!/bin/bash
|
|
2
|
+
|
|
3
|
+
# Color codes for output
|
|
4
|
+
RED='\033[0;31m'
|
|
5
|
+
GREEN='\033[0;32m'
|
|
6
|
+
NC='\033[0m' # No Color
|
|
7
|
+
|
|
8
|
+
# Assert that two values are equal
|
|
9
|
+
assert_equals() {
|
|
10
|
+
local actual="$1"
|
|
11
|
+
local expected="$2"
|
|
12
|
+
local message="${3:-Assertion failed}"
|
|
13
|
+
|
|
14
|
+
if [[ "$actual" == "$expected" ]]; then
|
|
15
|
+
echo -e "${GREEN}PASS${NC}: $message"
|
|
16
|
+
else
|
|
17
|
+
echo -e "${RED}FAIL${NC}: $message"
|
|
18
|
+
echo " Expected: $expected"
|
|
19
|
+
echo " Actual: $actual"
|
|
20
|
+
exit 1
|
|
21
|
+
fi
|
|
22
|
+
}
|
|
23
|
+
|
|
24
|
+
# Assert that a string contains another string
|
|
25
|
+
assert_contains() {
|
|
26
|
+
local haystack="$1"
|
|
27
|
+
local needle="$2"
|
|
28
|
+
local message="${3:-Assertion failed}"
|
|
29
|
+
|
|
30
|
+
if [[ "$haystack" == *"$needle"* ]]; then
|
|
31
|
+
echo -e "${GREEN}PASS${NC}: $message"
|
|
32
|
+
else
|
|
33
|
+
echo -e "${RED}FAIL${NC}: $message"
|
|
34
|
+
echo " Expected to contain: $needle"
|
|
35
|
+
echo " Actual: $haystack"
|
|
36
|
+
exit 1
|
|
37
|
+
fi
|
|
38
|
+
}
|
|
39
|
+
|
|
40
|
+
# Error handling wrapper
|
|
41
|
+
safe_execute() {
|
|
42
|
+
local cmd="$1"
|
|
43
|
+
local error_msg="${2:-Command execution failed}"
|
|
44
|
+
|
|
45
|
+
set +e
|
|
46
|
+
$cmd
|
|
47
|
+
local exit_code=$?
|
|
48
|
+
set -e
|
|
49
|
+
|
|
50
|
+
if [[ $exit_code -ne 0 ]]; then
|
|
51
|
+
echo -e "${RED}ERROR${NC}: $error_msg (Exit code: $exit_code)"
|
|
52
|
+
exit 1
|
|
53
|
+
fi
|
|
122
54
|
}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
#!/bin/bash
|
|
2
|
+
|
|
3
|
+
# 🚨 DEPRECATED TEST SUITE 🚨
|
|
4
|
+
#
|
|
5
|
+
# This test suite has been DEPRECATED and is kept ONLY for historical reference.
|
|
6
|
+
#
|
|
7
|
+
# REASONS FOR DEPRECATION:
|
|
8
|
+
# - References non-existent legacy scripts
|
|
9
|
+
# (redis-context-store.sh, redis-context-retrieve.sh, redis-coordination.sh)
|
|
10
|
+
# - Scripts have been renamed/replaced
|
|
11
|
+
#
|
|
12
|
+
# RECOMMENDED ACTION:
|
|
13
|
+
# - Use /tests/test-primitives.sh for current Redis coordination testing
|
|
14
|
+
#
|
|
15
|
+
# DO NOT RUN THIS TEST SUITE IN AUTOMATED TESTING
|
|
16
|
+
#
|
|
17
|
+
# Last updated: 2025-10-23
|
|
18
|
+
|
|
19
|
+
# Intentionally empty - kept for historical record
|
|
20
|
+
exit 0
|
|
@@ -0,0 +1,49 @@
|
|
|
1
|
+
#!/bin/bash
|
|
2
|
+
|
|
3
|
+
# Test Utilities for Bash Testing
|
|
4
|
+
|
|
5
|
+
# Color codes
|
|
6
|
+
GREEN='\033[0;32m'
|
|
7
|
+
RED='\033[0;31m'
|
|
8
|
+
NC='\033[0m' # No Color
|
|
9
|
+
|
|
10
|
+
# Assert functions
|
|
11
|
+
assert_equals() {
|
|
12
|
+
local actual="$1"
|
|
13
|
+
local expected="$2"
|
|
14
|
+
local message="${3:-Assertion failed}"
|
|
15
|
+
|
|
16
|
+
if [[ "$actual" != "$expected" ]]; then
|
|
17
|
+
echo -e "${RED}❌ $message${NC}"
|
|
18
|
+
echo " Expected: $expected"
|
|
19
|
+
echo " Actual: $actual"
|
|
20
|
+
exit 1
|
|
21
|
+
fi
|
|
22
|
+
echo -e "${GREEN}✅ $message passed${NC}"
|
|
23
|
+
}
|
|
24
|
+
|
|
25
|
+
assert_not_empty() {
|
|
26
|
+
local value="$1"
|
|
27
|
+
local message="${2:-Value should not be empty}"
|
|
28
|
+
|
|
29
|
+
if [[ -z "$value" ]]; then
|
|
30
|
+
echo -e "${RED}❌ $message${NC}"
|
|
31
|
+
exit 1
|
|
32
|
+
fi
|
|
33
|
+
echo -e "${GREEN}✅ $message passed${NC}"
|
|
34
|
+
}
|
|
35
|
+
|
|
36
|
+
assert_json_equals() {
|
|
37
|
+
local json1="$1"
|
|
38
|
+
local json2="$2"
|
|
39
|
+
local message="${3:-JSON comparison failed}"
|
|
40
|
+
|
|
41
|
+
# Requires jq for deep JSON comparison
|
|
42
|
+
if ! echo "$json1" | jq -n "inputs == $json2"; then
|
|
43
|
+
echo -e "${RED}❌ $message${NC}"
|
|
44
|
+
echo " JSON 1: $json1"
|
|
45
|
+
echo " JSON 2: $json2"
|
|
46
|
+
exit 1
|
|
47
|
+
fi
|
|
48
|
+
echo -e "${GREEN}✅ $message passed${NC}"
|
|
49
|
+
}
|
|
@@ -0,0 +1,76 @@
|
|
|
1
|
+
#!/usr/bin/env bash
|
|
2
|
+
# Core Orchestration Module for CFN Loop V2 Modularization
|
|
3
|
+
|
|
4
|
+
# Source required modules
|
|
5
|
+
source ./config_loader.sh
|
|
6
|
+
source ./context_manager.sh
|
|
7
|
+
source ./loop3_module.sh
|
|
8
|
+
source ./loop2_module.sh
|
|
9
|
+
source ./product_owner_module.sh
|
|
10
|
+
source ./metrics_logger.sh
|
|
11
|
+
|
|
12
|
+
# Main orchestration function
|
|
13
|
+
orchestrate_cfn_loop() {
|
|
14
|
+
local task_id="$1"
|
|
15
|
+
local mode="${2:-standard}"
|
|
16
|
+
|
|
17
|
+
# Load configuration
|
|
18
|
+
load_environment_config "$task_id"
|
|
19
|
+
validate_configuration
|
|
20
|
+
|
|
21
|
+
# Load epic context
|
|
22
|
+
local context
|
|
23
|
+
context=$(load_epic_context "$task_id")
|
|
24
|
+
|
|
25
|
+
# Execute Loop 3
|
|
26
|
+
local loop3_result
|
|
27
|
+
loop3_result=$(execute_loop_3_agents "$context")
|
|
28
|
+
|
|
29
|
+
if [[ $loop3_result -ne 0 ]]; then
|
|
30
|
+
log_iteration_metrics "loop3_failed"
|
|
31
|
+
return 3
|
|
32
|
+
fi
|
|
33
|
+
|
|
34
|
+
# Execute Loop 2 Validation
|
|
35
|
+
local consensus_result
|
|
36
|
+
consensus_result=$(execute_loop_2_validation "$loop3_result")
|
|
37
|
+
|
|
38
|
+
if [[ $consensus_result -ne 0 ]]; then
|
|
39
|
+
log_iteration_metrics "loop2_validation_failed"
|
|
40
|
+
return 4
|
|
41
|
+
fi
|
|
42
|
+
|
|
43
|
+
# Product Owner Decision
|
|
44
|
+
local final_decision
|
|
45
|
+
final_decision=$(evaluate_deliverables "$consensus_result")
|
|
46
|
+
|
|
47
|
+
case "$final_decision" in
|
|
48
|
+
"proceed")
|
|
49
|
+
log_iteration_metrics "successful_completion"
|
|
50
|
+
export_iteration_report
|
|
51
|
+
return 0
|
|
52
|
+
;;
|
|
53
|
+
"iterate")
|
|
54
|
+
log_iteration_metrics "iteration_required"
|
|
55
|
+
return 2
|
|
56
|
+
;;
|
|
57
|
+
"abort")
|
|
58
|
+
log_iteration_metrics "aborted"
|
|
59
|
+
return 1
|
|
60
|
+
;;
|
|
61
|
+
esac
|
|
62
|
+
}
|
|
63
|
+
|
|
64
|
+
# Entry point
|
|
65
|
+
main() {
|
|
66
|
+
local task_id="$1"
|
|
67
|
+
local mode="${2:-standard}"
|
|
68
|
+
|
|
69
|
+
orchestrate_cfn_loop "$task_id" "$mode"
|
|
70
|
+
exit $?
|
|
71
|
+
}
|
|
72
|
+
|
|
73
|
+
# Only run main if script is executed directly
|
|
74
|
+
if [[ "${BASH_SOURCE[0]}" == "${0}" ]]; then
|
|
75
|
+
main "$@"
|
|
76
|
+
fi
|