claude-flow-novice 2.6.0 → 2.9.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (659) hide show
  1. package/.claude/agents/cfn-dev-team/coordinators/README.md +42 -0
  2. package/.claude/agents/cfn-dev-team/coordinators/cfn-v3-coordinator.md +440 -0
  3. package/.claude/agents/{product-owner-team → cfn-dev-team/coordinators}/cto-agent.md +154 -187
  4. package/.claude/agents/cfn-dev-team/coordinators/multi-sprint-coordinator.md +50 -0
  5. package/.claude/agents/{product-owner-team → cfn-dev-team/coordinators}/product-owner-agent.md +7 -40
  6. package/.claude/agents/{cfn-loop → cfn-dev-team/coordinators}/product-owner.md +73 -18
  7. package/.claude/agents/cfn-dev-team/developers/README.md +69 -0
  8. package/.claude/agents/cfn-dev-team/developers/backend-dev.md +77 -0
  9. package/.claude/agents/{core-agents → cfn-dev-team/developers}/coder.md +132 -27
  10. package/.claude/agents/cfn-dev-team/developers/react-frontend-engineer.md +121 -0
  11. package/.claude/agents/{frontend → cfn-dev-team/developers}/state-architect.md +1 -0
  12. package/.claude/agents/{frontend → cfn-dev-team/developers}/ui-designer.md +1 -0
  13. package/.claude/agents/cfn-dev-team/reviewers/README.md +58 -0
  14. package/.claude/agents/{analysis → cfn-dev-team/reviewers}/code-quality-validator.md +9 -18
  15. package/.claude/agents/{core-agents → cfn-dev-team/reviewers}/reviewer.md +62 -23
  16. package/.claude/agents/cfn-dev-team/testers/README.md +94 -0
  17. package/.claude/agents/{testing → cfn-dev-team/testers}/e2e/playwright-agent.md +2 -21
  18. package/.claude/agents/{testing → cfn-dev-team/testers}/interaction-tester.md +2 -21
  19. package/.claude/agents/{testing → cfn-dev-team/testers}/playwright-tester.md +1 -1
  20. package/.claude/agents/cfn-dev-team/testers/tester.md +139 -0
  21. package/.claude/agents/cfn-dev-team/testers/unit/tdd-london-swarm.md +49 -0
  22. package/.claude/agents/cfn-dev-team/testers/validation/production-validator.md +33 -0
  23. package/.claude/cfn-data/cfn-loop.db +0 -0
  24. package/.claude/cfn-data/cfn_loop_logs.db +0 -0
  25. package/.claude/commands/{CFN_COORDINATOR_PARAMETERS.md → cfn/CFN_COORDINATOR_PARAMETERS.md} +22 -22
  26. package/.claude/commands/{cfn-loop-epic.md → cfn/cfn-loop-epic.md} +6 -6
  27. package/.claude/commands/{cfn-loop-single.md → cfn/cfn-loop-single.md} +9 -9
  28. package/.claude/commands/{cfn-loop-sprints.md → cfn/cfn-loop-sprints.md} +1 -1
  29. package/.claude/commands/{cfn-loop.md → cfn/cfn-loop.md} +9 -9
  30. package/.claude/commands/cfn/cfn-mode.md +20 -0
  31. package/.claude/commands/{cfn-optimize-agents.md → cfn/cfn-optimize-agents.md} +1 -1
  32. package/.claude/commands/{context-curate.md → cfn/context-curate.md} +2 -2
  33. package/.claude/commands/{context-inject.md → cfn/context-inject.md} +3 -3
  34. package/.claude/commands/{context-reflect.md → cfn/context-reflect.md} +1 -1
  35. package/.claude/commands/{context-stats.md → cfn/context-stats.md} +1 -1
  36. package/.claude/commands/{list-agents-rebuild.md → cfn/list-agents-rebuild.md} +12 -12
  37. package/.claude/commands/cfn/write-plan.md +104 -0
  38. package/.claude/hooks/cfn-BACKUP_USAGE.md +243 -0
  39. package/.claude/hooks/cfn-post-edit-cfn-retrospective.sh +79 -0
  40. package/.claude/hooks/cfn-post-edit.sh +21 -0
  41. package/.claude/hooks/cfn-pre-edit-backup.sh +71 -0
  42. package/.claude/hooks/cfn-restore-from-backup.sh +37 -0
  43. package/.claude/skills/cfn-loop-orchestration/README.md +41 -0
  44. package/.claude/skills/cfn-redis-coordination/README.md +65 -0
  45. package/.claude/skills/cfn-webapp-testing/README.md +142 -0
  46. package/CFN-CLAUDE.md +776 -0
  47. package/README.md +598 -251
  48. package/dist/agents/agent-loader.js +146 -165
  49. package/dist/agents/agent-loader.js.map +1 -1
  50. package/dist/cli/agent-command.js +2 -0
  51. package/dist/cli/agent-command.js.map +1 -1
  52. package/dist/cli/agent-definition-parser.js +7 -0
  53. package/dist/cli/agent-definition-parser.js.map +1 -1
  54. package/dist/cli/agent-executor.js +145 -11
  55. package/dist/cli/agent-executor.js.map +1 -1
  56. package/dist/cli/agent-prompt-builder.js +81 -1
  57. package/dist/cli/agent-prompt-builder.js.map +1 -1
  58. package/dist/cli/agent-spawn.js +10 -1
  59. package/dist/cli/agent-spawn.js.map +1 -1
  60. package/dist/cli/anthropic-client.js +192 -13
  61. package/dist/cli/anthropic-client.js.map +1 -1
  62. package/dist/cli/cfn-context.js +150 -0
  63. package/dist/cli/cfn-context.js.map +1 -1
  64. package/dist/cli/cfn-fork.js +159 -0
  65. package/dist/cli/cfn-fork.js.map +1 -0
  66. package/dist/cli/cli-agent-context.js +8 -3
  67. package/dist/cli/cli-agent-context.js.map +1 -1
  68. package/dist/cli/conversation-fork.js +201 -0
  69. package/dist/cli/conversation-fork.js.map +1 -0
  70. package/dist/cli/index.js +4 -0
  71. package/dist/cli/index.js.map +1 -1
  72. package/dist/cli/init-command.js +20 -0
  73. package/dist/cli/init-command.js.map +1 -0
  74. package/dist/cli/tool-definitions.js +263 -0
  75. package/dist/cli/tool-definitions.js.map +1 -0
  76. package/dist/cli/tool-executor.js +247 -0
  77. package/dist/cli/tool-executor.js.map +1 -0
  78. package/dist/hello.js +8 -0
  79. package/dist/hello.js.map +1 -0
  80. package/package.json +26 -12
  81. package/scripts/README.md +68 -0
  82. package/scripts/cfn-intervention-example.sh +21 -0
  83. package/scripts/init-project.js +148 -0
  84. package/scripts/migrate-test-infrastructure.sh +40 -0
  85. package/scripts/restructure-cfn-namespace.sh +161 -0
  86. package/scripts/validate-test-migration.sh +49 -0
  87. package/scripts/verify-no-secrets.sh +55 -0
  88. package/.claude/SLASH-COMMANDS-READY.md +0 -53
  89. package/.claude/WORKING-SETUP.md +0 -67
  90. package/.claude/ace-system-overview.md +0 -524
  91. package/.claude/agent-principles/agent-template.md +0 -96
  92. package/.claude/agents/CLAUDE.md +0 -995
  93. package/.claude/agents/README-VALIDATION.md +0 -243
  94. package/.claude/agents/agent-principles/README.md +0 -226
  95. package/.claude/agents/agent-principles/agent-type-guidelines.md +0 -465
  96. package/.claude/agents/agent-principles/format-selection.md +0 -224
  97. package/.claude/agents/agent-principles/phase4-template-optimization.md +0 -494
  98. package/.claude/agents/agent-principles/prompt-engineering.md +0 -501
  99. package/.claude/agents/agent-principles/quality-metrics.md +0 -375
  100. package/.claude/agents/analysis/code-analyzer.md +0 -192
  101. package/.claude/agents/analysis/code-review/analyze-code-quality.md +0 -133
  102. package/.claude/agents/analysis/perf-analyzer.md +0 -230
  103. package/.claude/agents/architecture/system-architect.md +0 -161
  104. package/.claude/agents/architecture/system-architect.md.backup +0 -603
  105. package/.claude/agents/code-booster.md +0 -131
  106. package/.claude/agents/consensus/consensus-builder.md +0 -159
  107. package/.claude/agents/consensus/crdt-synchronizer.md +0 -192
  108. package/.claude/agents/consensus/performance-benchmarker.md +0 -101
  109. package/.claude/agents/consensus/quorum-manager.md +0 -168
  110. package/.claude/agents/consensus/raft-manager.md +0 -106
  111. package/.claude/agents/consensus/security-manager.md +0 -107
  112. package/.claude/agents/context/context-curator.md +0 -84
  113. package/.claude/agents/context/context-reflector.md +0 -81
  114. package/.claude/agents/context-curator.md +0 -167
  115. package/.claude/agents/context-reflector.md +0 -65
  116. package/.claude/agents/core-agents/analyst.md +0 -170
  117. package/.claude/agents/core-agents/architect.md +0 -200
  118. package/.claude/agents/core-agents/base-template-generator.md +0 -188
  119. package/.claude/agents/core-agents/cfn-loop-coordinator.md +0 -134
  120. package/.claude/agents/core-agents/code-quality-validator.md +0 -149
  121. package/.claude/agents/core-agents/context-curator.md +0 -452
  122. package/.claude/agents/core-agents/context-reflector.md +0 -273
  123. package/.claude/agents/core-agents/coordinator.md +0 -182
  124. package/.claude/agents/core-agents/cost-savings-cfn-loop-coordinator.md +0 -235
  125. package/.claude/agents/core-agents/cost-savings-coordinator.md +0 -167
  126. package/.claude/agents/core-agents/performance-benchmarker.md +0 -148
  127. package/.claude/agents/core-agents/planner.md +0 -174
  128. package/.claude/agents/core-agents/security-manager.md +0 -111
  129. package/.claude/agents/core-agents/tester.md +0 -170
  130. package/.claude/agents/custom/agent-builder.md +0 -637
  131. package/.claude/agents/development/backend/dev-backend-api.md +0 -139
  132. package/.claude/agents/development/backend-dev.md +0 -165
  133. package/.claude/agents/development/npm-package-specialist.md +0 -347
  134. package/.claude/agents/devops/devops-engineer.md +0 -148
  135. package/.claude/agents/documentation/api-docs/docs-api-openapi.md +0 -98
  136. package/.claude/agents/documentation/api-docs.md +0 -103
  137. package/.claude/agents/frontend/README.md +0 -640
  138. package/.claude/agents/frontend/interaction-tester.md +0 -139
  139. package/.claude/agents/frontend/react-frontend-engineer.md +0 -9
  140. package/.claude/agents/github/github-commit-agent.md +0 -118
  141. package/.claude/agents/goal/goal-planner.md +0 -183
  142. package/.claude/agents/personas/accessibility-advocate-persona.md +0 -107
  143. package/.claude/agents/planning-team/api-designer-persona.md +0 -147
  144. package/.claude/agents/planning-team/security-architect-persona.md +0 -190
  145. package/.claude/agents/planning-team/system-architect-persona.md +0 -190
  146. package/.claude/agents/product-owner-team/accessibility-advocate-persona.md +0 -161
  147. package/.claude/agents/product-owner-team/power-user-persona.md +0 -182
  148. package/.claude/agents/security/security-specialist-existing.md +0 -154
  149. package/.claude/agents/security/security-specialist.md +0 -185
  150. package/.claude/agents/sparc/architecture.md +0 -149
  151. package/.claude/agents/sparc/pseudocode.md +0 -159
  152. package/.claude/agents/sparc/refinement.md +0 -106
  153. package/.claude/agents/sparc/specification.md +0 -157
  154. package/.claude/agents/specialized/cli-agent-optimizer.md +0 -122
  155. package/.claude/agents/specialized/code-booster.md +0 -143
  156. package/.claude/agents/specialized/devops-engineer.md +0 -150
  157. package/.claude/agents/specialized/mobile/mobile-dev.md +0 -210
  158. package/.claude/agents/specialized/mobile/spec-mobile-react-native.md +0 -191
  159. package/.claude/agents/specialized/rust-developer.md +0 -166
  160. package/.claude/agents/specialized/rust-enterprise-developer.md +0 -144
  161. package/.claude/agents/specialized/rust-mvp-developer.md +0 -142
  162. package/.claude/agents/testing/production-validator.md +0 -179
  163. package/.claude/agents/testing/tdd-london-swarm.md +0 -209
  164. package/.claude/agents/testing/unit/tdd-london-swarm.md +0 -43
  165. package/.claude/agents/testing/validation/production-validator.md +0 -43
  166. package/.claude/agents/validate-agent.js +0 -841
  167. package/.claude/agents-ignore/cfn-coordinator-enterprise.md +0 -1303
  168. package/.claude/agents-ignore/cfn-coordinator-mvp.md +0 -942
  169. package/.claude/agents-ignore/cfn-coordinator-standard.md +0 -1062
  170. package/.claude/agents-ignore/deprecated-coordinators/adaptive-coordinator-enhanced.md +0 -145
  171. package/.claude/agents-ignore/deprecated-coordinators/adaptive-coordinator.md +0 -161
  172. package/.claude/agents-ignore/deprecated-coordinators/blocking-coordinator-example.md +0 -732
  173. package/.claude/agents-ignore/deprecated-coordinators/byzantine-coordinator.md +0 -94
  174. package/.claude/agents-ignore/deprecated-coordinators/cfn-coordinator-enterprise.md +0 -323
  175. package/.claude/agents-ignore/deprecated-coordinators/cfn-coordinator-mvp.md +0 -157
  176. package/.claude/agents-ignore/deprecated-coordinators/cfn-coordinator-standard.md +0 -229
  177. package/.claude/agents-ignore/deprecated-coordinators/cfn-coordinator-unified.md +0 -149
  178. package/.claude/agents-ignore/deprecated-coordinators/coordinator-hybrid.md +0 -231
  179. package/.claude/agents-ignore/deprecated-coordinators/gossip-coordinator.md +0 -165
  180. package/.claude/agents-ignore/deprecated-coordinators/hierarchical-coordinator.md +0 -91
  181. package/.claude/agents-ignore/deprecated-coordinators/mesh-coordinator.md +0 -131
  182. package/.claude/agents-ignore/deprecated-coordinators/task-coordinator.md +0 -105
  183. package/.claude/agents-ignore/deprecated-coordinators/test-coordinator.md +0 -141
  184. package/.claude/api-configs/config-current-zai-config.env +0 -62
  185. package/.claude/api-configs/config-test-zai-config.env +0 -62
  186. package/.claude/api-configs/env-backups/before-anthropic-20251020-025404.env +0 -62
  187. package/.claude/api-configs/env-backups/before-restore-20251020-025431.env +0 -62
  188. package/.claude/architecture/mesh-get-polling-design.md +0 -87
  189. package/.claude/architecture/mesh-get-polling-implementation.md +0 -89
  190. package/.claude/architecture/typescript-microservices.md +0 -50
  191. package/.claude/artifacts/reflection-merge-logs/cli-agent-spawning-v2.5.2-merge-report.md +0 -61
  192. package/.claude/cfn-loop-rules.md +0 -73
  193. package/.claude/cfn-mode-patterns.md +0 -571
  194. package/.claude/claude-md-backup-pre-skills.md +0 -15
  195. package/.claude/commands/agents/README.md +0 -10
  196. package/.claude/commands/agents/agent-capabilities.md +0 -21
  197. package/.claude/commands/agents/agent-coordination.md +0 -28
  198. package/.claude/commands/agents/agent-spawning.md +0 -28
  199. package/.claude/commands/agents/agent-types.md +0 -26
  200. package/.claude/commands/analysis/COMMAND_COMPLIANCE_REPORT.md +0 -54
  201. package/.claude/commands/analysis/README.md +0 -9
  202. package/.claude/commands/analysis/bottleneck-detect.md +0 -162
  203. package/.claude/commands/analysis/performance-bottlenecks.md +0 -59
  204. package/.claude/commands/analysis/performance-report.md +0 -25
  205. package/.claude/commands/analysis/token-efficiency.md +0 -45
  206. package/.claude/commands/analysis/token-usage.md +0 -25
  207. package/.claude/commands/automation/README.md +0 -9
  208. package/.claude/commands/automation/auto-agent.md +0 -122
  209. package/.claude/commands/automation/self-healing.md +0 -106
  210. package/.claude/commands/automation/session-memory.md +0 -90
  211. package/.claude/commands/automation/smart-agents.md +0 -73
  212. package/.claude/commands/automation/smart-spawn.md +0 -25
  213. package/.claude/commands/automation/workflow-select.md +0 -25
  214. package/.claude/commands/claude-md.js +0 -237
  215. package/.claude/commands/claude-soul.js +0 -28
  216. package/.claude/commands/cli-integration.js +0 -216
  217. package/.claude/commands/coordination/README.md +0 -9
  218. package/.claude/commands/coordination/agent-spawn.md +0 -25
  219. package/.claude/commands/coordination/coordination-system.md +0 -88
  220. package/.claude/commands/coordination/init.md +0 -44
  221. package/.claude/commands/coordination/orchestrate.md +0 -43
  222. package/.claude/commands/coordination/spawn.md +0 -45
  223. package/.claude/commands/coordination/swarm-init.md +0 -85
  224. package/.claude/commands/coordination/task-orchestrate.md +0 -25
  225. package/.claude/commands/github/README.md +0 -11
  226. package/.claude/commands/github/code-review-swarm.md +0 -514
  227. package/.claude/commands/github/code-review.md +0 -25
  228. package/.claude/commands/github/github-modes.md +0 -147
  229. package/.claude/commands/github/github-swarm.md +0 -121
  230. package/.claude/commands/github/issue-tracker.md +0 -292
  231. package/.claude/commands/github/issue-triage.md +0 -25
  232. package/.claude/commands/github/multi-repo-swarm.md +0 -519
  233. package/.claude/commands/github/pr-enhance.md +0 -26
  234. package/.claude/commands/github/pr-manager.md +0 -170
  235. package/.claude/commands/github/project-board-sync.md +0 -471
  236. package/.claude/commands/github/release-manager.md +0 -338
  237. package/.claude/commands/github/release-swarm.md +0 -544
  238. package/.claude/commands/github/repo-analyze.md +0 -25
  239. package/.claude/commands/github/repo-architect.md +0 -367
  240. package/.claude/commands/github/swarm-issue.md +0 -482
  241. package/.claude/commands/github/swarm-pr.md +0 -285
  242. package/.claude/commands/github/sync-coordinator.md +0 -301
  243. package/.claude/commands/github/workflow-automation.md +0 -442
  244. package/.claude/commands/github.js +0 -638
  245. package/.claude/commands/hive-mind/README.md +0 -17
  246. package/.claude/commands/hive-mind/hive-mind-consensus.md +0 -8
  247. package/.claude/commands/hive-mind/hive-mind-init.md +0 -18
  248. package/.claude/commands/hive-mind/hive-mind-memory.md +0 -8
  249. package/.claude/commands/hive-mind/hive-mind-metrics.md +0 -8
  250. package/.claude/commands/hive-mind/hive-mind-resume.md +0 -8
  251. package/.claude/commands/hive-mind/hive-mind-sessions.md +0 -8
  252. package/.claude/commands/hive-mind/hive-mind-spawn.md +0 -21
  253. package/.claude/commands/hive-mind/hive-mind-status.md +0 -8
  254. package/.claude/commands/hive-mind/hive-mind-stop.md +0 -8
  255. package/.claude/commands/hive-mind/hive-mind-wizard.md +0 -8
  256. package/.claude/commands/hive-mind/hive-mind.md +0 -27
  257. package/.claude/commands/hooks/README.md +0 -11
  258. package/.claude/commands/hooks/overview.md +0 -58
  259. package/.claude/commands/hooks/post-edit.md +0 -117
  260. package/.claude/commands/hooks/post-task.md +0 -112
  261. package/.claude/commands/hooks/pre-edit.md +0 -113
  262. package/.claude/commands/hooks/pre-task.md +0 -111
  263. package/.claude/commands/hooks/session-end.md +0 -118
  264. package/.claude/commands/hooks/session-start.md +0 -9
  265. package/.claude/commands/hooks/setup.md +0 -103
  266. package/.claude/commands/hooks.js +0 -651
  267. package/.claude/commands/index.js +0 -119
  268. package/.claude/commands/memory/README.md +0 -9
  269. package/.claude/commands/memory/memory-bank.md +0 -58
  270. package/.claude/commands/memory/memory-persist.md +0 -25
  271. package/.claude/commands/memory/memory-search.md +0 -25
  272. package/.claude/commands/memory/memory-usage.md +0 -25
  273. package/.claude/commands/memory/neural.md +0 -47
  274. package/.claude/commands/memory/usage.md +0 -46
  275. package/.claude/commands/monitoring/README.md +0 -9
  276. package/.claude/commands/monitoring/agent-metrics.md +0 -25
  277. package/.claude/commands/monitoring/agents.md +0 -44
  278. package/.claude/commands/monitoring/real-time-view.md +0 -25
  279. package/.claude/commands/monitoring/status.md +0 -46
  280. package/.claude/commands/monitoring/swarm-monitor.md +0 -25
  281. package/.claude/commands/neural.js +0 -572
  282. package/.claude/commands/optimization/README.md +0 -9
  283. package/.claude/commands/optimization/auto-topology.md +0 -62
  284. package/.claude/commands/optimization/cache-manage.md +0 -25
  285. package/.claude/commands/optimization/parallel-execute.md +0 -25
  286. package/.claude/commands/optimization/parallel-execution.md +0 -50
  287. package/.claude/commands/optimization/topology-optimize.md +0 -25
  288. package/.claude/commands/pair/README.md +0 -261
  289. package/.claude/commands/pair/commands.md +0 -546
  290. package/.claude/commands/pair/config.md +0 -510
  291. package/.claude/commands/pair/examples.md +0 -512
  292. package/.claude/commands/pair/modes.md +0 -348
  293. package/.claude/commands/pair/session.md +0 -407
  294. package/.claude/commands/pair/start.md +0 -209
  295. package/.claude/commands/parse-epic.js +0 -180
  296. package/.claude/commands/performance.js +0 -582
  297. package/.claude/commands/register-all-commands.js +0 -320
  298. package/.claude/commands/register-claude-md.js +0 -82
  299. package/.claude/commands/register-claude-soul.js +0 -80
  300. package/.claude/commands/sparc/analyzer.md +0 -52
  301. package/.claude/commands/sparc/architect.md +0 -53
  302. package/.claude/commands/sparc/batch-executor.md +0 -54
  303. package/.claude/commands/sparc/coder.md +0 -54
  304. package/.claude/commands/sparc/debugger.md +0 -54
  305. package/.claude/commands/sparc/designer.md +0 -53
  306. package/.claude/commands/sparc/documenter.md +0 -54
  307. package/.claude/commands/sparc/innovator.md +0 -54
  308. package/.claude/commands/sparc/memory-manager.md +0 -54
  309. package/.claude/commands/sparc/optimizer.md +0 -54
  310. package/.claude/commands/sparc/orchestrator.md +0 -132
  311. package/.claude/commands/sparc/researcher.md +0 -54
  312. package/.claude/commands/sparc/reviewer.md +0 -54
  313. package/.claude/commands/sparc/sparc-modes.md +0 -174
  314. package/.claude/commands/sparc/swarm-coordinator.md +0 -54
  315. package/.claude/commands/sparc/tdd.md +0 -54
  316. package/.claude/commands/sparc/tester.md +0 -54
  317. package/.claude/commands/sparc/workflow-manager.md +0 -54
  318. package/.claude/commands/sparc.js +0 -110
  319. package/.claude/commands/stream-chain/pipeline.md +0 -121
  320. package/.claude/commands/stream-chain/run.md +0 -70
  321. package/.claude/commands/swarm/README.md +0 -15
  322. package/.claude/commands/swarm/analysis.md +0 -95
  323. package/.claude/commands/swarm/development.md +0 -96
  324. package/.claude/commands/swarm/examples.md +0 -168
  325. package/.claude/commands/swarm/maintenance.md +0 -102
  326. package/.claude/commands/swarm/optimization.md +0 -117
  327. package/.claude/commands/swarm/research.md +0 -136
  328. package/.claude/commands/swarm/swarm-analysis.md +0 -8
  329. package/.claude/commands/swarm/swarm-background.md +0 -8
  330. package/.claude/commands/swarm/swarm-init.md +0 -19
  331. package/.claude/commands/swarm/swarm-modes.md +0 -8
  332. package/.claude/commands/swarm/swarm-monitor.md +0 -8
  333. package/.claude/commands/swarm/swarm-spawn.md +0 -19
  334. package/.claude/commands/swarm/swarm-status.md +0 -8
  335. package/.claude/commands/swarm/swarm-strategies.md +0 -8
  336. package/.claude/commands/swarm/swarm.md +0 -27
  337. package/.claude/commands/swarm/testing.md +0 -131
  338. package/.claude/commands/swarm.js +0 -423
  339. package/.claude/commands/testing/playwright-e2e.md +0 -288
  340. package/.claude/commands/training/README.md +0 -9
  341. package/.claude/commands/training/model-update.md +0 -25
  342. package/.claude/commands/training/neural-patterns.md +0 -74
  343. package/.claude/commands/training/neural-train.md +0 -25
  344. package/.claude/commands/training/pattern-learn.md +0 -25
  345. package/.claude/commands/training/specialization.md +0 -63
  346. package/.claude/commands/truth/start.md +0 -143
  347. package/.claude/commands/validate-commands.js +0 -223
  348. package/.claude/commands/verify/check.md +0 -50
  349. package/.claude/commands/verify/start.md +0 -128
  350. package/.claude/commands/workflow.js +0 -606
  351. package/.claude/commands/workflows/README.md +0 -9
  352. package/.claude/commands/workflows/development.md +0 -78
  353. package/.claude/commands/workflows/research.md +0 -63
  354. package/.claude/commands/workflows/workflow-create.md +0 -25
  355. package/.claude/commands/workflows/workflow-execute.md +0 -25
  356. package/.claude/commands/workflows/workflow-export.md +0 -25
  357. package/.claude/coordinator-feedback-pattern.md +0 -326
  358. package/.claude/coordinator-patterns.md +0 -126
  359. package/.claude/core/agent-manager.js +0 -80
  360. package/.claude/core/agent-manager.js.map +0 -1
  361. package/.claude/core/config.js +0 -1221
  362. package/.claude/core/config.js.map +0 -1
  363. package/.claude/core/event-bus.js +0 -136
  364. package/.claude/core/event-bus.js.map +0 -1
  365. package/.claude/core/index.js +0 -6
  366. package/.claude/core/index.js.map +0 -1
  367. package/.claude/core/json-persistence.js +0 -112
  368. package/.claude/core/json-persistence.js.map +0 -1
  369. package/.claude/core/logger.js +0 -245
  370. package/.claude/core/logger.js.map +0 -1
  371. package/.claude/core/orchestrator-fixed.js +0 -236
  372. package/.claude/core/orchestrator-fixed.js.map +0 -1
  373. package/.claude/core/orchestrator.js +0 -1136
  374. package/.claude/core/orchestrator.js.map +0 -1
  375. package/.claude/core/persistence.js +0 -185
  376. package/.claude/core/persistence.js.map +0 -1
  377. package/.claude/core/project-manager.js +0 -80
  378. package/.claude/core/project-manager.js.map +0 -1
  379. package/.claude/core/slash-command.js +0 -24
  380. package/.claude/core/version.js +0 -35
  381. package/.claude/core/version.js.map +0 -1
  382. package/.claude/helpers/checkpoint-manager.sh +0 -251
  383. package/.claude/helpers/github-safe.js +0 -106
  384. package/.claude/helpers/github-setup.sh +0 -28
  385. package/.claude/helpers/quick-start.sh +0 -19
  386. package/.claude/helpers/setup-mcp.sh +0 -18
  387. package/.claude/helpers/standard-checkpoint-hooks.sh +0 -179
  388. package/.claude/hooks.json +0 -21
  389. package/.claude/logs/sprint1-hybrid-routing-v2-decision.json +0 -18
  390. package/.claude/redis-agent-dependencies.md +0 -494
  391. package/.claude/root-claude-distribute/CLAUDE.md +0 -428
  392. package/.claude/settings.json +0 -129
  393. package/.claude/settings.local.json +0 -33
  394. package/.claude/skills/CFN-LOOP-VALIDATION.md +0 -202
  395. package/.claude/skills/REDIS-COORDINATION.md +0 -187
  396. package/.claude/skills/SKILL.md +0 -229
  397. package/.claude/skills/ace-system/SKILL.md +0 -364
  398. package/.claude/skills/ace-system/add-bullet.sh +0 -145
  399. package/.claude/skills/ace-system/invoke-context-curate.sh +0 -192
  400. package/.claude/skills/ace-system/invoke-context-inject.sh +0 -166
  401. package/.claude/skills/ace-system/invoke-context-query.sh +0 -127
  402. package/.claude/skills/ace-system/invoke-context-reflect.sh +0 -98
  403. package/.claude/skills/ace-system/invoke-context-stats.sh +0 -188
  404. package/.claude/skills/ace-system/log-merge.sh +0 -67
  405. package/.claude/skills/ace-system/query-reflections.sh +0 -35
  406. package/.claude/skills/ace-system/store-reflection.sh +0 -149
  407. package/.claude/skills/ace-system/test-ace-skill.sh +0 -312
  408. package/.claude/skills/ace-system/update-reflection.sh +0 -41
  409. package/.claude/skills/agent-execution/execute-agent.sh +0 -126
  410. package/.claude/skills/agent-spawning/SKILL.md +0 -135
  411. package/.claude/skills/agent-spawning/agent-selection-guide.md +0 -814
  412. package/.claude/skills/agent-spawning/check-dependencies.sh +0 -30
  413. package/.claude/skills/agent-spawning/spawn-agent.sh +0 -263
  414. package/.claude/skills/agent-spawning/spawn-templates.sh +0 -613
  415. package/.claude/skills/analytics/description-refinement-guide.md +0 -164
  416. package/.claude/skills/analytics/log-skill-invocation.js +0 -122
  417. package/.claude/skills/analytics/run-production-criteria-tests.sh +0 -126
  418. package/.claude/skills/analytics/skill-analytics-dashboard.js +0 -113
  419. package/.claude/skills/analytics/skill-invocation-hook.sh +0 -28
  420. package/.claude/skills/analytics/skill-invocations.sql +0 -58
  421. package/.claude/skills/analytics/test-corpus.json +0 -32
  422. package/.claude/skills/analytics/test-data-generator.js +0 -115
  423. package/.claude/skills/analytics/test-manual-override-rate.js +0 -285
  424. package/.claude/skills/analytics/validate-skill-selection.js +0 -188
  425. package/.claude/skills/cfn-loop-validation/SKILL.md +0 -263
  426. package/.claude/skills/cfn-loop-validation/check-dependencies.sh +0 -31
  427. package/.claude/skills/cfn-loop-validation/config.json +0 -161
  428. package/.claude/skills/cfn-loop-validation/consensus-calculator.js +0 -477
  429. package/.claude/skills/cfn-loop-validation/evidence-chain.sql +0 -163
  430. package/.claude/skills/cfn-loop-validation/examples/README.md +0 -453
  431. package/.claude/skills/cfn-loop-validation/examples/coordinator-full-cfn-loop.sh +0 -234
  432. package/.claude/skills/cfn-loop-validation/examples/coordinator-loop2-consensus.sh +0 -132
  433. package/.claude/skills/cfn-loop-validation/examples/coordinator-loop3-gate.sh +0 -115
  434. package/.claude/skills/cfn-loop-validation/examples/coordinator-redis-integration.sh +0 -186
  435. package/.claude/skills/cfn-loop-validation/orchestrate-cfn-loop.sh +0 -252
  436. package/.claude/skills/cfn-loop-validation/validate-iteration.sh +0 -134
  437. package/.claude/skills/cfn-loop-validation.sh +0 -70
  438. package/.claude/skills/config-management/SKILL.md +0 -34
  439. package/.claude/skills/config-management/check-dependencies.sh +0 -56
  440. package/.claude/skills/config-management/config.json +0 -32
  441. package/.claude/skills/config-management/manage-config.sh +0 -113
  442. package/.claude/skills/consensus-calculator.js +0 -45
  443. package/.claude/skills/event-bus/SKILL.md +0 -412
  444. package/.claude/skills/event-bus/config.json +0 -111
  445. package/.claude/skills/event-bus/eventbus-wrapper.cjs +0 -69
  446. package/.claude/skills/event-bus/invoke-event-publish.sh +0 -147
  447. package/.claude/skills/event-bus/invoke-event-subscribe.sh +0 -171
  448. package/.claude/skills/event-bus/invoke-lifecycle-track.sh +0 -201
  449. package/.claude/skills/event-bus/test-event-bus.sh +0 -280
  450. package/.claude/skills/evidence-chain.sql +0 -66
  451. package/.claude/skills/fleet-manager/SKILL.md +0 -412
  452. package/.claude/skills/fleet-manager/config.json +0 -60
  453. package/.claude/skills/fleet-manager/invoke-fleet-allocate.sh +0 -182
  454. package/.claude/skills/fleet-manager/invoke-fleet-balance.sh +0 -239
  455. package/.claude/skills/fleet-manager/invoke-fleet-metrics.sh +0 -193
  456. package/.claude/skills/fleet-manager/invoke-fleet-register.sh +0 -124
  457. package/.claude/skills/fleet-manager/test-fleet-manager.sh +0 -345
  458. package/.claude/skills/hook-pipeline/SKILL.md +0 -148
  459. package/.claude/skills/hook-pipeline/auto-resolve.sh +0 -66
  460. package/.claude/skills/hook-pipeline/check-dependencies.sh +0 -40
  461. package/.claude/skills/hook-pipeline/feedback-resolver.sh +0 -452
  462. package/.claude/skills/hook-pipeline/post-edit-handler.sh +0 -154
  463. package/.claude/skills/hook-pipeline/security-scan.json +0 -60
  464. package/.claude/skills/hook-pipeline/security-scanner.sh +0 -121
  465. package/.claude/skills/hook-pipeline/test-root-warning-resolution.sh +0 -148
  466. package/.claude/skills/hybrid-routing/SKILL.md +0 -46
  467. package/.claude/skills/hybrid-routing/check-dependencies.sh +0 -52
  468. package/.claude/skills/hybrid-routing/config.json +0 -26
  469. package/.claude/skills/hybrid-routing/spawn-worker.sh +0 -44
  470. package/.claude/skills/process-lifecycle/SKILL.md +0 -39
  471. package/.claude/skills/process-lifecycle/check-dependencies.sh +0 -58
  472. package/.claude/skills/process-lifecycle/config.json +0 -39
  473. package/.claude/skills/process-lifecycle/process-manager.sh +0 -144
  474. package/.claude/skills/redis-coordination/AGENT_LOGGING.md +0 -280
  475. package/.claude/skills/redis-coordination/BZPOPMIN_FIX_SUMMARY.md +0 -209
  476. package/.claude/skills/redis-coordination/HEARTBEAT.md +0 -57
  477. package/.claude/skills/redis-coordination/HEARTBEAT_MONITORING.md +0 -267
  478. package/.claude/skills/redis-coordination/README.md +0 -64
  479. package/.claude/skills/redis-coordination/SECURITY_REVIEW.md +0 -25
  480. package/.claude/skills/redis-coordination/SHUTDOWN_HANDLING.md +0 -164
  481. package/.claude/skills/redis-coordination/SKILL.md +0 -118
  482. package/.claude/skills/redis-coordination/agent-log.sh +0 -124
  483. package/.claude/skills/redis-coordination/agent-recovery.sh +0 -75
  484. package/.claude/skills/redis-coordination/cancel-swarm.sh +0 -221
  485. package/.claude/skills/redis-coordination/cfn-loop-relaunch.sh +0 -29
  486. package/.claude/skills/redis-coordination/check-dependencies.sh +0 -32
  487. package/.claude/skills/redis-coordination/complete-swarm.sh +0 -75
  488. package/.claude/skills/redis-coordination/config.json +0 -61
  489. package/.claude/skills/redis-coordination/examples/README.md +0 -73
  490. package/.claude/skills/redis-coordination/examples/grafana-dashboard.json +0 -352
  491. package/.claude/skills/redis-coordination/examples/hierarchical-pattern.sh +0 -127
  492. package/.claude/skills/redis-coordination/examples/mesh-pattern.sh +0 -171
  493. package/.claude/skills/redis-coordination/examples/timeout-handling.sh +0 -227
  494. package/.claude/skills/redis-coordination/examples/waiting-mode-pattern.sh +0 -239
  495. package/.claude/skills/redis-coordination/get-agent-timeout.sh +0 -177
  496. package/.claude/skills/redis-coordination/heartbeat-functions.sh +0 -137
  497. package/.claude/skills/redis-coordination/heartbeat-protocol.md +0 -106
  498. package/.claude/skills/redis-coordination/heartbeat.sh +0 -126
  499. package/.claude/skills/redis-coordination/init-swarm.sh +0 -148
  500. package/.claude/skills/redis-coordination/invoke-redis-pattern.sh +0 -220
  501. package/.claude/skills/redis-coordination/invoke-waiting-mode.sh +0 -417
  502. package/.claude/skills/redis-coordination/list-active-swarms.sh +0 -147
  503. package/.claude/skills/redis-coordination/metrics-export.sh +0 -674
  504. package/.claude/skills/redis-coordination/metrics-schema.json +0 -66
  505. package/.claude/skills/redis-coordination/metrics-storage.md +0 -31
  506. package/.claude/skills/redis-coordination/monitor-heartbeats.sh +0 -101
  507. package/.claude/skills/redis-coordination/orchestrate-cfn-loop.sh +0 -993
  508. package/.claude/skills/redis-coordination/orchestrate-cfn-loop.sh.backup-1760949407 +0 -933
  509. package/.claude/skills/redis-coordination/phase4-wake-queue-test-report.md +0 -82
  510. package/.claude/skills/redis-coordination/priority-wake-mechanism.md +0 -75
  511. package/.claude/skills/redis-coordination/priority_wake.py +0 -134
  512. package/.claude/skills/redis-coordination/query-dlq.sh +0 -162
  513. package/.claude/skills/redis-coordination/redis-pattern.sh +0 -619
  514. package/.claude/skills/redis-coordination/send-heartbeat.sh +0 -73
  515. package/.claude/skills/redis-coordination/store-epic-context.sh +0 -123
  516. package/.claude/skills/redis-coordination/test-bzpopmin-fix.sh +0 -274
  517. package/.claude/skills/redis-coordination/test-cancel-swarm.sh +0 -276
  518. package/.claude/skills/redis-coordination/test-dlq.sh +0 -129
  519. package/.claude/skills/redis-coordination/test-iteration-feedback.sh +0 -320
  520. package/.claude/skills/redis-coordination/test-orchestrator.sh +0 -224
  521. package/.claude/skills/redis-coordination/test-priority-wake-phase4-unix.sh +0 -148
  522. package/.claude/skills/redis-coordination/test-priority-wake-phase4.sh +0 -163
  523. package/.claude/skills/redis-coordination/test-priority-wake.sh +0 -138
  524. package/.claude/skills/redis-coordination/test-quick-fix.sh +0 -81
  525. package/.claude/skills/redis-coordination/test-quorum-absolute.sh +0 -45
  526. package/.claude/skills/redis-coordination/test-quorum-fallback.sh +0 -68
  527. package/.claude/skills/redis-coordination/test-quorum-percentage.sh +0 -56
  528. package/.claude/skills/redis-coordination/test-quorum-with-retry.sh +0 -81
  529. package/.claude/skills/redis-coordination/test-quorum.sh +0 -57
  530. package/.claude/skills/redis-coordination/test-shutdown-handling.sh +0 -187
  531. package/.claude/skills/redis-coordination/test-shutdown.sh +0 -160
  532. package/.claude/skills/redis-coordination/test-utils-unix.sh +0 -97
  533. package/.claude/skills/redis-coordination/test-utils.sh +0 -97
  534. package/.claude/skills/redis-coordination/test-waiting-mode.sh +0 -59
  535. package/.claude/skills/redis-coordination/tests/dlq-functionality-test.sh +0 -102
  536. package/.claude/skills/redis-coordination/tests/edge-cases-test.sh +0 -99
  537. package/.claude/skills/redis-coordination/tests/integration-test.sh +0 -170
  538. package/.claude/skills/redis-coordination/tests/retry-mechanism-test.sh +0 -82
  539. package/.claude/skills/redis-coordination/tests/run-test-suite.sh +0 -92
  540. package/.claude/skills/redis-coordination/tests/test-heartbeat-monitoring.sh +0 -418
  541. package/.claude/skills/redis-coordination/tests/test-heartbeat-simple.sh +0 -124
  542. package/.claude/skills/redis-coordination/tests/test-utils.sh +0 -122
  543. package/.claude/skills/skill-builder/SKILL.md +0 -910
  544. package/.claude/skills/sqlite-memory/IMPLEMENTATION_REPORT.md +0 -393
  545. package/.claude/skills/sqlite-memory/QUICK_REFERENCE.md +0 -204
  546. package/.claude/skills/sqlite-memory/SKILL.md +0 -415
  547. package/.claude/skills/sqlite-memory/acl-queries.sql +0 -452
  548. package/.claude/skills/sqlite-memory/check-dependencies.sh +0 -36
  549. package/.claude/skills/sqlite-memory/config.json +0 -45
  550. package/.claude/skills/sqlite-memory/memory-cli.sh +0 -88
  551. package/.claude/skills/sqlite-memory/test-state-persistence.js +0 -187
  552. package/.claude/skills/sqlite-memory/ttl-cleanup.sh +0 -274
  553. package/.claude/skills/test-execution/SKILL.md +0 -128
  554. package/.claude/skills/test-execution/check-dependencies.sh +0 -36
  555. package/.claude/skills/test-execution/test-cache-reader.sh +0 -134
  556. package/.claude/skills/test-execution/test-concurrent-conflicts.sh +0 -115
  557. package/.claude/skills/test-execution/test-coordinator-pattern.sh +0 -109
  558. package/.claude/skills/test-execution-coordinator-pattern.md +0 -228
  559. package/.claude/skills/transparency-middleware/Cargo.toml +0 -18
  560. package/.claude/skills/transparency-middleware/SECURITY.md +0 -41
  561. package/.claude/skills/transparency-middleware/SKILL.md +0 -91
  562. package/.claude/skills/transparency-middleware/TEST_RESULTS.md +0 -174
  563. package/.claude/skills/transparency-middleware/config.json +0 -31
  564. package/.claude/skills/transparency-middleware/examples/basic-usage.ts +0 -39
  565. package/.claude/skills/transparency-middleware/examples/batch-processing.ts +0 -52
  566. package/.claude/skills/transparency-middleware/examples/custom-filtering.ts +0 -61
  567. package/.claude/skills/transparency-middleware/invoke-transparency-filter.sh +0 -98
  568. package/.claude/skills/transparency-middleware/invoke-transparency-init.sh +0 -224
  569. package/.claude/skills/transparency-middleware/invoke-transparency-level.sh +0 -333
  570. package/.claude/skills/transparency-middleware/invoke-transparency-metrics.sh +0 -345
  571. package/.claude/skills/transparency-middleware/invoke-transparency-observe.sh +0 -140
  572. package/.claude/skills/transparency-middleware/invoke-transparency-stop.sh +0 -235
  573. package/.claude/skills/transparency-middleware/memory_query.rs +0 -85
  574. package/.claude/skills/transparency-middleware/memory_repository.rs +0 -140
  575. package/.claude/skills/transparency-middleware/memory_schema.rs +0 -64
  576. package/.claude/skills/transparency-middleware/middleware-config.sh +0 -29
  577. package/.claude/skills/transparency-middleware/performance-benchmark.sh +0 -79
  578. package/.claude/skills/transparency-middleware/test-e2e.sh +0 -406
  579. package/.claude/skills/transparency-middleware/test-integration.sh +0 -162
  580. package/.claude/skills/transparency-middleware/test-transparency-skill.sh +0 -368
  581. package/.claude/skills/transparency-middleware/test-transparency-skill.sh.unix +0 -126
  582. package/.claude/skills/transparency-middleware/tests/input-validation.sh +0 -93
  583. package/.claude/skills/transparency-middleware/wrap-agent.sh +0 -132
  584. package/.claude/skills/web-portal/DESIGN.md +0 -117
  585. package/.claude/skills/web-portal/SKILL.md +0 -679
  586. package/.claude/skills/web-portal/invoke-portal-agents.sh +0 -129
  587. package/.claude/skills/web-portal/invoke-portal-dashboard.sh +0 -85
  588. package/.claude/skills/web-portal/invoke-portal-events.sh +0 -125
  589. package/.claude/skills/web-portal/invoke-portal-metrics.sh +0 -112
  590. package/.claude/skills/web-portal/invoke-portal-start.sh +0 -135
  591. package/.claude/skills/web-portal/invoke-portal-stop.sh +0 -121
  592. package/.claude/skills/web-portal/test-web-portal-skill.sh +0 -51
  593. package/.claude/skills/web-portal/validate-deployment.sh +0 -85
  594. package/.claude/slash-commands.json +0 -92
  595. package/.claude/spawn-pattern-examples.md +0 -500
  596. package/.claude/sprint-configs/cfn-naming-standardization.json +0 -729
  597. package/.claude/sprint-reports/sprint-1.4-self-correction-monitoring.json +0 -64
  598. package/.claude/swarm-memory.db +0 -0
  599. package/.claude/templates/agent-optimization-plan.md +0 -439
  600. package/.claude/templates/bulk-optimization-strategy.md +0 -367
  601. package/.claude/templates/cfn-loop-mechanics.md +0 -80
  602. package/.claude/templates/coordinator-patterns.md +0 -75
  603. package/.claude/templates/memory-operations.md +0 -200
  604. package/.claude/templates/post-edit-validation.md +0 -109
  605. package/.claude/templates/redis-coordination.md +0 -140
  606. package/.claude/templates/remaining-agent-analysis.md +0 -121
  607. package/.claude/templates/swarm-coordination.md +0 -103
  608. package/.claude/templates/team-dynamics.md +0 -82
  609. package/CLAUDE.md +0 -502
  610. package/dist/cli/cli-agent-context.test.js +0 -451
  611. package/dist/cli/cli-agent-context.test.js.map +0 -1
  612. package/dist/coordination/fleet-manager.test.js +0 -141
  613. package/dist/coordination/fleet-manager.test.js.map +0 -1
  614. package/dist/middleware/transparency-middleware.test.js +0 -184
  615. package/dist/middleware/transparency-middleware.test.js.map +0 -1
  616. package/readme/CLAUDE.md +0 -429
  617. /package/.claude/agents/{core-agents → cfn-dev-team/developers}/researcher.md +0 -0
  618. /package/.claude/commands/{README.md → cfn/README.md} +0 -0
  619. /package/.claude/commands/{auto-compact.md → cfn/auto-compact.md} +0 -0
  620. /package/.claude/commands/{cfn-claude-sync.md → cfn/cfn-claude-sync.md} +0 -0
  621. /package/.claude/commands/{cfn-loop-document.md → cfn/cfn-loop-document.md} +0 -0
  622. /package/.claude/commands/{claude-md.md → cfn/claude-md.md} +0 -0
  623. /package/.claude/commands/{claude-soul.md → cfn/claude-soul.md} +0 -0
  624. /package/.claude/commands/{context-query.md → cfn/context-query.md} +0 -0
  625. /package/.claude/commands/{cost-savings-off.md → cfn/cost-savings-off.md} +0 -0
  626. /package/.claude/commands/{cost-savings-on.md → cfn/cost-savings-on.md} +0 -0
  627. /package/.claude/commands/{cost-savings-status.md → cfn/cost-savings-status.md} +0 -0
  628. /package/.claude/commands/{custom-routing-activate.md → cfn/custom-routing-activate.md} +0 -0
  629. /package/.claude/commands/{custom-routing-deactivate.md → cfn/custom-routing-deactivate.md} +0 -0
  630. /package/.claude/commands/{dependency-recommendations.md → cfn/dependency-recommendations.md} +0 -0
  631. /package/.claude/commands/{fullstack.md → cfn/fullstack.md} +0 -0
  632. /package/.claude/commands/{github-commit.md → cfn/github-commit.md} +0 -0
  633. /package/.claude/commands/{github.md → cfn/github.md} +0 -0
  634. /package/.claude/commands/{hello-world-tests.md → cfn/hello-world-tests.md} +0 -0
  635. /package/.claude/commands/{hooks.md → cfn/hooks.md} +0 -0
  636. /package/.claude/commands/{launch-web-dashboard.md → cfn/launch-web-dashboard.md} +0 -0
  637. /package/.claude/commands/{metrics-summary.md → cfn/metrics-summary.md} +0 -0
  638. /package/.claude/commands/{neural.md → cfn/neural.md} +0 -0
  639. /package/.claude/commands/{parse-epic.md → cfn/parse-epic.md} +0 -0
  640. /package/.claude/commands/{performance.md → cfn/performance.md} +0 -0
  641. /package/.claude/commands/{sparc.md → cfn/sparc.md} +0 -0
  642. /package/.claude/commands/{suggest-improvements.md → cfn/suggest-improvements.md} +0 -0
  643. /package/.claude/commands/{suggest-templates.md → cfn/suggest-templates.md} +0 -0
  644. /package/.claude/commands/{swarm.md → cfn/swarm.md} +0 -0
  645. /package/.claude/commands/{switch-api.md → cfn/switch-api.md} +0 -0
  646. /package/.claude/commands/{workflow.md → cfn/workflow.md} +0 -0
  647. /package/.claude/hooks/{invoke-post-edit.sh → cfn-invoke-post-edit.sh} +0 -0
  648. /package/.claude/hooks/{post-edit.config.json → cfn-post-edit.config.json} +0 -0
  649. /package/.claude/skills/{agent-spawning → cfn-agent-spawning}/README.md +0 -0
  650. /package/.claude/skills/{analytics → cfn-analytics}/README.md +0 -0
  651. /package/.claude/skills/{config-management → cfn-config-management}/README.md +0 -0
  652. /package/.claude/skills/{event-bus → cfn-event-bus}/README.md +0 -0
  653. /package/.claude/skills/{fleet-manager → cfn-fleet-manager}/README.md +0 -0
  654. /package/.claude/skills/{hook-pipeline → cfn-hook-pipeline}/README.md +0 -0
  655. /package/.claude/skills/{hybrid-routing → cfn-hybrid-routing}/README.md +0 -0
  656. /package/.claude/skills/{process-lifecycle → cfn-process-lifecycle}/README.md +0 -0
  657. /package/.claude/skills/{sqlite-memory → cfn-sqlite-memory}/README.md +0 -0
  658. /package/.claude/skills/{test-execution → cfn-test-execution}/README.md +0 -0
  659. /package/.claude/skills/{transparency-middleware → cfn-transparency-middleware}/README.md +0 -0
