claude-code-workflow 7.2.30 → 7.3.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 (183) hide show
  1. package/.claude/commands/workflow-skill.md +130 -0
  2. package/.claude/skills/ccw-chain/SKILL.md +44 -71
  3. package/.claude/skills/ccw-chain/chains/ccw-cycle.json +13 -3
  4. package/.claude/skills/ccw-chain/chains/ccw-exploration.json +33 -22
  5. package/.claude/skills/ccw-chain/chains/ccw-issue.json +23 -12
  6. package/.claude/skills/ccw-chain/chains/ccw-lightweight.json +23 -9
  7. package/.claude/skills/ccw-chain/chains/ccw-main.json +15 -2
  8. package/.claude/skills/ccw-chain/chains/ccw-standard.json +28 -16
  9. package/.claude/skills/ccw-chain/chains/ccw-team.json +7 -2
  10. package/.claude/skills/ccw-chain/chains/ccw-with-file.json +25 -9
  11. package/.claude/skills/chain-loader/phases/01-analyze-skill.md +53 -53
  12. package/.claude/skills/chain-loader/specs/chain-schema.md +30 -3
  13. package/.claude/skills/chain-loader/templates/chain-json.md +63 -63
  14. package/.claude/skills/workflow-plan/SKILL.md +1 -0
  15. package/.claude/skills/workflow-plan/phases/01-session-discovery.md +19 -2
  16. package/.claude/skills/workflow-plan/phases/02-context-gathering.md +2 -2
  17. package/.claude/skills/workflow-plan/phases/04-task-generation.md +9 -1
  18. package/.codex/skills/analyze-with-file/SKILL.md +383 -134
  19. package/.codex/skills/brainstorm/SKILL.md +3 -3
  20. package/.codex/skills/brainstorm-with-file/SKILL.md +208 -88
  21. package/.codex/skills/clean/SKILL.md +1 -1
  22. package/.codex/skills/csv-wave-pipeline/SKILL.md +2 -2
  23. package/.codex/skills/investigate/orchestrator.md +24 -0
  24. package/.codex/skills/issue-discover/SKILL.md +374 -361
  25. package/.codex/skills/issue-discover/phases/01-issue-new.md +1 -1
  26. package/.codex/skills/issue-discover/phases/02-discover.md +2 -2
  27. package/.codex/skills/issue-discover/phases/03-discover-by-prompt.md +1 -1
  28. package/.codex/skills/issue-discover/phases/04-quick-execute.md +2 -2
  29. package/.codex/skills/parallel-dev-cycle/SKILL.md +44 -37
  30. package/.codex/skills/project-documentation-workflow/SKILL.md +1 -1
  31. package/.codex/skills/review-cycle/SKILL.md +31 -12
  32. package/.codex/skills/roadmap-with-file/SKILL.md +141 -133
  33. package/.codex/skills/security-audit/orchestrator.md +29 -0
  34. package/.codex/skills/session-sync/SKILL.md +1 -1
  35. package/.codex/skills/ship/orchestrator.md +24 -0
  36. package/.codex/skills/spec-add/SKILL.md +5 -5
  37. package/.codex/skills/spec-generator/SKILL.md +33 -2
  38. package/.codex/skills/spec-generator/phases/01-5-requirement-clarification.md +3 -3
  39. package/.codex/skills/spec-generator/phases/01-discovery.md +1 -1
  40. package/.codex/skills/spec-generator/phases/02-product-brief.md +1 -1
  41. package/.codex/skills/spec-generator/phases/03-requirements.md +1 -1
  42. package/.codex/skills/spec-generator/phases/04-architecture.md +1 -1
  43. package/.codex/skills/spec-generator/phases/05-epics-stories.md +1 -1
  44. package/.codex/skills/spec-generator/phases/06-readiness-check.md +1 -1
  45. package/.codex/skills/spec-generator/phases/07-issue-export.md +1 -1
  46. package/.codex/skills/spec-setup/SKILL.md +669 -669
  47. package/.codex/skills/team-arch-opt/specs/team-config.json +1 -1
  48. package/.codex/skills/team-brainstorm/SKILL.md +259 -259
  49. package/.codex/skills/team-coordinate/SKILL.md +359 -359
  50. package/.codex/skills/team-coordinate/roles/coordinator/commands/monitor.md +1 -1
  51. package/.codex/skills/team-designer/SKILL.md +27 -1
  52. package/.codex/skills/team-designer/phases/01-requirements-analysis.md +2 -2
  53. package/.codex/skills/team-designer/phases/02-scaffold-generation.md +1 -1
  54. package/.codex/skills/team-designer/phases/04-validation.md +1 -1
  55. package/.codex/skills/team-executor/SKILL.md +218 -218
  56. package/.codex/skills/team-frontend/SKILL.md +227 -227
  57. package/.codex/skills/team-frontend-debug/SKILL.md +278 -278
  58. package/.codex/skills/team-frontend-debug/roles/coordinator/commands/analyze.md +2 -2
  59. package/.codex/skills/team-interactive-craft/SKILL.md +220 -220
  60. package/.codex/skills/team-interactive-craft/roles/coordinator/role.md +209 -209
  61. package/.codex/skills/team-issue/SKILL.md +269 -269
  62. package/.codex/skills/team-issue/roles/coordinator/role.md +1 -1
  63. package/.codex/skills/team-lifecycle-v4/SKILL.md +305 -305
  64. package/.codex/skills/team-motion-design/SKILL.md +222 -222
  65. package/.codex/skills/team-motion-design/roles/coordinator/role.md +210 -210
  66. package/.codex/skills/team-perf-opt/SKILL.md +258 -258
  67. package/.codex/skills/team-perf-opt/specs/team-config.json +1 -1
  68. package/.codex/skills/team-planex/SKILL.md +216 -216
  69. package/.codex/skills/team-quality-assurance/SKILL.md +229 -229
  70. package/.codex/skills/team-review/SKILL.md +227 -227
  71. package/.codex/skills/team-roadmap-dev/SKILL.md +238 -238
  72. package/.codex/skills/team-roadmap-dev/roles/coordinator/commands/roadmap-discuss.md +5 -5
  73. package/.codex/skills/team-tech-debt/SKILL.md +206 -206
  74. package/.codex/skills/team-tech-debt/roles/coordinator/commands/monitor.md +1 -1
  75. package/.codex/skills/team-testing/SKILL.md +237 -237
  76. package/.codex/skills/team-ui-polish/SKILL.md +218 -218
  77. package/.codex/skills/team-ui-polish/roles/coordinator/role.md +213 -213
  78. package/.codex/skills/team-uidesign/SKILL.md +219 -219
  79. package/.codex/skills/team-uidesign/roles/coordinator/role.md +2 -2
  80. package/.codex/skills/team-ultra-analyze/SKILL.md +260 -260
  81. package/.codex/skills/team-ultra-analyze/roles/coordinator/commands/monitor.md +1 -1
  82. package/.codex/skills/team-ultra-analyze/roles/coordinator/role.md +1 -1
  83. package/.codex/skills/team-ux-improve/SKILL.md +227 -227
  84. package/.codex/skills/team-ux-improve/roles/coordinator/role.md +1 -1
  85. package/.codex/skills/team-ux-improve/specs/team-config.json +1 -1
  86. package/.codex/skills/team-visual-a11y/SKILL.md +319 -319
  87. package/.codex/skills/team-visual-a11y/roles/coordinator/role.md +213 -213
  88. package/.codex/skills/workflow-execute/SKILL.md +5 -5
  89. package/.codex/skills/workflow-lite-planex/SKILL.md +3 -3
  90. package/.codex/skills/workflow-plan/SKILL.md +3 -3
  91. package/.codex/skills/workflow-tdd-plan/SKILL.md +4 -4
  92. package/.codex/skills/workflow-test-fix-cycle/SKILL.md +403 -402
  93. package/ccw/dist/cli.d.ts.map +1 -1
  94. package/ccw/dist/cli.js +16 -0
  95. package/ccw/dist/cli.js.map +1 -1
  96. package/ccw/dist/commands/chain-loader.d.ts +2 -0
  97. package/ccw/dist/commands/chain-loader.d.ts.map +1 -0
  98. package/ccw/dist/commands/chain-loader.js +11 -0
  99. package/ccw/dist/commands/chain-loader.js.map +1 -0
  100. package/ccw/dist/commands/install.d.ts.map +1 -1
  101. package/ccw/dist/commands/install.js +52 -1
  102. package/ccw/dist/commands/install.js.map +1 -1
  103. package/ccw/dist/commands/launcher.d.ts +2 -0
  104. package/ccw/dist/commands/launcher.d.ts.map +1 -0
  105. package/ccw/dist/commands/launcher.js +434 -0
  106. package/ccw/dist/commands/launcher.js.map +1 -0
  107. package/ccw/dist/tools/chain-loader.d.ts.map +1 -1
  108. package/ccw/dist/tools/chain-loader.js +457 -45
  109. package/ccw/dist/tools/chain-loader.js.map +1 -1
  110. package/ccw/dist/tools/skill-context-loader.d.ts.map +1 -1
  111. package/ccw/dist/tools/skill-context-loader.js +12 -26
  112. package/ccw/dist/tools/skill-context-loader.js.map +1 -1
  113. package/ccw/dist/types/chain-types.d.ts +41 -1
  114. package/ccw/dist/types/chain-types.d.ts.map +1 -1
  115. package/ccw/dist/utils/chain-visualizer.d.ts +13 -0
  116. package/ccw/dist/utils/chain-visualizer.d.ts.map +1 -0
  117. package/ccw/dist/utils/chain-visualizer.js +164 -0
  118. package/ccw/dist/utils/chain-visualizer.js.map +1 -0
  119. package/package.json +1 -1
  120. package/.claude/commands/cli/cli-init.md +0 -441
  121. package/.claude/commands/cli/codex-review.md +0 -361
  122. package/.claude/commands/flow-create.md +0 -663
  123. package/.claude/skills/ccw-chain/phases/analyze-with-file.md +0 -788
  124. package/.claude/skills/ccw-chain/phases/brainstorm/SKILL.md +0 -408
  125. package/.claude/skills/ccw-chain/phases/brainstorm/phases/01-mode-routing.md +0 -207
  126. package/.claude/skills/ccw-chain/phases/brainstorm/phases/02-artifacts.md +0 -567
  127. package/.claude/skills/ccw-chain/phases/brainstorm/phases/03-role-analysis.md +0 -748
  128. package/.claude/skills/ccw-chain/phases/brainstorm/phases/04-synthesis.md +0 -827
  129. package/.claude/skills/ccw-chain/phases/brainstorm-with-file.md +0 -482
  130. package/.claude/skills/ccw-chain/phases/collaborative-plan-with-file.md +0 -639
  131. package/.claude/skills/ccw-chain/phases/debug-with-file.md +0 -656
  132. package/.claude/skills/ccw-chain/phases/integration-test-cycle.md +0 -936
  133. package/.claude/skills/ccw-chain/phases/issue-convert-to-plan.md +0 -720
  134. package/.claude/skills/ccw-chain/phases/issue-discover.md +0 -483
  135. package/.claude/skills/ccw-chain/phases/issue-execute.md +0 -629
  136. package/.claude/skills/ccw-chain/phases/issue-from-brainstorm.md +0 -382
  137. package/.claude/skills/ccw-chain/phases/issue-plan.md +0 -343
  138. package/.claude/skills/ccw-chain/phases/issue-queue.md +0 -464
  139. package/.claude/skills/ccw-chain/phases/refactor-cycle.md +0 -852
  140. package/.claude/skills/ccw-chain/phases/review-cycle/SKILL.md +0 -132
  141. package/.claude/skills/ccw-chain/phases/review-cycle/phases/review-fix.md +0 -760
  142. package/.claude/skills/ccw-chain/phases/review-cycle/phases/review-module.md +0 -764
  143. package/.claude/skills/ccw-chain/phases/review-cycle/phases/review-session.md +0 -775
  144. package/.claude/skills/ccw-chain/phases/roadmap-with-file.md +0 -544
  145. package/.claude/skills/ccw-chain/phases/spec-generator/SKILL.md +0 -338
  146. package/.claude/skills/ccw-chain/phases/spec-generator/phases/01-5-requirement-clarification.md +0 -404
  147. package/.claude/skills/ccw-chain/phases/spec-generator/phases/01-discovery.md +0 -257
  148. package/.claude/skills/ccw-chain/phases/spec-generator/phases/02-product-brief.md +0 -274
  149. package/.claude/skills/ccw-chain/phases/spec-generator/phases/03-requirements.md +0 -184
  150. package/.claude/skills/ccw-chain/phases/spec-generator/phases/04-architecture.md +0 -248
  151. package/.claude/skills/ccw-chain/phases/spec-generator/phases/05-epics-stories.md +0 -178
  152. package/.claude/skills/ccw-chain/phases/spec-generator/phases/06-5-auto-fix.md +0 -144
  153. package/.claude/skills/ccw-chain/phases/spec-generator/phases/06-readiness-check.md +0 -480
  154. package/.claude/skills/ccw-chain/phases/team-planex.md +0 -123
  155. package/.claude/skills/ccw-chain/phases/ui-design-explore-auto.md +0 -678
  156. package/.claude/skills/ccw-chain/phases/unified-execute-with-file.md +0 -870
  157. package/.claude/skills/ccw-chain/phases/workflow-execute/SKILL.md +0 -625
  158. package/.claude/skills/ccw-chain/phases/workflow-execute/phases/06-review.md +0 -215
  159. package/.claude/skills/ccw-chain/phases/workflow-lite-plan.md +0 -616
  160. package/.claude/skills/ccw-chain/phases/workflow-multi-cli-plan.md +0 -424
  161. package/.claude/skills/ccw-chain/phases/workflow-plan/SKILL.md +0 -466
  162. package/.claude/skills/ccw-chain/phases/workflow-plan/phases/01-session-discovery.md +0 -99
  163. package/.claude/skills/ccw-chain/phases/workflow-plan/phases/02-context-gathering.md +0 -338
  164. package/.claude/skills/ccw-chain/phases/workflow-plan/phases/03-conflict-resolution.md +0 -422
  165. package/.claude/skills/ccw-chain/phases/workflow-plan/phases/04-task-generation.md +0 -440
  166. package/.claude/skills/ccw-chain/phases/workflow-plan/phases/05-plan-verify.md +0 -395
  167. package/.claude/skills/ccw-chain/phases/workflow-plan/phases/06-replan.md +0 -594
  168. package/.claude/skills/ccw-chain/phases/workflow-tdd-plan/SKILL.md +0 -527
  169. package/.claude/skills/ccw-chain/phases/workflow-tdd-plan/phases/01-session-discovery.md +0 -57
  170. package/.claude/skills/ccw-chain/phases/workflow-tdd-plan/phases/02-context-gathering.md +0 -407
  171. package/.claude/skills/ccw-chain/phases/workflow-tdd-plan/phases/03-test-coverage-analysis.md +0 -172
  172. package/.claude/skills/ccw-chain/phases/workflow-tdd-plan/phases/04-conflict-resolution.md +0 -426
  173. package/.claude/skills/ccw-chain/phases/workflow-tdd-plan/phases/05-tdd-task-generation.md +0 -473
  174. package/.claude/skills/ccw-chain/phases/workflow-tdd-plan/phases/06-tdd-structure-validation.md +0 -189
  175. package/.claude/skills/ccw-chain/phases/workflow-tdd-plan/phases/07-tdd-verify.md +0 -635
  176. package/.claude/skills/ccw-chain/phases/workflow-test-fix/SKILL.md +0 -482
  177. package/.claude/skills/ccw-chain/phases/workflow-test-fix/phases/01-session-start.md +0 -60
  178. package/.claude/skills/ccw-chain/phases/workflow-test-fix/phases/02-test-context-gather.md +0 -493
  179. package/.claude/skills/ccw-chain/phases/workflow-test-fix/phases/03-test-concept-enhanced.md +0 -150
  180. package/.claude/skills/ccw-chain/phases/workflow-test-fix/phases/04-test-task-generate.md +0 -346
  181. package/.claude/skills/ccw-chain/phases/workflow-test-fix/phases/05-test-cycle-execute.md +0 -538
  182. package/.claude/skills/ccw-chain/specs/intent-patterns.md +0 -60
  183. package/.claude/skills/team-edict.zip +0 -0
