claude-code-workflow 7.2.29 → 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.
- package/.ccw/workflows/cli-templates/schemas/plan-overview-base-schema.json +2 -2
- package/.ccw/workflows/cli-templates/schemas/task-schema.json +14 -7
- package/.claude/agents/action-planning-agent.md +7 -4
- package/.claude/agents/cli-explore-agent.md +77 -63
- package/.claude/agents/cli-lite-planning-agent.md +11 -10
- package/.claude/agents/issue-plan-agent.md +421 -426
- package/.claude/commands/workflow/spec/setup.md +1 -1
- package/.claude/commands/workflow-skill.md +130 -0
- package/.claude/skills/ccw-chain/SKILL.md +92 -0
- package/.claude/skills/ccw-chain/chains/ccw-cycle.json +31 -0
- package/.claude/skills/ccw-chain/chains/ccw-exploration.json +58 -0
- package/.claude/skills/ccw-chain/chains/ccw-issue.json +44 -0
- package/.claude/skills/ccw-chain/chains/ccw-lightweight.json +71 -0
- package/.claude/skills/ccw-chain/chains/ccw-main.json +65 -0
- package/.claude/skills/ccw-chain/chains/ccw-standard.json +51 -0
- package/.claude/skills/ccw-chain/chains/ccw-team.json +15 -0
- package/.claude/skills/ccw-chain/chains/ccw-with-file.json +47 -0
- package/.claude/skills/ccw-chain/specs/auto-mode.md +47 -0
- package/.claude/skills/chain-loader/SKILL.md +78 -0
- package/.claude/skills/chain-loader/phases/01-analyze-skill.md +53 -0
- package/.claude/skills/chain-loader/phases/02-design-graph.md +73 -0
- package/.claude/skills/chain-loader/phases/03-generate-validate.md +75 -0
- package/.claude/skills/chain-loader/specs/chain-schema.md +126 -0
- package/.claude/skills/chain-loader/specs/design-patterns.md +99 -0
- package/.claude/skills/chain-loader/templates/chain-json.md +63 -0
- package/.claude/skills/review-cycle/phases/review-module.md +764 -764
- package/.claude/skills/review-cycle/phases/review-session.md +775 -775
- package/.claude/skills/workflow-multi-cli-plan/SKILL.md +2 -2
- package/.claude/skills/workflow-plan/SKILL.md +1 -0
- package/.claude/skills/workflow-plan/phases/01-session-discovery.md +19 -2
- package/.claude/skills/workflow-plan/phases/02-context-gathering.md +2 -2
- package/.claude/skills/workflow-plan/phases/03-conflict-resolution.md +422 -422
- package/.claude/skills/workflow-plan/phases/04-task-generation.md +9 -1
- package/.claude/skills/workflow-plan/phases/05-plan-verify.md +395 -395
- package/.claude/skills/workflow-tdd-plan/phases/02-context-gathering.md +407 -407
- package/.claude/skills/workflow-tdd-plan/phases/04-conflict-resolution.md +426 -426
- package/.claude/skills/workflow-test-fix/phases/02-test-context-gather.md +493 -493
- package/.codex/skills/analyze-with-file/SKILL.md +383 -134
- package/.codex/skills/brainstorm/SKILL.md +3 -3
- package/.codex/skills/brainstorm-with-file/SKILL.md +208 -88
- package/.codex/skills/clean/SKILL.md +1 -1
- package/.codex/skills/csv-wave-pipeline/SKILL.md +2 -2
- package/.codex/skills/investigate/orchestrator.md +24 -0
- package/.codex/skills/issue-discover/SKILL.md +374 -361
- package/.codex/skills/issue-discover/phases/01-issue-new.md +1 -1
- package/.codex/skills/issue-discover/phases/02-discover.md +2 -2
- package/.codex/skills/issue-discover/phases/03-discover-by-prompt.md +1 -1
- package/.codex/skills/issue-discover/phases/04-quick-execute.md +2 -2
- package/.codex/skills/parallel-dev-cycle/SKILL.md +44 -37
- package/.codex/skills/project-documentation-workflow/SKILL.md +1 -1
- package/.codex/skills/review-cycle/SKILL.md +31 -12
- package/.codex/skills/roadmap-with-file/SKILL.md +141 -133
- package/.codex/skills/security-audit/orchestrator.md +29 -0
- package/.codex/skills/session-sync/SKILL.md +1 -1
- package/.codex/skills/ship/orchestrator.md +24 -0
- package/.codex/skills/spec-add/SKILL.md +5 -5
- package/.codex/skills/spec-generator/SKILL.md +33 -2
- package/.codex/skills/spec-generator/phases/01-5-requirement-clarification.md +3 -3
- package/.codex/skills/spec-generator/phases/01-discovery.md +1 -1
- package/.codex/skills/spec-generator/phases/02-product-brief.md +1 -1
- package/.codex/skills/spec-generator/phases/03-requirements.md +1 -1
- package/.codex/skills/spec-generator/phases/04-architecture.md +1 -1
- package/.codex/skills/spec-generator/phases/05-epics-stories.md +1 -1
- package/.codex/skills/spec-generator/phases/06-readiness-check.md +1 -1
- package/.codex/skills/spec-generator/phases/07-issue-export.md +1 -1
- package/.codex/skills/spec-setup/SKILL.md +669 -669
- package/.codex/skills/team-arch-opt/specs/team-config.json +1 -1
- package/.codex/skills/team-brainstorm/SKILL.md +259 -259
- package/.codex/skills/team-coordinate/SKILL.md +359 -359
- package/.codex/skills/team-coordinate/roles/coordinator/commands/monitor.md +1 -1
- package/.codex/skills/team-designer/SKILL.md +27 -1
- package/.codex/skills/team-designer/phases/01-requirements-analysis.md +2 -2
- package/.codex/skills/team-designer/phases/02-scaffold-generation.md +1 -1
- package/.codex/skills/team-designer/phases/04-validation.md +1 -1
- package/.codex/skills/team-executor/SKILL.md +218 -218
- package/.codex/skills/team-frontend/SKILL.md +227 -227
- package/.codex/skills/team-frontend-debug/SKILL.md +278 -278
- package/.codex/skills/team-frontend-debug/roles/coordinator/commands/analyze.md +2 -2
- package/.codex/skills/team-interactive-craft/SKILL.md +220 -220
- package/.codex/skills/team-interactive-craft/roles/coordinator/role.md +209 -209
- package/.codex/skills/team-issue/SKILL.md +269 -269
- package/.codex/skills/team-issue/roles/coordinator/role.md +1 -1
- package/.codex/skills/team-lifecycle-v4/SKILL.md +305 -305
- package/.codex/skills/team-motion-design/SKILL.md +222 -222
- package/.codex/skills/team-motion-design/roles/coordinator/role.md +210 -210
- package/.codex/skills/team-perf-opt/SKILL.md +258 -258
- package/.codex/skills/team-perf-opt/specs/team-config.json +1 -1
- package/.codex/skills/team-planex/SKILL.md +216 -216
- package/.codex/skills/team-quality-assurance/SKILL.md +229 -229
- package/.codex/skills/team-review/SKILL.md +227 -227
- package/.codex/skills/team-roadmap-dev/SKILL.md +238 -238
- package/.codex/skills/team-roadmap-dev/roles/coordinator/commands/roadmap-discuss.md +5 -5
- package/.codex/skills/team-tech-debt/SKILL.md +206 -206
- package/.codex/skills/team-tech-debt/roles/coordinator/commands/monitor.md +1 -1
- package/.codex/skills/team-testing/SKILL.md +237 -237
- package/.codex/skills/team-ui-polish/SKILL.md +218 -218
- package/.codex/skills/team-ui-polish/roles/coordinator/role.md +213 -213
- package/.codex/skills/team-uidesign/SKILL.md +219 -219
- package/.codex/skills/team-uidesign/roles/coordinator/role.md +2 -2
- package/.codex/skills/team-ultra-analyze/SKILL.md +260 -260
- package/.codex/skills/team-ultra-analyze/roles/coordinator/commands/monitor.md +1 -1
- package/.codex/skills/team-ultra-analyze/roles/coordinator/role.md +1 -1
- package/.codex/skills/team-ux-improve/SKILL.md +227 -227
- package/.codex/skills/team-ux-improve/roles/coordinator/role.md +1 -1
- package/.codex/skills/team-ux-improve/specs/team-config.json +1 -1
- package/.codex/skills/team-visual-a11y/SKILL.md +319 -319
- package/.codex/skills/team-visual-a11y/roles/coordinator/role.md +213 -213
- package/.codex/skills/workflow-execute/SKILL.md +5 -5
- package/.codex/skills/workflow-lite-planex/SKILL.md +3 -3
- package/.codex/skills/workflow-plan/SKILL.md +3 -3
- package/.codex/skills/workflow-tdd-plan/SKILL.md +4 -4
- package/.codex/skills/workflow-test-fix-cycle/SKILL.md +403 -402
- package/README.md +14 -0
- package/ccw/dist/cli.d.ts.map +1 -1
- package/ccw/dist/cli.js +16 -0
- package/ccw/dist/cli.js.map +1 -1
- package/ccw/dist/commands/chain-loader.d.ts +2 -0
- package/ccw/dist/commands/chain-loader.d.ts.map +1 -0
- package/ccw/dist/commands/chain-loader.js +11 -0
- package/ccw/dist/commands/chain-loader.js.map +1 -0
- package/ccw/dist/commands/install.d.ts.map +1 -1
- package/ccw/dist/commands/install.js +52 -1
- package/ccw/dist/commands/install.js.map +1 -1
- package/ccw/dist/commands/launcher.d.ts +2 -0
- package/ccw/dist/commands/launcher.d.ts.map +1 -0
- package/ccw/dist/commands/launcher.js +434 -0
- package/ccw/dist/commands/launcher.js.map +1 -0
- package/ccw/dist/core/routes/litellm-api-routes.d.ts.map +1 -1
- package/ccw/dist/core/routes/litellm-api-routes.js +0 -23
- package/ccw/dist/core/routes/litellm-api-routes.js.map +1 -1
- package/ccw/dist/tools/chain-loader.d.ts +10 -0
- package/ccw/dist/tools/chain-loader.d.ts.map +1 -0
- package/ccw/dist/tools/chain-loader.js +1054 -0
- package/ccw/dist/tools/chain-loader.js.map +1 -0
- package/ccw/dist/tools/index.d.ts.map +1 -1
- package/ccw/dist/tools/index.js +2 -0
- package/ccw/dist/tools/index.js.map +1 -1
- package/ccw/dist/tools/json-builder.js +20 -0
- package/ccw/dist/tools/json-builder.js.map +1 -1
- package/ccw/dist/tools/skill-context-loader.d.ts.map +1 -1
- package/ccw/dist/tools/skill-context-loader.js +12 -26
- package/ccw/dist/tools/skill-context-loader.js.map +1 -1
- package/ccw/dist/types/chain-types.d.ts +112 -0
- package/ccw/dist/types/chain-types.d.ts.map +1 -0
- package/ccw/dist/types/chain-types.js +5 -0
- package/ccw/dist/types/chain-types.js.map +1 -0
- package/ccw/dist/utils/chain-visualizer.d.ts +13 -0
- package/ccw/dist/utils/chain-visualizer.d.ts.map +1 -0
- package/ccw/dist/utils/chain-visualizer.js +164 -0
- package/ccw/dist/utils/chain-visualizer.js.map +1 -0
- package/ccw/scripts/prepublish-clean.mjs +0 -1
- package/package.json +1 -3
- package/.claude/commands/cli/cli-init.md +0 -441
- package/.claude/commands/cli/codex-review.md +0 -361
- package/.claude/commands/flow-create.md +0 -663
- package/.claude/skills/team-edict.zip +0 -0
- package/ccw-litellm/README.md +0 -180
- package/ccw-litellm/pyproject.toml +0 -35
- package/ccw-litellm/src/ccw_litellm/__init__.py +0 -47
- package/ccw-litellm/src/ccw_litellm/cli.py +0 -108
- package/ccw-litellm/src/ccw_litellm/clients/__init__.py +0 -12
- package/ccw-litellm/src/ccw_litellm/clients/litellm_embedder.py +0 -270
- package/ccw-litellm/src/ccw_litellm/clients/litellm_llm.py +0 -198
- package/ccw-litellm/src/ccw_litellm/config/__init__.py +0 -22
- package/ccw-litellm/src/ccw_litellm/config/loader.py +0 -343
- package/ccw-litellm/src/ccw_litellm/config/models.py +0 -162
- package/ccw-litellm/src/ccw_litellm/interfaces/__init__.py +0 -14
- package/ccw-litellm/src/ccw_litellm/interfaces/embedder.py +0 -52
- package/ccw-litellm/src/ccw_litellm/interfaces/llm.py +0 -45
|
@@ -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 |
|