@@ -1,451 +0,0 @@
1
- /**
2
- * Unit Tests for CLI Agent Context Builder
3
- *
4
- * Tests the buildCLIAgentSystemPrompt function that creates natural language
5
- * system prompts for CLI-spawned agents.
6
- */ import { buildCLIAgentSystemPrompt, loadContextFromEnv } from './cli-agent-context';
7
- import fs from 'fs/promises';
8
- // Mock fs module
9
- jest.mock('fs/promises');
10
- describe('CLI Agent Context Builder', ()=>{
11
- const mockFs = fs;
12
- beforeEach(()=>{
13
- // Reset all mocks before each test
14
- jest.clearAllMocks();
15
- });
16
- afterEach(()=>{
17
- // Clean up environment variables
18
- delete process.env.AGENT_TYPE;
19
- delete process.env.TASK_ID;
20
- delete process.env.ITERATION;
21
- delete process.env.EPIC_CONTEXT;
22
- delete process.env.PHASE_CONTEXT;
23
- delete process.env.SUCCESS_CRITERIA;
24
- });
25
- describe('buildCLIAgentSystemPrompt', ()=>{
26
- it('should build basic system prompt with agent type only', async ()=>{
27
- // Mock fs.readFile to fail (no CLAUDE.md, no agent template)
28
- mockFs.readFile.mockRejectedValue(new Error('File not found'));
29
- const options = {
30
- agentType: 'researcher'
31
- };
32
- const result = await buildCLIAgentSystemPrompt(options);
33
- expect(result).toBeTruthy();
34
- expect(result).toContain('Execution Instructions');
35
- expect(result).toContain('CLI-spawned agent');
36
- });
37
- it('should include CLAUDE.md when available', async ()=>{
38
- const claudeMd = '# Test Project Rules\nRule 1\nRule 2';
39
- mockFs.readFile.mockImplementation((path)=>{
40
- if (path.toString().endsWith('CLAUDE.md')) {
41
- return Promise.resolve(claudeMd);
42
- }
43
- return Promise.reject(new Error('File not found'));
44
- });
45
- const options = {
46
- agentType: 'researcher'
47
- };
48
- const result = await buildCLIAgentSystemPrompt(options);
49
- expect(result).toContain('Project Rules (CLAUDE.md)');
50
- expect(result).toContain('Test Project Rules');
51
- expect(result).toContain('Rule 1');
52
- });
53
- it('should include agent markdown template when available', async ()=>{
54
- const agentTemplate = '# Researcher Agent\n\nCore responsibilities:\n- Research\n- Analysis';
55
- mockFs.readFile.mockImplementation((path)=>{
56
- if (path.toString().includes('researcher.md')) {
57
- return Promise.resolve(agentTemplate);
58
- }
59
- return Promise.reject(new Error('File not found'));
60
- });
61
- const options = {
62
- agentType: 'researcher'
63
- };
64
- const result = await buildCLIAgentSystemPrompt(options);
65
- expect(result).toContain('Agent Definition: researcher');
66
- expect(result).toContain('Researcher Agent');
67
- expect(result).toContain('Core responsibilities');
68
- });
69
- it('should format epic context from JSON to natural language', async ()=>{
70
- mockFs.readFile.mockRejectedValue(new Error('File not found'));
71
- const epicContext = {
72
- epicGoal: 'Build authentication system',
73
- inScope: [
74
- 'JWT authentication',
75
- 'User login',
76
- 'Session management'
77
- ],
78
- outOfScope: [
79
- 'OAuth integration',
80
- 'SAML'
81
- ],
82
- riskProfile: 'medium'
83
- };
84
- const options = {
85
- agentType: 'researcher',
86
- epicContext: JSON.stringify(epicContext)
87
- };
88
- const result = await buildCLIAgentSystemPrompt(options);
89
- expect(result).toContain('## Epic Context');
90
- expect(result).toContain('**Epic Goal:**');
91
- expect(result).toContain('Build authentication system');
92
- expect(result).toContain('**In Scope:**');
93
- expect(result).toContain('- JWT authentication');
94
- expect(result).toContain('- User login');
95
- expect(result).toContain('**Out of Scope:**');
96
- expect(result).toContain('- OAuth integration');
97
- expect(result).toContain('**Risk Profile:** medium');
98
- });
99
- it('should format phase context from JSON to natural language', async ()=>{
100
- mockFs.readFile.mockRejectedValue(new Error('File not found'));
101
- const phaseContext = {
102
- currentPhase: 'Implementation',
103
- phaseNumber: 2,
104
- dependencies: [
105
- 'Design complete',
106
- 'API spec approved'
107
- ],
108
- deliverables: [
109
- 'Working authentication',
110
- 'Unit tests',
111
- 'Documentation'
112
- ]
113
- };
114
- const options = {
115
- agentType: 'researcher',
116
- phaseContext: JSON.stringify(phaseContext)
117
- };
118
- const result = await buildCLIAgentSystemPrompt(options);
119
- expect(result).toContain('## Current Phase');
120
- expect(result).toContain('**Phase:** Implementation');
121
- expect(result).toContain('**Phase Number:** 2');
122
- expect(result).toContain('**Dependencies:**');
123
- expect(result).toContain('- Design complete');
124
- expect(result).toContain('**Deliverables:**');
125
- expect(result).toContain('- Working authentication');
126
- });
127
- it('should format success criteria from JSON to natural language', async ()=>{
128
- mockFs.readFile.mockRejectedValue(new Error('File not found'));
129
- const successCriteria = {
130
- acceptanceCriteria: [
131
- 'All tests pass',
132
- 'Code coverage > 80%',
133
- 'Security review complete'
134
- ],
135
- gateThreshold: 0.75,
136
- consensusThreshold: 0.9,
137
- qualityGates: {
138
- testCoverage: 80,
139
- securityScore: 0.9,
140
- performanceBudget: 200
141
- }
142
- };
143
- const options = {
144
- agentType: 'researcher',
145
- successCriteria: JSON.stringify(successCriteria)
146
- };
147
- const result = await buildCLIAgentSystemPrompt(options);
148
- expect(result).toContain('## Success Criteria');
149
- expect(result).toContain('**Acceptance Criteria:**');
150
- expect(result).toContain('- All tests pass');
151
- expect(result).toContain('- Code coverage > 80%');
152
- expect(result).toContain('**Quality Gates:**');
153
- expect(result).toContain('- Gate Threshold (Loop 3): 75%');
154
- expect(result).toContain('- Consensus Threshold (Loop 2): 90%');
155
- expect(result).toContain('**Quality Metrics:**');
156
- expect(result).toContain('- Test Coverage: 80%');
157
- expect(result).toContain('- Security Score: 90%');
158
- expect(result).toContain('- Performance Budget: 200ms');
159
- });
160
- it('should include iteration context for iteration > 1', async ()=>{
161
- mockFs.readFile.mockRejectedValue(new Error('File not found'));
162
- const options = {
163
- agentType: 'researcher',
164
- taskId: 'task-123',
165
- iteration: 3
166
- };
167
- const result = await buildCLIAgentSystemPrompt(options);
168
- expect(result).toContain('## Current Iteration');
169
- expect(result).toContain('This is **iteration 3** of your task');
170
- expect(result).toContain('You have completed 2 iterations before this one');
171
- expect(result).toContain('Address feedback from previous iterations');
172
- });
173
- it('should not include iteration context for iteration 1', async ()=>{
174
- mockFs.readFile.mockRejectedValue(new Error('File not found'));
175
- const options = {
176
- agentType: 'researcher',
177
- taskId: 'task-123',
178
- iteration: 1
179
- };
180
- const result = await buildCLIAgentSystemPrompt(options);
181
- expect(result).not.toContain('## Current Iteration');
182
- });
183
- it('should handle malformed JSON gracefully', async ()=>{
184
- mockFs.readFile.mockRejectedValue(new Error('File not found'));
185
- const options = {
186
- agentType: 'researcher',
187
- epicContext: '{invalid json}',
188
- phaseContext: 'not json at all',
189
- successCriteria: ''
190
- };
191
- const result = await buildCLIAgentSystemPrompt(options);
192
- // Should not throw, and should still build basic prompt
193
- expect(result).toBeTruthy();
194
- expect(result).toContain('Execution Instructions');
195
- });
196
- it('should handle nil Redis values gracefully', async ()=>{
197
- mockFs.readFile.mockRejectedValue(new Error('File not found'));
198
- const options = {
199
- agentType: 'researcher',
200
- epicContext: '(nil)',
201
- phaseContext: '(nil)',
202
- successCriteria: '(nil)'
203
- };
204
- const result = await buildCLIAgentSystemPrompt(options);
205
- // Should not throw, and should not include empty sections
206
- expect(result).toBeTruthy();
207
- expect(result).not.toContain('## Epic Context');
208
- expect(result).not.toContain('## Current Phase');
209
- expect(result).not.toContain('## Success Criteria');
210
- });
211
- it('should build complete prompt with all sections', async ()=>{
212
- const claudeMd = '# Project Rules\nRule 1';
213
- const agentTemplate = '# Researcher\nResponsibilities';
214
- mockFs.readFile.mockImplementation((path)=>{
215
- if (path.toString().endsWith('CLAUDE.md')) {
216
- return Promise.resolve(claudeMd);
217
- }
218
- if (path.toString().includes('researcher.md')) {
219
- return Promise.resolve(agentTemplate);
220
- }
221
- return Promise.reject(new Error('File not found'));
222
- });
223
- const epicContext = {
224
- epicGoal: 'Test Epic',
225
- inScope: [
226
- 'Feature A'
227
- ],
228
- outOfScope: [
229
- 'Feature B'
230
- ]
231
- };
232
- const phaseContext = {
233
- currentPhase: 'Implementation',
234
- deliverables: [
235
- 'Code',
236
- 'Tests'
237
- ]
238
- };
239
- const successCriteria = {
240
- acceptanceCriteria: [
241
- 'All tests pass'
242
- ],
243
- gateThreshold: 0.75
244
- };
245
- const options = {
246
- agentType: 'researcher',
247
- taskId: 'task-123',
248
- iteration: 2,
249
- epicContext: JSON.stringify(epicContext),
250
- phaseContext: JSON.stringify(phaseContext),
251
- successCriteria: JSON.stringify(successCriteria)
252
- };
253
- const result = await buildCLIAgentSystemPrompt(options);
254
- // Check all sections are present
255
- expect(result).toContain('Project Rules (CLAUDE.md)');
256
- expect(result).toContain('Agent Definition: researcher');
257
- expect(result).toContain('## Epic Context');
258
- expect(result).toContain('## Current Phase');
259
- expect(result).toContain('## Success Criteria');
260
- expect(result).toContain('## Current Iteration');
261
- expect(result).toContain('## Execution Instructions');
262
- // Check separators
263
- expect(result.split('---').length).toBeGreaterThan(3);
264
- });
265
- });
266
- describe('loadContextFromEnv', ()=>{
267
- it('should load context from environment variables', ()=>{
268
- process.env.AGENT_TYPE = 'researcher';
269
- process.env.TASK_ID = 'task-123';
270
- process.env.ITERATION = '2';
271
- process.env.EPIC_CONTEXT = '{"epicGoal":"Test"}';
272
- process.env.PHASE_CONTEXT = '{"currentPhase":"Implementation"}';
273
- process.env.SUCCESS_CRITERIA = '{"gateThreshold":0.75}';
274
- const result = loadContextFromEnv();
275
- expect(result.agentType).toBe('researcher');
276
- expect(result.taskId).toBe('task-123');
277
- expect(result.iteration).toBe(2);
278
- expect(result.epicContext).toBe('{"epicGoal":"Test"}');
279
- expect(result.phaseContext).toBe('{"currentPhase":"Implementation"}');
280
- expect(result.successCriteria).toBe('{"gateThreshold":0.75}');
281
- });
282
- it('should handle missing environment variables', ()=>{
283
- const result = loadContextFromEnv();
284
- expect(result.agentType).toBe('unknown');
285
- expect(result.taskId).toBeUndefined();
286
- expect(result.iteration).toBe(1);
287
- expect(result.epicContext).toBeUndefined();
288
- });
289
- it('should parse iteration as number', ()=>{
290
- process.env.ITERATION = '5';
291
- const result = loadContextFromEnv();
292
- expect(result.iteration).toBe(5);
293
- expect(typeof result.iteration).toBe('number');
294
- });
295
- it('should default iteration to 1 if not provided', ()=>{
296
- const result = loadContextFromEnv();
297
- expect(result.iteration).toBe(1);
298
- });
299
- });
300
- describe('Epic Context Formatting', ()=>{
301
- it('should format epic with phases', async ()=>{
302
- mockFs.readFile.mockRejectedValue(new Error('File not found'));
303
- const epicContext = {
304
- epicGoal: 'Build system',
305
- phases: [
306
- 'Phase 1: Design',
307
- 'Phase 2: Implementation',
308
- 'Phase 3: Testing'
309
- ]
310
- };
311
- const options = {
312
- agentType: 'researcher',
313
- epicContext: JSON.stringify(epicContext)
314
- };
315
- const result = await buildCLIAgentSystemPrompt(options);
316
- expect(result).toContain('**Phases:**');
317
- expect(result).toContain('1. Phase 1: Design');
318
- expect(result).toContain('2. Phase 2: Implementation');
319
- expect(result).toContain('3. Phase 3: Testing');
320
- });
321
- it('should format epic with stakeholders', async ()=>{
322
- mockFs.readFile.mockRejectedValue(new Error('File not found'));
323
- const epicContext = {
324
- epicGoal: 'Build system',
325
- stakeholders: [
326
- 'Product Manager',
327
- 'Tech Lead',
328
- 'Security Team'
329
- ]
330
- };
331
- const options = {
332
- agentType: 'researcher',
333
- epicContext: JSON.stringify(epicContext)
334
- };
335
- const result = await buildCLIAgentSystemPrompt(options);
336
- expect(result).toContain('**Stakeholders:** Product Manager, Tech Lead, Security Team');
337
- });
338
- it('should format epic with timeline', async ()=>{
339
- mockFs.readFile.mockRejectedValue(new Error('File not found'));
340
- const epicContext = {
341
- epicGoal: 'Build system',
342
- timeline: {
343
- start: '2025-10-01',
344
- end: '2025-12-31',
345
- milestones: [
346
- {
347
- phase: 'Design',
348
- date: '2025-10-15'
349
- },
350
- {
351
- phase: 'Implementation',
352
- date: '2025-11-30'
353
- }
354
- ]
355
- }
356
- };
357
- const options = {
358
- agentType: 'researcher',
359
- epicContext: JSON.stringify(epicContext)
360
- };
361
- const result = await buildCLIAgentSystemPrompt(options);
362
- expect(result).toContain('**Timeline:**');
363
- expect(result).toContain('- Start: 2025-10-01');
364
- expect(result).toContain('- End: 2025-12-31');
365
- expect(result).toContain('- Milestones:');
366
- expect(result).toContain(' - Design: 2025-10-15');
367
- expect(result).toContain(' - Implementation: 2025-11-30');
368
- });
369
- });
370
- describe('Phase Context Formatting', ()=>{
371
- it('should format phase with blockers', async ()=>{
372
- mockFs.readFile.mockRejectedValue(new Error('File not found'));
373
- const phaseContext = {
374
- currentPhase: 'Implementation',
375
- blockers: [
376
- 'Waiting for API key',
377
- 'Database migration pending'
378
- ]
379
- };
380
- const options = {
381
- agentType: 'researcher',
382
- phaseContext: JSON.stringify(phaseContext)
383
- };
384
- const result = await buildCLIAgentSystemPrompt(options);
385
- expect(result).toContain('**Current Blockers:**');
386
- expect(result).toContain('- Waiting for API key');
387
- expect(result).toContain('- Database migration pending');
388
- });
389
- it('should format phase with resources', async ()=>{
390
- mockFs.readFile.mockRejectedValue(new Error('File not found'));
391
- const phaseContext = {
392
- currentPhase: 'Implementation',
393
- resources: {
394
- agentCount: 5,
395
- estimatedDuration: 3,
396
- costBudget: 2.5
397
- }
398
- };
399
- const options = {
400
- agentType: 'researcher',
401
- phaseContext: JSON.stringify(phaseContext)
402
- };
403
- const result = await buildCLIAgentSystemPrompt(options);
404
- expect(result).toContain('**Resources:**');
405
- expect(result).toContain('- Agents: 5');
406
- expect(result).toContain('- Duration: 3 hours');
407
- expect(result).toContain('- Budget: $2.50');
408
- });
409
- });
410
- describe('Success Criteria Formatting', ()=>{
411
- it('should format success criteria with definition of done', async ()=>{
412
- mockFs.readFile.mockRejectedValue(new Error('File not found'));
413
- const successCriteria = {
414
- definitionOfDone: [
415
- 'All tests pass',
416
- 'Code reviewed',
417
- 'Documentation complete'
418
- ]
419
- };
420
- const options = {
421
- agentType: 'researcher',
422
- successCriteria: JSON.stringify(successCriteria)
423
- };
424
- const result = await buildCLIAgentSystemPrompt(options);
425
- expect(result).toContain('**Definition of Done:**');
426
- expect(result).toContain('- [ ] All tests pass');
427
- expect(result).toContain('- [ ] Code reviewed');
428
- expect(result).toContain('- [ ] Documentation complete');
429
- });
430
- it('should format success criteria with non-functional requirements', async ()=>{
431
- mockFs.readFile.mockRejectedValue(new Error('File not found'));
432
- const successCriteria = {
433
- nonFunctionalRequirements: [
434
- 'Response time < 200ms',
435
- 'Support 1000 concurrent users',
436
- 'WCAG 2.1 AA compliance'
437
- ]
438
- };
439
- const options = {
440
- agentType: 'researcher',
441
- successCriteria: JSON.stringify(successCriteria)
442
- };
443
- const result = await buildCLIAgentSystemPrompt(options);
444
- expect(result).toContain('**Non-Functional Requirements:**');
445
- expect(result).toContain('- Response time < 200ms');
446
- expect(result).toContain('- Support 1000 concurrent users');
447
- });
448
- });
449
- });
450
-
451
- //# sourceMappingURL=cli-agent-context.test.js.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../../src/cli/cli-agent-context.test.ts"],"sourcesContent":["/**\r\n * Unit Tests for CLI Agent Context Builder\r\n *\r\n * Tests the buildCLIAgentSystemPrompt function that creates natural language\r\n * system prompts for CLI-spawned agents.\r\n */\r\n\r\nimport {\r\n buildCLIAgentSystemPrompt,\r\n loadContextFromEnv,\r\n type ContextBuilderOptions,\r\n type EpicContext,\r\n type PhaseContext,\r\n type SuccessCriteria,\r\n} from './cli-agent-context';\r\nimport fs from 'fs/promises';\r\n\r\n// Mock fs module\r\njest.mock('fs/promises');\r\n\r\ndescribe('CLI Agent Context Builder', () => {\r\n const mockFs = fs as jest.Mocked<typeof fs>;\r\n\r\n beforeEach(() => {\r\n // Reset all mocks before each test\r\n jest.clearAllMocks();\r\n });\r\n\r\n afterEach(() => {\r\n // Clean up environment variables\r\n delete process.env.AGENT_TYPE;\r\n delete process.env.TASK_ID;\r\n delete process.env.ITERATION;\r\n delete process.env.EPIC_CONTEXT;\r\n delete process.env.PHASE_CONTEXT;\r\n delete process.env.SUCCESS_CRITERIA;\r\n });\r\n\r\n describe('buildCLIAgentSystemPrompt', () => {\r\n it('should build basic system prompt with agent type only', async () => {\r\n // Mock fs.readFile to fail (no CLAUDE.md, no agent template)\r\n mockFs.readFile.mockRejectedValue(new Error('File not found'));\r\n\r\n const options: ContextBuilderOptions = {\r\n agentType: 'researcher',\r\n };\r\n\r\n const result = await buildCLIAgentSystemPrompt(options);\r\n\r\n expect(result).toBeTruthy();\r\n expect(result).toContain('Execution Instructions');\r\n expect(result).toContain('CLI-spawned agent');\r\n });\r\n\r\n it('should include CLAUDE.md when available', async () => {\r\n const claudeMd = '# Test Project Rules\\nRule 1\\nRule 2';\r\n\r\n mockFs.readFile.mockImplementation((path: any) => {\r\n if (path.toString().endsWith('CLAUDE.md')) {\r\n return Promise.resolve(claudeMd);\r\n }\r\n return Promise.reject(new Error('File not found'));\r\n });\r\n\r\n const options: ContextBuilderOptions = {\r\n agentType: 'researcher',\r\n };\r\n\r\n const result = await buildCLIAgentSystemPrompt(options);\r\n\r\n expect(result).toContain('Project Rules (CLAUDE.md)');\r\n expect(result).toContain('Test Project Rules');\r\n expect(result).toContain('Rule 1');\r\n });\r\n\r\n it('should include agent markdown template when available', async () => {\r\n const agentTemplate = '# Researcher Agent\\n\\nCore responsibilities:\\n- Research\\n- Analysis';\r\n\r\n mockFs.readFile.mockImplementation((path: any) => {\r\n if (path.toString().includes('researcher.md')) {\r\n return Promise.resolve(agentTemplate);\r\n }\r\n return Promise.reject(new Error('File not found'));\r\n });\r\n\r\n const options: ContextBuilderOptions = {\r\n agentType: 'researcher',\r\n };\r\n\r\n const result = await buildCLIAgentSystemPrompt(options);\r\n\r\n expect(result).toContain('Agent Definition: researcher');\r\n expect(result).toContain('Researcher Agent');\r\n expect(result).toContain('Core responsibilities');\r\n });\r\n\r\n it('should format epic context from JSON to natural language', async () => {\r\n mockFs.readFile.mockRejectedValue(new Error('File not found'));\r\n\r\n const epicContext: EpicContext = {\r\n epicGoal: 'Build authentication system',\r\n inScope: ['JWT authentication', 'User login', 'Session management'],\r\n outOfScope: ['OAuth integration', 'SAML'],\r\n riskProfile: 'medium',\r\n };\r\n\r\n const options: ContextBuilderOptions = {\r\n agentType: 'researcher',\r\n epicContext: JSON.stringify(epicContext),\r\n };\r\n\r\n const result = await buildCLIAgentSystemPrompt(options);\r\n\r\n expect(result).toContain('## Epic Context');\r\n expect(result).toContain('**Epic Goal:**');\r\n expect(result).toContain('Build authentication system');\r\n expect(result).toContain('**In Scope:**');\r\n expect(result).toContain('- JWT authentication');\r\n expect(result).toContain('- User login');\r\n expect(result).toContain('**Out of Scope:**');\r\n expect(result).toContain('- OAuth integration');\r\n expect(result).toContain('**Risk Profile:** medium');\r\n });\r\n\r\n it('should format phase context from JSON to natural language', async () => {\r\n mockFs.readFile.mockRejectedValue(new Error('File not found'));\r\n\r\n const phaseContext: PhaseContext = {\r\n currentPhase: 'Implementation',\r\n phaseNumber: 2,\r\n dependencies: ['Design complete', 'API spec approved'],\r\n deliverables: ['Working authentication', 'Unit tests', 'Documentation'],\r\n };\r\n\r\n const options: ContextBuilderOptions = {\r\n agentType: 'researcher',\r\n phaseContext: JSON.stringify(phaseContext),\r\n };\r\n\r\n const result = await buildCLIAgentSystemPrompt(options);\r\n\r\n expect(result).toContain('## Current Phase');\r\n expect(result).toContain('**Phase:** Implementation');\r\n expect(result).toContain('**Phase Number:** 2');\r\n expect(result).toContain('**Dependencies:**');\r\n expect(result).toContain('- Design complete');\r\n expect(result).toContain('**Deliverables:**');\r\n expect(result).toContain('- Working authentication');\r\n });\r\n\r\n it('should format success criteria from JSON to natural language', async () => {\r\n mockFs.readFile.mockRejectedValue(new Error('File not found'));\r\n\r\n const successCriteria: SuccessCriteria = {\r\n acceptanceCriteria: [\r\n 'All tests pass',\r\n 'Code coverage > 80%',\r\n 'Security review complete',\r\n ],\r\n gateThreshold: 0.75,\r\n consensusThreshold: 0.9,\r\n qualityGates: {\r\n testCoverage: 80,\r\n securityScore: 0.9,\r\n performanceBudget: 200,\r\n },\r\n };\r\n\r\n const options: ContextBuilderOptions = {\r\n agentType: 'researcher',\r\n successCriteria: JSON.stringify(successCriteria),\r\n };\r\n\r\n const result = await buildCLIAgentSystemPrompt(options);\r\n\r\n expect(result).toContain('## Success Criteria');\r\n expect(result).toContain('**Acceptance Criteria:**');\r\n expect(result).toContain('- All tests pass');\r\n expect(result).toContain('- Code coverage > 80%');\r\n expect(result).toContain('**Quality Gates:**');\r\n expect(result).toContain('- Gate Threshold (Loop 3): 75%');\r\n expect(result).toContain('- Consensus Threshold (Loop 2): 90%');\r\n expect(result).toContain('**Quality Metrics:**');\r\n expect(result).toContain('- Test Coverage: 80%');\r\n expect(result).toContain('- Security Score: 90%');\r\n expect(result).toContain('- Performance Budget: 200ms');\r\n });\r\n\r\n it('should include iteration context for iteration > 1', async () => {\r\n mockFs.readFile.mockRejectedValue(new Error('File not found'));\r\n\r\n const options: ContextBuilderOptions = {\r\n agentType: 'researcher',\r\n taskId: 'task-123',\r\n iteration: 3,\r\n };\r\n\r\n const result = await buildCLIAgentSystemPrompt(options);\r\n\r\n expect(result).toContain('## Current Iteration');\r\n expect(result).toContain('This is **iteration 3** of your task');\r\n expect(result).toContain('You have completed 2 iterations before this one');\r\n expect(result).toContain('Address feedback from previous iterations');\r\n });\r\n\r\n it('should not include iteration context for iteration 1', async () => {\r\n mockFs.readFile.mockRejectedValue(new Error('File not found'));\r\n\r\n const options: ContextBuilderOptions = {\r\n agentType: 'researcher',\r\n taskId: 'task-123',\r\n iteration: 1,\r\n };\r\n\r\n const result = await buildCLIAgentSystemPrompt(options);\r\n\r\n expect(result).not.toContain('## Current Iteration');\r\n });\r\n\r\n it('should handle malformed JSON gracefully', async () => {\r\n mockFs.readFile.mockRejectedValue(new Error('File not found'));\r\n\r\n const options: ContextBuilderOptions = {\r\n agentType: 'researcher',\r\n epicContext: '{invalid json}',\r\n phaseContext: 'not json at all',\r\n successCriteria: '',\r\n };\r\n\r\n const result = await buildCLIAgentSystemPrompt(options);\r\n\r\n // Should not throw, and should still build basic prompt\r\n expect(result).toBeTruthy();\r\n expect(result).toContain('Execution Instructions');\r\n });\r\n\r\n it('should handle nil Redis values gracefully', async () => {\r\n mockFs.readFile.mockRejectedValue(new Error('File not found'));\r\n\r\n const options: ContextBuilderOptions = {\r\n agentType: 'researcher',\r\n epicContext: '(nil)',\r\n phaseContext: '(nil)',\r\n successCriteria: '(nil)',\r\n };\r\n\r\n const result = await buildCLIAgentSystemPrompt(options);\r\n\r\n // Should not throw, and should not include empty sections\r\n expect(result).toBeTruthy();\r\n expect(result).not.toContain('## Epic Context');\r\n expect(result).not.toContain('## Current Phase');\r\n expect(result).not.toContain('## Success Criteria');\r\n });\r\n\r\n it('should build complete prompt with all sections', async () => {\r\n const claudeMd = '# Project Rules\\nRule 1';\r\n const agentTemplate = '# Researcher\\nResponsibilities';\r\n\r\n mockFs.readFile.mockImplementation((path: any) => {\r\n if (path.toString().endsWith('CLAUDE.md')) {\r\n return Promise.resolve(claudeMd);\r\n }\r\n if (path.toString().includes('researcher.md')) {\r\n return Promise.resolve(agentTemplate);\r\n }\r\n return Promise.reject(new Error('File not found'));\r\n });\r\n\r\n const epicContext: EpicContext = {\r\n epicGoal: 'Test Epic',\r\n inScope: ['Feature A'],\r\n outOfScope: ['Feature B'],\r\n };\r\n\r\n const phaseContext: PhaseContext = {\r\n currentPhase: 'Implementation',\r\n deliverables: ['Code', 'Tests'],\r\n };\r\n\r\n const successCriteria: SuccessCriteria = {\r\n acceptanceCriteria: ['All tests pass'],\r\n gateThreshold: 0.75,\r\n };\r\n\r\n const options: ContextBuilderOptions = {\r\n agentType: 'researcher',\r\n taskId: 'task-123',\r\n iteration: 2,\r\n epicContext: JSON.stringify(epicContext),\r\n phaseContext: JSON.stringify(phaseContext),\r\n successCriteria: JSON.stringify(successCriteria),\r\n };\r\n\r\n const result = await buildCLIAgentSystemPrompt(options);\r\n\r\n // Check all sections are present\r\n expect(result).toContain('Project Rules (CLAUDE.md)');\r\n expect(result).toContain('Agent Definition: researcher');\r\n expect(result).toContain('## Epic Context');\r\n expect(result).toContain('## Current Phase');\r\n expect(result).toContain('## Success Criteria');\r\n expect(result).toContain('## Current Iteration');\r\n expect(result).toContain('## Execution Instructions');\r\n\r\n // Check separators\r\n expect(result.split('---').length).toBeGreaterThan(3);\r\n });\r\n });\r\n\r\n describe('loadContextFromEnv', () => {\r\n it('should load context from environment variables', () => {\r\n process.env.AGENT_TYPE = 'researcher';\r\n process.env.TASK_ID = 'task-123';\r\n process.env.ITERATION = '2';\r\n process.env.EPIC_CONTEXT = '{\"epicGoal\":\"Test\"}';\r\n process.env.PHASE_CONTEXT = '{\"currentPhase\":\"Implementation\"}';\r\n process.env.SUCCESS_CRITERIA = '{\"gateThreshold\":0.75}';\r\n\r\n const result = loadContextFromEnv();\r\n\r\n expect(result.agentType).toBe('researcher');\r\n expect(result.taskId).toBe('task-123');\r\n expect(result.iteration).toBe(2);\r\n expect(result.epicContext).toBe('{\"epicGoal\":\"Test\"}');\r\n expect(result.phaseContext).toBe('{\"currentPhase\":\"Implementation\"}');\r\n expect(result.successCriteria).toBe('{\"gateThreshold\":0.75}');\r\n });\r\n\r\n it('should handle missing environment variables', () => {\r\n const result = loadContextFromEnv();\r\n\r\n expect(result.agentType).toBe('unknown');\r\n expect(result.taskId).toBeUndefined();\r\n expect(result.iteration).toBe(1);\r\n expect(result.epicContext).toBeUndefined();\r\n });\r\n\r\n it('should parse iteration as number', () => {\r\n process.env.ITERATION = '5';\r\n\r\n const result = loadContextFromEnv();\r\n\r\n expect(result.iteration).toBe(5);\r\n expect(typeof result.iteration).toBe('number');\r\n });\r\n\r\n it('should default iteration to 1 if not provided', () => {\r\n const result = loadContextFromEnv();\r\n\r\n expect(result.iteration).toBe(1);\r\n });\r\n });\r\n\r\n describe('Epic Context Formatting', () => {\r\n it('should format epic with phases', async () => {\r\n mockFs.readFile.mockRejectedValue(new Error('File not found'));\r\n\r\n const epicContext: EpicContext = {\r\n epicGoal: 'Build system',\r\n phases: ['Phase 1: Design', 'Phase 2: Implementation', 'Phase 3: Testing'],\r\n };\r\n\r\n const options: ContextBuilderOptions = {\r\n agentType: 'researcher',\r\n epicContext: JSON.stringify(epicContext),\r\n };\r\n\r\n const result = await buildCLIAgentSystemPrompt(options);\r\n\r\n expect(result).toContain('**Phases:**');\r\n expect(result).toContain('1. Phase 1: Design');\r\n expect(result).toContain('2. Phase 2: Implementation');\r\n expect(result).toContain('3. Phase 3: Testing');\r\n });\r\n\r\n it('should format epic with stakeholders', async () => {\r\n mockFs.readFile.mockRejectedValue(new Error('File not found'));\r\n\r\n const epicContext: EpicContext = {\r\n epicGoal: 'Build system',\r\n stakeholders: ['Product Manager', 'Tech Lead', 'Security Team'],\r\n };\r\n\r\n const options: ContextBuilderOptions = {\r\n agentType: 'researcher',\r\n epicContext: JSON.stringify(epicContext),\r\n };\r\n\r\n const result = await buildCLIAgentSystemPrompt(options);\r\n\r\n expect(result).toContain('**Stakeholders:** Product Manager, Tech Lead, Security Team');\r\n });\r\n\r\n it('should format epic with timeline', async () => {\r\n mockFs.readFile.mockRejectedValue(new Error('File not found'));\r\n\r\n const epicContext: EpicContext = {\r\n epicGoal: 'Build system',\r\n timeline: {\r\n start: '2025-10-01',\r\n end: '2025-12-31',\r\n milestones: [\r\n { phase: 'Design', date: '2025-10-15' },\r\n { phase: 'Implementation', date: '2025-11-30' },\r\n ],\r\n },\r\n };\r\n\r\n const options: ContextBuilderOptions = {\r\n agentType: 'researcher',\r\n epicContext: JSON.stringify(epicContext),\r\n };\r\n\r\n const result = await buildCLIAgentSystemPrompt(options);\r\n\r\n expect(result).toContain('**Timeline:**');\r\n expect(result).toContain('- Start: 2025-10-01');\r\n expect(result).toContain('- End: 2025-12-31');\r\n expect(result).toContain('- Milestones:');\r\n expect(result).toContain(' - Design: 2025-10-15');\r\n expect(result).toContain(' - Implementation: 2025-11-30');\r\n });\r\n });\r\n\r\n describe('Phase Context Formatting', () => {\r\n it('should format phase with blockers', async () => {\r\n mockFs.readFile.mockRejectedValue(new Error('File not found'));\r\n\r\n const phaseContext: PhaseContext = {\r\n currentPhase: 'Implementation',\r\n blockers: ['Waiting for API key', 'Database migration pending'],\r\n };\r\n\r\n const options: ContextBuilderOptions = {\r\n agentType: 'researcher',\r\n phaseContext: JSON.stringify(phaseContext),\r\n };\r\n\r\n const result = await buildCLIAgentSystemPrompt(options);\r\n\r\n expect(result).toContain('**Current Blockers:**');\r\n expect(result).toContain('- Waiting for API key');\r\n expect(result).toContain('- Database migration pending');\r\n });\r\n\r\n it('should format phase with resources', async () => {\r\n mockFs.readFile.mockRejectedValue(new Error('File not found'));\r\n\r\n const phaseContext: PhaseContext = {\r\n currentPhase: 'Implementation',\r\n resources: {\r\n agentCount: 5,\r\n estimatedDuration: 3,\r\n costBudget: 2.5,\r\n },\r\n };\r\n\r\n const options: ContextBuilderOptions = {\r\n agentType: 'researcher',\r\n phaseContext: JSON.stringify(phaseContext),\r\n };\r\n\r\n const result = await buildCLIAgentSystemPrompt(options);\r\n\r\n expect(result).toContain('**Resources:**');\r\n expect(result).toContain('- Agents: 5');\r\n expect(result).toContain('- Duration: 3 hours');\r\n expect(result).toContain('- Budget: $2.50');\r\n });\r\n });\r\n\r\n describe('Success Criteria Formatting', () => {\r\n it('should format success criteria with definition of done', async () => {\r\n mockFs.readFile.mockRejectedValue(new Error('File not found'));\r\n\r\n const successCriteria: SuccessCriteria = {\r\n definitionOfDone: [\r\n 'All tests pass',\r\n 'Code reviewed',\r\n 'Documentation complete',\r\n ],\r\n };\r\n\r\n const options: ContextBuilderOptions = {\r\n agentType: 'researcher',\r\n successCriteria: JSON.stringify(successCriteria),\r\n };\r\n\r\n const result = await buildCLIAgentSystemPrompt(options);\r\n\r\n expect(result).toContain('**Definition of Done:**');\r\n expect(result).toContain('- [ ] All tests pass');\r\n expect(result).toContain('- [ ] Code reviewed');\r\n expect(result).toContain('- [ ] Documentation complete');\r\n });\r\n\r\n it('should format success criteria with non-functional requirements', async () => {\r\n mockFs.readFile.mockRejectedValue(new Error('File not found'));\r\n\r\n const successCriteria: SuccessCriteria = {\r\n nonFunctionalRequirements: [\r\n 'Response time < 200ms',\r\n 'Support 1000 concurrent users',\r\n 'WCAG 2.1 AA compliance',\r\n ],\r\n };\r\n\r\n const options: ContextBuilderOptions = {\r\n agentType: 'researcher',\r\n successCriteria: JSON.stringify(successCriteria),\r\n };\r\n\r\n const result = await buildCLIAgentSystemPrompt(options);\r\n\r\n expect(result).toContain('**Non-Functional Requirements:**');\r\n expect(result).toContain('- Response time < 200ms');\r\n expect(result).toContain('- Support 1000 concurrent users');\r\n });\r\n });\r\n});\r\n"],"names":["buildCLIAgentSystemPrompt","loadContextFromEnv","fs","jest","mock","describe","mockFs","beforeEach","clearAllMocks","afterEach","process","env","AGENT_TYPE","TASK_ID","ITERATION","EPIC_CONTEXT","PHASE_CONTEXT","SUCCESS_CRITERIA","it","readFile","mockRejectedValue","Error","options","agentType","result","expect","toBeTruthy","toContain","claudeMd","mockImplementation","path","toString","endsWith","Promise","resolve","reject","agentTemplate","includes","epicContext","epicGoal","inScope","outOfScope","riskProfile","JSON","stringify","phaseContext","currentPhase","phaseNumber","dependencies","deliverables","successCriteria","acceptanceCriteria","gateThreshold","consensusThreshold","qualityGates","testCoverage","securityScore","performanceBudget","taskId","iteration","not","split","length","toBeGreaterThan","toBe","toBeUndefined","phases","stakeholders","timeline","start","end","milestones","phase","date","blockers","resources","agentCount","estimatedDuration","costBudget","definitionOfDone","nonFunctionalRequirements"],"mappings":"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"}
@@ -1,141 +0,0 @@
1
- import { FleetManager } from './fleet-manager';
2
- import { ResourceTier } from './types/fleet-manager.types';
3
- describe('FleetManager', ()=>{
4
- let fleetManager;
5
- let mockRedis;
6
- let mockAgentRegistry;
7
- let mockDependencyTracker;
8
- let mockTransparencyMiddleware;
9
- beforeEach(()=>{
10
- mockRedis = {
11
- hset: jest.fn().mockResolvedValue(true),
12
- sadd: jest.fn().mockResolvedValue(true)
13
- };
14
- mockAgentRegistry = {
15
- registerAgent: jest.fn().mockResolvedValue(true)
16
- };
17
- mockDependencyTracker = {};
18
- mockTransparencyMiddleware = {
19
- logEvent: jest.fn()
20
- };
21
- fleetManager = new FleetManager(mockRedis, mockAgentRegistry, mockDependencyTracker, mockTransparencyMiddleware, {
22
- maxAgents: 10,
23
- resourceAllocationStrategy: 'least-loaded'
24
- });
25
- });
26
- describe('registerAgent', ()=>{
27
- it('should successfully register an agent', async ()=>{
28
- const agentId = 'test-agent-1';
29
- const result = await fleetManager.registerAgent(agentId, ResourceTier.Shared);
30
- expect(result).toBe(true);
31
- expect(mockAgentRegistry.registerAgent).toHaveBeenCalledWith(agentId);
32
- expect(mockRedis.hset).toHaveBeenCalledWith(`fleet:agents:${agentId}`, 'tier', ResourceTier.Shared);
33
- expect(mockRedis.sadd).toHaveBeenCalledWith('fleet:registered_agents', agentId);
34
- expect(mockTransparencyMiddleware.logEvent).toHaveBeenCalledWith('fleet_manager', 'agent_registered', {
35
- agentId,
36
- tier: ResourceTier.Shared
37
- });
38
- });
39
- it('should not register an agent if registry fails', async ()=>{
40
- mockAgentRegistry.registerAgent.mockResolvedValue(false);
41
- const agentId = 'test-agent-2';
42
- const result = await fleetManager.registerAgent(agentId);
43
- expect(result).toBe(false);
44
- expect(mockTransparencyMiddleware.logEvent).toHaveBeenCalledWith('fleet_manager', 'agent_registration_failed', {
45
- agentId
46
- });
47
- });
48
- it('should not register more agents than maxAgents', async ()=>{
49
- const mockConfig = {
50
- maxAgents: 1
51
- };
52
- fleetManager = new FleetManager(mockRedis, mockAgentRegistry, mockDependencyTracker, mockTransparencyMiddleware, mockConfig);
53
- const result1 = await fleetManager.registerAgent('agent-1');
54
- const result2 = await fleetManager.registerAgent('agent-2');
55
- expect(result1).toBe(true);
56
- expect(result2).toBe(false);
57
- expect(mockTransparencyMiddleware.logEvent).toHaveBeenCalledWith('fleet_manager', 'max_agents_reached', {
58
- currentCount: 1,
59
- maxAgents: 1
60
- });
61
- });
62
- });
63
- describe('allocateResources', ()=>{
64
- it('should successfully allocate resources for an existing agent', async ()=>{
65
- const agentId = 'test-agent-3';
66
- await fleetManager.registerAgent(agentId);
67
- const requirements = {
68
- cpu: 2,
69
- memory: 4,
70
- network: 50,
71
- storageIO: 100
72
- };
73
- const result = await fleetManager.allocateResources(agentId, requirements);
74
- expect(result).toBe(true);
75
- expect(mockRedis.hset).toHaveBeenCalledWith(`fleet:agents:${agentId}`, 'resources', JSON.stringify(requirements));
76
- expect(mockTransparencyMiddleware.logEvent).toHaveBeenCalledWith('fleet_manager', 'resources_allocated', {
77
- agentId,
78
- requirements
79
- });
80
- });
81
- it('should not allocate resources for a non-existent agent', async ()=>{
82
- const requirements = {
83
- cpu: 2,
84
- memory: 4,
85
- network: 50,
86
- storageIO: 100
87
- };
88
- const result = await fleetManager.allocateResources('unknown-agent', requirements);
89
- expect(result).toBe(false);
90
- });
91
- it('should not allocate resources exceeding tier limits', async ()=>{
92
- const agentId = 'test-agent-4';
93
- await fleetManager.registerAgent(agentId, ResourceTier.Shared);
94
- const excessiveRequirements = {
95
- cpu: 20,
96
- memory: 40,
97
- network: 500,
98
- storageIO: 1000
99
- };
100
- const result = await fleetManager.allocateResources(agentId, excessiveRequirements);
101
- expect(result).toBe(false);
102
- expect(mockTransparencyMiddleware.logEvent).toHaveBeenCalledWith('fleet_manager', 'resource_allocation_denied', {
103
- agentId,
104
- requirements: excessiveRequirements,
105
- tier: ResourceTier.Shared
106
- });
107
- });
108
- });
109
- describe('getPerformanceMetrics', ()=>{
110
- it('should return performance metrics for a registered agent', async ()=>{
111
- const agentId = 'test-agent-5';
112
- await fleetManager.registerAgent(agentId);
113
- const metrics = await fleetManager.getPerformanceMetrics(agentId);
114
- expect(metrics).toBeDefined();
115
- expect(metrics?.cpuUtilization).toBe(0);
116
- expect(metrics?.memoryUsage).toBe(0);
117
- expect(metrics?.networkThroughput).toBe(0);
118
- expect(metrics?.storageIOPS).toBe(0);
119
- });
120
- it('should return null for a non-existent agent', async ()=>{
121
- const metrics = await fleetManager.getPerformanceMetrics('unknown-agent');
122
- expect(metrics).toBeNull();
123
- });
124
- });
125
- describe('balanceLoad', ()=>{
126
- it('should return a load balancing result based on the configured strategy', async ()=>{
127
- const agents = [
128
- 'agent-1',
129
- 'agent-2',
130
- 'agent-3'
131
- ];
132
- const result = await fleetManager.balanceLoad(agents);
133
- expect(result).toEqual({
134
- rebalancedAgents: [],
135
- migrationPlan: {}
136
- });
137
- });
138
- });
139
- });
140
-
141
- //# sourceMappingURL=fleet-manager.test.js.map