@@ -1,237 +1,237 @@
1
- ---
2
- name: team-testing
3
- description: Unified team skill for testing team. Progressive test coverage through Generator-Critic loops, shared memory, and dynamic layer selection. Triggers on "team testing".
4
- allowed-tools: spawn_agent(*), wait_agent(*), send_message(*), assign_task(*), close_agent(*), list_agents(*), report_agent_job_result(*), request_user_input(*), Read(*), Write(*), Edit(*), Bash(*), Glob(*), Grep(*)
5
- ---
6
-
7
- # Team Testing
8
-
9
- Orchestrate multi-agent test pipeline: strategist -> generator -> executor -> analyst. Progressive layer coverage (L1/L2/L3) with Generator-Critic loops for coverage convergence.
10
-
11
- ## Architecture
12
-
13
- ```
14
- Skill(skill="team-testing", args="task description")
15
- |
16
- SKILL.md (this file) = Router
17
- |
18
- +--------------+--------------+
19
- | |
20
- no --role flag --role <name>
21
- | |
22
- Coordinator Worker
23
- roles/coordinator/role.md roles/<name>/role.md
24
- |
25
- +-- analyze -> dispatch -> spawn workers -> STOP
26
- |
27
- +-------+-------+-------+-------+
28
- v v v v
29
- [strat] [gen] [exec] [analyst]
30
- team-worker agents, each loads roles/<role>/role.md
31
- ```
32
-
33
- ## Role Registry
34
-
35
- | Role | Path | Prefix | Inner Loop |
36
- |------|------|--------|------------|
37
- | coordinator | [roles/coordinator/role.md](roles/coordinator/role.md) | — | — |
38
- | strategist | [roles/strategist/role.md](roles/strategist/role.md) | STRATEGY-* | false |
39
- | generator | [roles/generator/role.md](roles/generator/role.md) | TESTGEN-* | true |
40
- | executor | [roles/executor/role.md](roles/executor/role.md) | TESTRUN-* | true |
41
- | analyst | [roles/analyst/role.md](roles/analyst/role.md) | TESTANA-* | false |
42
-
43
- ## Role Router
44
-
45
- Parse `$ARGUMENTS`:
46
- - Has `--role <name>` -> Read `roles/<name>/role.md`, execute Phase 2-4
47
- - No `--role` -> `roles/coordinator/role.md`, execute entry router
48
-
49
- ## Delegation Lock
50
-
51
- **Coordinator is a PURE ORCHESTRATOR. It coordinates, it does NOT do.**
52
-
53
- Before calling ANY tool, apply this check:
54
-
55
- | Tool Call | Verdict | Reason |
56
- |-----------|---------|--------|
57
- | `spawn_agent`, `wait_agent`, `close_agent`, `send_message`, `assign_task` | ALLOWED | Orchestration |
58
- | `list_agents` | ALLOWED | Agent health check |
59
- | `request_user_input` | ALLOWED | User interaction |
60
- | `mcp__ccw-tools__team_msg` | ALLOWED | Message bus |
61
- | `Read/Write` on `.workflow/.team/` files | ALLOWED | Session state |
62
- | `Read` on `roles/`, `commands/`, `specs/` | ALLOWED | Loading own instructions |
63
- | `Read/Grep/Glob` on project source code | BLOCKED | Delegate to worker |
64
- | `Edit` on any file outside `.workflow/` | BLOCKED | Delegate to worker |
65
- | `Bash("ccw cli ...")` | BLOCKED | Only workers call CLI |
66
- | `Bash` running build/test/lint commands | BLOCKED | Delegate to worker |
67
-
68
- **If a tool call is BLOCKED**: STOP. Create a task, spawn a worker.
69
-
70
- **No exceptions for "simple" tasks.** Even a single-file read-and-report MUST go through spawn_agent.
71
-
72
- ---
73
-
74
- ## Shared Constants
75
-
76
- - **Session prefix**: `TST`
77
- - **Session path**: `.workflow/.team/TST-<slug>-<date>/`
78
- - **Team name**: `testing`
79
- - **CLI tools**: `ccw cli --mode analysis` (read-only), `ccw cli --mode write` (modifications)
80
- - **Message bus**: `mcp__ccw-tools__team_msg(session_id=<session-id>, ...)`
81
-
82
- ## Worker Spawn Template
83
-
84
- Coordinator spawns workers using this template:
85
-
86
- ```
87
- spawn_agent({
88
- agent_type: "team_worker",
89
- task_name: "<task-id>",
90
- fork_context: false,
91
- items: [
92
- { type: "text", text: `## Role Assignment
93
- role: <role>
94
- role_spec: <skill_root>/roles/<role>/role.md
95
- session: <session-folder>
96
- session_id: <session-id>
97
- requirement: <task-description>
98
- inner_loop: <true|false>
99
-
100
- Read role_spec file (<skill_root>/roles/<role>/role.md) to load Phase 2-4 domain instructions.` },
101
-
102
- { type: "text", text: `## Task Context
103
- task_id: <task-id>
104
- title: <task-title>
105
- description: <task-description>
106
- pipeline_phase: <pipeline-phase>` },
107
-
108
- { type: "text", text: `## Upstream Context
109
- <prev_context>` }
110
- ]
111
- })
112
- ```
113
-
114
- After spawning, use `wait_agent({ targets: [...], timeout_ms: 900000 })` to collect results, then `close_agent({ target })` each worker.
115
-
116
-
117
- ### Model Selection Guide
118
-
119
- | Role | model | reasoning_effort | Rationale |
120
- |------|-------|-------------------|-----------|
121
- | Strategist (STRATEGY-*) | (default) | high | Test strategy requires deep code understanding |
122
- | Generator (TESTGEN-*) | (default) | high | Test code generation needs precision |
123
- | Executor (TESTRUN-*) | (default) | medium | Running tests and collecting results, less reasoning |
124
- | Analyst (TESTANA-*) | (default) | high | Coverage analysis and quality assessment |
125
-
126
- Override model/reasoning_effort in spawn_agent when cost optimization is needed:
127
- ```
128
- spawn_agent({
129
- agent_type: "team_worker",
130
- task_name: "<task-id>",
131
- fork_context: false,
132
- model: "<model-override>",
133
- reasoning_effort: "<effort-level>",
134
- items: [...]
135
- })
136
- ```
137
-
138
- ## User Commands
139
-
140
- | Command | Action |
141
- |---------|--------|
142
- | `check` / `status` | View pipeline status graph |
143
- | `resume` / `continue` | Advance to next step |
144
- | `revise <TASK-ID>` | Revise specific task |
145
- | `feedback <text>` | Inject feedback for revision |
146
-
147
- ## v4 Agent Coordination
148
-
149
- ### Message Semantics
150
-
151
- | Intent | API | Example |
152
- |--------|-----|---------|
153
- | Send strategy to running generators | `send_message` | Queue test strategy findings to TESTGEN-* workers |
154
- | Not used in this skill | `assign_task` | No resident agents -- all workers are one-shot |
155
- | Check running agents | `list_agents` | Verify parallel generator/executor health |
156
-
157
- ### Parallel Test Generation
158
-
159
- Comprehensive pipeline spawns multiple generators (per layer) and executors in parallel:
160
-
161
- ```
162
- // Spawn parallel generators for L1 and L2
163
- const genNames = ["TESTGEN-001", "TESTGEN-002"]
164
- for (const name of genNames) {
165
- spawn_agent({ agent_type: "team_worker", task_name: name, ... })
166
- }
167
- wait_agent({ targets: genNames, timeout_ms: 900000 })
168
- ```
169
-
170
- ### GC Loop Coordination
171
-
172
- Generator-Critic loops create dynamic TESTGEN-fix and TESTRUN-fix tasks. The coordinator tracks `gc_rounds[layer]` and creates fix tasks dynamically when coverage is below target.
173
-
174
- ### Agent Health Check
175
-
176
- Use `list_agents({})` in handleResume and handleComplete:
177
-
178
- ```
179
- // Reconcile session state with actual running agents
180
- const running = list_agents({})
181
- // Compare with tasks.json active_agents
182
- // Reset orphaned tasks (in_progress but agent gone) to pending
183
- ```
184
-
185
- ### Named Agent Targeting
186
-
187
- Workers are spawned with `task_name: "<task-id>"` enabling direct addressing:
188
- - `send_message({ target: "TESTGEN-001", items: [...] })` -- queue strategy context to running generator
189
- - `close_agent({ target: "TESTRUN-001" })` -- cleanup by name after wait_agent returns
190
-
191
- ## Completion Action
192
-
193
- When pipeline completes, coordinator presents:
194
-
195
- ```
196
- request_user_input({
197
- questions: [{
198
- question: "Testing pipeline complete. What would you like to do?",
199
- header: "Completion",
200
- multiSelect: false,
201
- options: [
202
- { label: "Archive & Clean (Recommended)", description: "Archive session, clean up team" },
203
- { label: "Keep Active", description: "Keep session for follow-up work" },
204
- { label: "Deepen Coverage", description: "Add more test layers or increase coverage targets" }
205
- ]
206
- }]
207
- })
208
- ```
209
-
210
- ## Session Directory
211
-
212
- ```
213
- .workflow/.team/TST-<slug>-<date>/
214
- ├── .msg/messages.jsonl # Team message bus
215
- ├── .msg/meta.json # Session metadata
216
- ├── wisdom/ # Cross-task knowledge
217
- ├── strategy/ # Strategist output
218
- ├── tests/ # Generator output (L1-unit/, L2-integration/, L3-e2e/)
219
- ├── results/ # Executor output
220
- └── analysis/ # Analyst output
221
- ```
222
-
223
- ## Specs Reference
224
-
225
- - [specs/pipelines.md](specs/pipelines.md) — Pipeline definitions and task registry
226
- - [specs/team-config.json](specs/team-config.json) — Team configuration
227
-
228
- ## Error Handling
229
-
230
- | Scenario | Resolution |
231
- |----------|------------|
232
- | Unknown --role value | Error with available role list |
233
- | Role not found | Error with expected path (roles/<name>/role.md) |
234
- | CLI tool fails | Worker fallback to direct implementation |
235
- | GC loop exceeded | Accept current coverage with warning |
236
- | Fast-advance conflict | Coordinator reconciles on next callback |
237
- | Completion action fails | Default to Keep Active |
1
+ ---
2
+ name: team-testing
3
+ description: Unified team skill for testing team. Progressive test coverage through Generator-Critic loops, shared memory, and dynamic layer selection. Triggers on "team testing".
4
+ allowed-tools: spawn_agent(*), wait_agent(*), send_message(*), assign_task(*), close_agent(*), list_agents(*), report_agent_job_result(*), request_user_input(*), Read(*), Write(*), Edit(*), Bash(*), Glob(*), Grep(*)
5
+ ---
6
+
7
+ # Team Testing
8
+
9
+ Orchestrate multi-agent test pipeline: strategist -> generator -> executor -> analyst. Progressive layer coverage (L1/L2/L3) with Generator-Critic loops for coverage convergence.
10
+
11
+ ## Architecture
12
+
13
+ ```
14
+ Skill(skill="team-testing", args="task description")
15
+ |
16
+ SKILL.md (this file) = Router
17
+ |
18
+ +--------------+--------------+
19
+ | |
20
+ no --role flag --role <name>
21
+ | |
22
+ Coordinator Worker
23
+ roles/coordinator/role.md roles/<name>/role.md
24
+ |
25
+ +-- analyze -> dispatch -> spawn workers -> STOP
26
+ |
27
+ +-------+-------+-------+-------+
28
+ v v v v
29
+ [strat] [gen] [exec] [analyst]
30
+ team-worker agents, each loads roles/<role>/role.md
31
+ ```
32
+
33
+ ## Role Registry
34
+
35
+ | Role | Path | Prefix | Inner Loop |
36
+ |------|------|--------|------------|
37
+ | coordinator | [roles/coordinator/role.md](roles/coordinator/role.md) | — | — |
38
+ | strategist | [roles/strategist/role.md](roles/strategist/role.md) | STRATEGY-* | false |
39
+ | generator | [roles/generator/role.md](roles/generator/role.md) | TESTGEN-* | true |
40
+ | executor | [roles/executor/role.md](roles/executor/role.md) | TESTRUN-* | true |
41
+ | analyst | [roles/analyst/role.md](roles/analyst/role.md) | TESTANA-* | false |
42
+
43
+ ## Role Router
44
+
45
+ Parse `$ARGUMENTS`:
46
+ - Has `--role <name>` -> Read `roles/<name>/role.md`, execute Phase 2-4
47
+ - No `--role` -> `roles/coordinator/role.md`, execute entry router
48
+
49
+ ## Delegation Lock
50
+
51
+ **Coordinator is a PURE ORCHESTRATOR. It coordinates, it does NOT do.**
52
+
53
+ Before calling ANY tool, apply this check:
54
+
55
+ | Tool Call | Verdict | Reason |
56
+ |-----------|---------|--------|
57
+ | `spawn_agent`, `wait_agent`, `close_agent`, `send_message`, `assign_task` | ALLOWED | Orchestration |
58
+ | `list_agents` | ALLOWED | Agent health check |
59
+ | `request_user_input` | ALLOWED | User interaction |
60
+ | `mcp__ccw-tools__team_msg` | ALLOWED | Message bus |
61
+ | `Read/Write` on `.workflow/.team/` files | ALLOWED | Session state |
62
+ | `Read` on `roles/`, `commands/`, `specs/` | ALLOWED | Loading own instructions |
63
+ | `Read/Grep/Glob` on project source code | BLOCKED | Delegate to worker |
64
+ | `Edit` on any file outside `.workflow/` | BLOCKED | Delegate to worker |
65
+ | `Bash("ccw cli ...")` | BLOCKED | Only workers call CLI |
66
+ | `Bash` running build/test/lint commands | BLOCKED | Delegate to worker |
67
+
68
+ **If a tool call is BLOCKED**: STOP. Create a task, spawn a worker.
69
+
70
+ **No exceptions for "simple" tasks.** Even a single-file read-and-report MUST go through spawn_agent.
71
+
72
+ ---
73
+
74
+ ## Shared Constants
75
+
76
+ - **Session prefix**: `TST`
77
+ - **Session path**: `.workflow/.team/TST-<slug>-<date>/`
78
+ - **Team name**: `testing`
79
+ - **CLI tools**: `ccw cli --mode analysis` (read-only), `ccw cli --mode write` (modifications)
80
+ - **Message bus**: `mcp__ccw-tools__team_msg(session_id=<session-id>, ...)`
81
+
82
+ ## Worker Spawn Template
83
+
84
+ Coordinator spawns workers using this template:
85
+
86
+ ```
87
+ spawn_agent({
88
+ agent_type: "team_worker",
89
+ task_name: "<task-id>",
90
+ fork_context: false,
91
+ items: [
92
+ { type: "text", text: `## Role Assignment
93
+ role: <role>
94
+ role_spec: <skill_root>/roles/<role>/role.md
95
+ session: <session-folder>
96
+ session_id: <session-id>
97
+ requirement: <task-description>
98
+ inner_loop: <true|false>
99
+
100
+ Read role_spec file (<skill_root>/roles/<role>/role.md) to load Phase 2-4 domain instructions.` },
101
+
102
+ { type: "text", text: `## Task Context
103
+ task_id: <task-id>
104
+ title: <task-title>
105
+ description: <task-description>
106
+ pipeline_phase: <pipeline-phase>` },
107
+
108
+ { type: "text", text: `## Upstream Context
109
+ <prev_context>` }
110
+ ]
111
+ })
112
+ ```
113
+
114
+ After spawning, use `wait_agent({ targets: [...], timeout_ms: 900000 })` to collect results, then `close_agent({ target })` each worker.
115
+
116
+
117
+ ### Model Selection Guide
118
+
119
+ | Role | model | reasoning_effort | Rationale |
120
+ |------|-------|-------------------|-----------|
121
+ | Strategist (STRATEGY-*) | (default) | high | Test strategy requires deep code understanding |
122
+ | Generator (TESTGEN-*) | (default) | high | Test code generation needs precision |
123
+ | Executor (TESTRUN-*) | (default) | medium | Running tests and collecting results, less reasoning |
124
+ | Analyst (TESTANA-*) | (default) | high | Coverage analysis and quality assessment |
125
+
126
+ Override model/reasoning_effort in spawn_agent when cost optimization is needed:
127
+ ```
128
+ spawn_agent({
129
+ agent_type: "team_worker",
130
+ task_name: "<task-id>",
131
+ fork_context: false,
132
+ model: "<model-override>",
133
+ reasoning_effort: "<effort-level>",
134
+ items: [...]
135
+ })
136
+ ```
137
+
138
+ ## User Commands
139
+
140
+ | Command | Action |
141
+ |---------|--------|
142
+ | `check` / `status` | View pipeline status graph |
143
+ | `resume` / `continue` | Advance to next step |
144
+ | `revise <TASK-ID>` | Revise specific task |
145
+ | `feedback <text>` | Inject feedback for revision |
146
+
147
+ ## v4 Agent Coordination
148
+
149
+ ### Message Semantics
150
+
151
+ | Intent | API | Example |
152
+ |--------|-----|---------|
153
+ | Send strategy to running generators | `send_message` | Queue test strategy findings to TESTGEN-* workers |
154
+ | Not used in this skill | `assign_task` | No resident agents -- all workers are one-shot |
155
+ | Check running agents | `list_agents` | Verify parallel generator/executor health |
156
+
157
+ ### Parallel Test Generation
158
+
159
+ Comprehensive pipeline spawns multiple generators (per layer) and executors in parallel:
160
+
161
+ ```
162
+ // Spawn parallel generators for L1 and L2
163
+ const genNames = ["TESTGEN-001", "TESTGEN-002"]
164
+ for (const name of genNames) {
165
+ spawn_agent({ agent_type: "team_worker", task_name: name, ... })
166
+ }
167
+ wait_agent({ targets: genNames, timeout_ms: 900000 })
168
+ ```
169
+
170
+ ### GC Loop Coordination
171
+
172
+ Generator-Critic loops create dynamic TESTGEN-fix and TESTRUN-fix tasks. The coordinator tracks `gc_rounds[layer]` and creates fix tasks dynamically when coverage is below target.
173
+
174
+ ### Agent Health Check
175
+
176
+ Use `list_agents({})` in handleResume and handleComplete:
177
+
178
+ ```
179
+ // Reconcile session state with actual running agents
180
+ const running = list_agents({})
181
+ // Compare with tasks.json active_agents
182
+ // Reset orphaned tasks (in_progress but agent gone) to pending
183
+ ```
184
+
185
+ ### Named Agent Targeting
186
+
187
+ Workers are spawned with `task_name: "<task-id>"` enabling direct addressing:
188
+ - `send_message({ target: "TESTGEN-001", items: [...] })` -- queue strategy context to running generator
189
+ - `close_agent({ target: "TESTRUN-001" })` -- cleanup by name after wait_agent returns
190
+
191
+ ## Completion Action
192
+
193
+ When pipeline completes, coordinator presents:
194
+
195
+ ```
196
+ functions.request_user_input({
197
+ questions: [{
198
+ question: "Testing pipeline complete. What would you like to do?",
199
+ header: "Completion",
200
+ multiSelect: false,
201
+ options: [
202
+ { label: "Archive & Clean (Recommended)", description: "Archive session, clean up team" },
203
+ { label: "Keep Active", description: "Keep session for follow-up work" },
204
+ { label: "Deepen Coverage", description: "Add more test layers or increase coverage targets" }
205
+ ]
206
+ }]
207
+ })
208
+ ```
209
+
210
+ ## Session Directory
211
+
212
+ ```
213
+ .workflow/.team/TST-<slug>-<date>/
214
+ ├── .msg/messages.jsonl # Team message bus
215
+ ├── .msg/meta.json # Session metadata
216
+ ├── wisdom/ # Cross-task knowledge
217
+ ├── strategy/ # Strategist output
218
+ ├── tests/ # Generator output (L1-unit/, L2-integration/, L3-e2e/)
219
+ ├── results/ # Executor output
220
+ └── analysis/ # Analyst output
221
+ ```
222
+
223
+ ## Specs Reference
224
+
225
+ - [specs/pipelines.md](specs/pipelines.md) — Pipeline definitions and task registry
226
+ - [specs/team-config.json](specs/team-config.json) — Team configuration
227
+
228
+ ## Error Handling
229
+
230
+ | Scenario | Resolution |
231
+ |----------|------------|
232
+ | Unknown --role value | Error with available role list |
233
+ | Role not found | Error with expected path (roles/<name>/role.md) |
234
+ | CLI tool fails | Worker fallback to direct implementation |
235
+ | GC loop exceeded | Accept current coverage with warning |
236
+ | Fast-advance conflict | Coordinator reconciles on next callback |
237
+ | Completion action fails | Default to Keep Active |