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,229 +1,229 @@
|
|
|
1
|
-
---
|
|
2
|
-
name: team-quality-assurance
|
|
3
|
-
description: Unified team skill for quality assurance. Full closed-loop QA combining issue discovery and software testing. Triggers on "team quality-assurance", "team qa".
|
|
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 Quality Assurance
|
|
8
|
-
|
|
9
|
-
Orchestrate multi-agent QA: scout -> strategist -> generator -> executor -> analyst. Supports discovery, testing, and full closed-loop modes with parallel generation and GC loops.
|
|
10
|
-
|
|
11
|
-
## Architecture
|
|
12
|
-
|
|
13
|
-
```
|
|
14
|
-
Skill(skill="team-quality-assurance", 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 v
|
|
29
|
-
[scout] [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
|
-
| scout | [roles/scout/role.md](roles/scout/role.md) | SCOUT-* | false |
|
|
39
|
-
| strategist | [roles/strategist/role.md](roles/strategist/role.md) | QASTRAT-* | false |
|
|
40
|
-
| generator | [roles/generator/role.md](roles/generator/role.md) | QAGEN-* | false |
|
|
41
|
-
| executor | [roles/executor/role.md](roles/executor/role.md) | QARUN-* | true |
|
|
42
|
-
| analyst | [roles/analyst/role.md](roles/analyst/role.md) | QAANA-* | false |
|
|
43
|
-
|
|
44
|
-
## Role Router
|
|
45
|
-
|
|
46
|
-
Parse `$ARGUMENTS`:
|
|
47
|
-
- Has `--role <name>` -> Read `roles/<name>/role.md`, execute Phase 2-4
|
|
48
|
-
- No `--role` -> `roles/coordinator/role.md`, execute entry router
|
|
49
|
-
|
|
50
|
-
## Delegation Lock
|
|
51
|
-
|
|
52
|
-
**Coordinator is a PURE ORCHESTRATOR. It coordinates, it does NOT do.**
|
|
53
|
-
|
|
54
|
-
Before calling ANY tool, apply this check:
|
|
55
|
-
|
|
56
|
-
| Tool Call | Verdict | Reason |
|
|
57
|
-
|-----------|---------|--------|
|
|
58
|
-
| `spawn_agent`, `wait_agent`, `close_agent`, `send_message`, `assign_task` | ALLOWED | Orchestration |
|
|
59
|
-
| `list_agents` | ALLOWED | Agent health check |
|
|
60
|
-
| `request_user_input` | ALLOWED | User interaction |
|
|
61
|
-
| `mcp__ccw-tools__team_msg` | ALLOWED | Message bus |
|
|
62
|
-
| `Read/Write` on `.workflow/.team/` files | ALLOWED | Session state |
|
|
63
|
-
| `Read` on `roles/`, `commands/`, `specs/` | ALLOWED | Loading own instructions |
|
|
64
|
-
| `Read/Grep/Glob` on project source code | BLOCKED | Delegate to worker |
|
|
65
|
-
| `Edit` on any file outside `.workflow/` | BLOCKED | Delegate to worker |
|
|
66
|
-
| `Bash("ccw cli ...")` | BLOCKED | Only workers call CLI |
|
|
67
|
-
| `Bash` running build/test/lint commands | BLOCKED | Delegate to worker |
|
|
68
|
-
|
|
69
|
-
**If a tool call is BLOCKED**: STOP. Create a task, spawn a worker.
|
|
70
|
-
|
|
71
|
-
**No exceptions for "simple" tasks.** Even a single-file read-and-report MUST go through spawn_agent.
|
|
72
|
-
|
|
73
|
-
---
|
|
74
|
-
|
|
75
|
-
## Shared Constants
|
|
76
|
-
|
|
77
|
-
- **Session prefix**: `QA`
|
|
78
|
-
- **Session path**: `.workflow/.team/QA-<slug>-<date>/`
|
|
79
|
-
- **Team name**: `quality-assurance`
|
|
80
|
-
- **CLI tools**: `ccw cli --mode analysis` (read-only), `ccw cli --mode write` (modifications)
|
|
81
|
-
- **Message bus**: `mcp__ccw-tools__team_msg(session_id=<session-id>, ...)`
|
|
82
|
-
|
|
83
|
-
## Worker Spawn Template
|
|
84
|
-
|
|
85
|
-
Coordinator spawns workers using this template:
|
|
86
|
-
|
|
87
|
-
```
|
|
88
|
-
spawn_agent({
|
|
89
|
-
agent_type: "team_worker",
|
|
90
|
-
task_name: "<task-id>",
|
|
91
|
-
fork_context: false,
|
|
92
|
-
items: [
|
|
93
|
-
{ type: "text", text: `## Role Assignment
|
|
94
|
-
role: <role>
|
|
95
|
-
role_spec: <skill_root>/roles/<role>/role.md
|
|
96
|
-
session: <session-folder>
|
|
97
|
-
session_id: <session-id>
|
|
98
|
-
requirement: <task-description>
|
|
99
|
-
inner_loop: <true|false>
|
|
100
|
-
|
|
101
|
-
Read role_spec file (<skill_root>/roles/<role>/role.md) to load Phase 2-4 domain instructions.` },
|
|
102
|
-
|
|
103
|
-
{ type: "text", text: `## Task Context
|
|
104
|
-
task_id: <task-id>
|
|
105
|
-
title: <task-title>
|
|
106
|
-
description: <task-description>
|
|
107
|
-
pipeline_phase: <pipeline-phase>` },
|
|
108
|
-
|
|
109
|
-
{ type: "text", text: `## Upstream Context
|
|
110
|
-
<prev_context>` }
|
|
111
|
-
]
|
|
112
|
-
})
|
|
113
|
-
```
|
|
114
|
-
|
|
115
|
-
After spawning, use `wait_agent({ targets: [...], timeout_ms: 900000 })` to collect results, then `close_agent({ target })` each worker.
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
### Model Selection Guide
|
|
119
|
-
|
|
120
|
-
| Role | model | reasoning_effort | Rationale |
|
|
121
|
-
|------|-------|-------------------|-----------|
|
|
122
|
-
| Scout (SCOUT-*) | (default) | medium | Issue discovery scanning, less reasoning needed |
|
|
123
|
-
| Strategist (QASTRAT-*) | (default) | high | Test strategy design requires deep analysis |
|
|
124
|
-
| Generator (QAGEN-*) | (default) | high | Test code generation needs precision |
|
|
125
|
-
| Executor (QARUN-*) | (default) | medium | Running tests and collecting results |
|
|
126
|
-
| Analyst (QAANA-*) | (default) | high | Quality analysis and coverage assessment |
|
|
127
|
-
|
|
128
|
-
Override model/reasoning_effort in spawn_agent when cost optimization is needed:
|
|
129
|
-
```
|
|
130
|
-
spawn_agent({
|
|
131
|
-
agent_type: "team_worker",
|
|
132
|
-
task_name: "<task-id>",
|
|
133
|
-
fork_context: false,
|
|
134
|
-
model: "<model-override>",
|
|
135
|
-
reasoning_effort: "<effort-level>",
|
|
136
|
-
items: [...]
|
|
137
|
-
})
|
|
138
|
-
```
|
|
139
|
-
|
|
140
|
-
## User Commands
|
|
141
|
-
|
|
142
|
-
| Command | Action |
|
|
143
|
-
|---------|--------|
|
|
144
|
-
| `check` / `status` | View pipeline status graph |
|
|
145
|
-
| `resume` / `continue` | Advance to next step |
|
|
146
|
-
| `--mode=discovery` | Force discovery mode |
|
|
147
|
-
| `--mode=testing` | Force testing mode |
|
|
148
|
-
| `--mode=full` | Force full QA mode |
|
|
149
|
-
|
|
150
|
-
## v4 Agent Coordination
|
|
151
|
-
|
|
152
|
-
### Message Semantics
|
|
153
|
-
|
|
154
|
-
| Intent | API | Example |
|
|
155
|
-
|--------|-----|---------|
|
|
156
|
-
| Send scout findings to running strategist | `send_message` | Queue issue scan results to QASTRAT-* |
|
|
157
|
-
| Not used in this skill | `assign_task` | No resident agents -- all workers are one-shot |
|
|
158
|
-
| Check running agents | `list_agents` | Verify agent health during resume |
|
|
159
|
-
|
|
160
|
-
### Pipeline Pattern
|
|
161
|
-
|
|
162
|
-
Sequential pipeline with GC loops: scout -> strategist -> generator -> executor -> analyst. The executor/generator may loop via GC fix tasks when coverage is below target (max 3 rounds).
|
|
163
|
-
|
|
164
|
-
### Agent Health Check
|
|
165
|
-
|
|
166
|
-
Use `list_agents({})` in handleResume and handleComplete:
|
|
167
|
-
|
|
168
|
-
```
|
|
169
|
-
// Reconcile session state with actual running agents
|
|
170
|
-
const running = list_agents({})
|
|
171
|
-
// Compare with tasks.json active_agents
|
|
172
|
-
// Reset orphaned tasks (in_progress but agent gone) to pending
|
|
173
|
-
```
|
|
174
|
-
|
|
175
|
-
### Named Agent Targeting
|
|
176
|
-
|
|
177
|
-
Workers are spawned with `task_name: "<task-id>"` enabling direct addressing:
|
|
178
|
-
- `send_message({ target: "QASTRAT-001", items: [...] })` -- queue scout findings to running strategist
|
|
179
|
-
- `close_agent({ target: "SCOUT-001" })` -- cleanup by name after completion
|
|
180
|
-
|
|
181
|
-
## Completion Action
|
|
182
|
-
|
|
183
|
-
When pipeline completes, coordinator presents:
|
|
184
|
-
|
|
185
|
-
```
|
|
186
|
-
request_user_input({
|
|
187
|
-
questions: [{
|
|
188
|
-
question: "Quality Assurance pipeline complete. What would you like to do?",
|
|
189
|
-
header: "Completion",
|
|
190
|
-
multiSelect: false,
|
|
191
|
-
options: [
|
|
192
|
-
{ label: "Archive & Clean (Recommended)", description: "Archive session, clean up" },
|
|
193
|
-
{ label: "Keep Active", description: "Keep session for follow-up work" },
|
|
194
|
-
{ label: "Export Results", description: "Export deliverables to target directory" }
|
|
195
|
-
]
|
|
196
|
-
}]
|
|
197
|
-
})
|
|
198
|
-
```
|
|
199
|
-
|
|
200
|
-
## Session Directory
|
|
201
|
-
|
|
202
|
-
```
|
|
203
|
-
.workflow/.team/QA-<slug>-<date>/
|
|
204
|
-
├── .msg/messages.jsonl # Team message bus
|
|
205
|
-
├── .msg/meta.json # Session state + shared memory
|
|
206
|
-
├── wisdom/ # Cross-task knowledge
|
|
207
|
-
├── scan/ # Scout output
|
|
208
|
-
├── strategy/ # Strategist output
|
|
209
|
-
├── tests/ # Generator output (L1/, L2/, L3/)
|
|
210
|
-
├── results/ # Executor output
|
|
211
|
-
└── analysis/ # Analyst output
|
|
212
|
-
```
|
|
213
|
-
|
|
214
|
-
## Specs Reference
|
|
215
|
-
|
|
216
|
-
- [specs/pipelines.md](specs/pipelines.md) — Pipeline definitions and task registry
|
|
217
|
-
- [specs/team-config.json](specs/team-config.json) — Team configuration and shared memory schema
|
|
218
|
-
|
|
219
|
-
## Error Handling
|
|
220
|
-
|
|
221
|
-
| Scenario | Resolution |
|
|
222
|
-
|----------|------------|
|
|
223
|
-
| Unknown --role value | Error with available role list |
|
|
224
|
-
| Role not found | Error with expected path (roles/<name>/role.md) |
|
|
225
|
-
| CLI tool fails | Worker fallback to direct implementation |
|
|
226
|
-
| Scout finds no issues | Report clean scan, skip to testing mode |
|
|
227
|
-
| GC loop exceeded | Accept current coverage with warning |
|
|
228
|
-
| Fast-advance conflict | Coordinator reconciles on next callback |
|
|
229
|
-
| Completion action fails | Default to Keep Active |
|
|
1
|
+
---
|
|
2
|
+
name: team-quality-assurance
|
|
3
|
+
description: Unified team skill for quality assurance. Full closed-loop QA combining issue discovery and software testing. Triggers on "team quality-assurance", "team qa".
|
|
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 Quality Assurance
|
|
8
|
+
|
|
9
|
+
Orchestrate multi-agent QA: scout -> strategist -> generator -> executor -> analyst. Supports discovery, testing, and full closed-loop modes with parallel generation and GC loops.
|
|
10
|
+
|
|
11
|
+
## Architecture
|
|
12
|
+
|
|
13
|
+
```
|
|
14
|
+
Skill(skill="team-quality-assurance", 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 v
|
|
29
|
+
[scout] [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
|
+
| scout | [roles/scout/role.md](roles/scout/role.md) | SCOUT-* | false |
|
|
39
|
+
| strategist | [roles/strategist/role.md](roles/strategist/role.md) | QASTRAT-* | false |
|
|
40
|
+
| generator | [roles/generator/role.md](roles/generator/role.md) | QAGEN-* | false |
|
|
41
|
+
| executor | [roles/executor/role.md](roles/executor/role.md) | QARUN-* | true |
|
|
42
|
+
| analyst | [roles/analyst/role.md](roles/analyst/role.md) | QAANA-* | false |
|
|
43
|
+
|
|
44
|
+
## Role Router
|
|
45
|
+
|
|
46
|
+
Parse `$ARGUMENTS`:
|
|
47
|
+
- Has `--role <name>` -> Read `roles/<name>/role.md`, execute Phase 2-4
|
|
48
|
+
- No `--role` -> `roles/coordinator/role.md`, execute entry router
|
|
49
|
+
|
|
50
|
+
## Delegation Lock
|
|
51
|
+
|
|
52
|
+
**Coordinator is a PURE ORCHESTRATOR. It coordinates, it does NOT do.**
|
|
53
|
+
|
|
54
|
+
Before calling ANY tool, apply this check:
|
|
55
|
+
|
|
56
|
+
| Tool Call | Verdict | Reason |
|
|
57
|
+
|-----------|---------|--------|
|
|
58
|
+
| `spawn_agent`, `wait_agent`, `close_agent`, `send_message`, `assign_task` | ALLOWED | Orchestration |
|
|
59
|
+
| `list_agents` | ALLOWED | Agent health check |
|
|
60
|
+
| `request_user_input` | ALLOWED | User interaction |
|
|
61
|
+
| `mcp__ccw-tools__team_msg` | ALLOWED | Message bus |
|
|
62
|
+
| `Read/Write` on `.workflow/.team/` files | ALLOWED | Session state |
|
|
63
|
+
| `Read` on `roles/`, `commands/`, `specs/` | ALLOWED | Loading own instructions |
|
|
64
|
+
| `Read/Grep/Glob` on project source code | BLOCKED | Delegate to worker |
|
|
65
|
+
| `Edit` on any file outside `.workflow/` | BLOCKED | Delegate to worker |
|
|
66
|
+
| `Bash("ccw cli ...")` | BLOCKED | Only workers call CLI |
|
|
67
|
+
| `Bash` running build/test/lint commands | BLOCKED | Delegate to worker |
|
|
68
|
+
|
|
69
|
+
**If a tool call is BLOCKED**: STOP. Create a task, spawn a worker.
|
|
70
|
+
|
|
71
|
+
**No exceptions for "simple" tasks.** Even a single-file read-and-report MUST go through spawn_agent.
|
|
72
|
+
|
|
73
|
+
---
|
|
74
|
+
|
|
75
|
+
## Shared Constants
|
|
76
|
+
|
|
77
|
+
- **Session prefix**: `QA`
|
|
78
|
+
- **Session path**: `.workflow/.team/QA-<slug>-<date>/`
|
|
79
|
+
- **Team name**: `quality-assurance`
|
|
80
|
+
- **CLI tools**: `ccw cli --mode analysis` (read-only), `ccw cli --mode write` (modifications)
|
|
81
|
+
- **Message bus**: `mcp__ccw-tools__team_msg(session_id=<session-id>, ...)`
|
|
82
|
+
|
|
83
|
+
## Worker Spawn Template
|
|
84
|
+
|
|
85
|
+
Coordinator spawns workers using this template:
|
|
86
|
+
|
|
87
|
+
```
|
|
88
|
+
spawn_agent({
|
|
89
|
+
agent_type: "team_worker",
|
|
90
|
+
task_name: "<task-id>",
|
|
91
|
+
fork_context: false,
|
|
92
|
+
items: [
|
|
93
|
+
{ type: "text", text: `## Role Assignment
|
|
94
|
+
role: <role>
|
|
95
|
+
role_spec: <skill_root>/roles/<role>/role.md
|
|
96
|
+
session: <session-folder>
|
|
97
|
+
session_id: <session-id>
|
|
98
|
+
requirement: <task-description>
|
|
99
|
+
inner_loop: <true|false>
|
|
100
|
+
|
|
101
|
+
Read role_spec file (<skill_root>/roles/<role>/role.md) to load Phase 2-4 domain instructions.` },
|
|
102
|
+
|
|
103
|
+
{ type: "text", text: `## Task Context
|
|
104
|
+
task_id: <task-id>
|
|
105
|
+
title: <task-title>
|
|
106
|
+
description: <task-description>
|
|
107
|
+
pipeline_phase: <pipeline-phase>` },
|
|
108
|
+
|
|
109
|
+
{ type: "text", text: `## Upstream Context
|
|
110
|
+
<prev_context>` }
|
|
111
|
+
]
|
|
112
|
+
})
|
|
113
|
+
```
|
|
114
|
+
|
|
115
|
+
After spawning, use `wait_agent({ targets: [...], timeout_ms: 900000 })` to collect results, then `close_agent({ target })` each worker.
|
|
116
|
+
|
|
117
|
+
|
|
118
|
+
### Model Selection Guide
|
|
119
|
+
|
|
120
|
+
| Role | model | reasoning_effort | Rationale |
|
|
121
|
+
|------|-------|-------------------|-----------|
|
|
122
|
+
| Scout (SCOUT-*) | (default) | medium | Issue discovery scanning, less reasoning needed |
|
|
123
|
+
| Strategist (QASTRAT-*) | (default) | high | Test strategy design requires deep analysis |
|
|
124
|
+
| Generator (QAGEN-*) | (default) | high | Test code generation needs precision |
|
|
125
|
+
| Executor (QARUN-*) | (default) | medium | Running tests and collecting results |
|
|
126
|
+
| Analyst (QAANA-*) | (default) | high | Quality analysis and coverage assessment |
|
|
127
|
+
|
|
128
|
+
Override model/reasoning_effort in spawn_agent when cost optimization is needed:
|
|
129
|
+
```
|
|
130
|
+
spawn_agent({
|
|
131
|
+
agent_type: "team_worker",
|
|
132
|
+
task_name: "<task-id>",
|
|
133
|
+
fork_context: false,
|
|
134
|
+
model: "<model-override>",
|
|
135
|
+
reasoning_effort: "<effort-level>",
|
|
136
|
+
items: [...]
|
|
137
|
+
})
|
|
138
|
+
```
|
|
139
|
+
|
|
140
|
+
## User Commands
|
|
141
|
+
|
|
142
|
+
| Command | Action |
|
|
143
|
+
|---------|--------|
|
|
144
|
+
| `check` / `status` | View pipeline status graph |
|
|
145
|
+
| `resume` / `continue` | Advance to next step |
|
|
146
|
+
| `--mode=discovery` | Force discovery mode |
|
|
147
|
+
| `--mode=testing` | Force testing mode |
|
|
148
|
+
| `--mode=full` | Force full QA mode |
|
|
149
|
+
|
|
150
|
+
## v4 Agent Coordination
|
|
151
|
+
|
|
152
|
+
### Message Semantics
|
|
153
|
+
|
|
154
|
+
| Intent | API | Example |
|
|
155
|
+
|--------|-----|---------|
|
|
156
|
+
| Send scout findings to running strategist | `send_message` | Queue issue scan results to QASTRAT-* |
|
|
157
|
+
| Not used in this skill | `assign_task` | No resident agents -- all workers are one-shot |
|
|
158
|
+
| Check running agents | `list_agents` | Verify agent health during resume |
|
|
159
|
+
|
|
160
|
+
### Pipeline Pattern
|
|
161
|
+
|
|
162
|
+
Sequential pipeline with GC loops: scout -> strategist -> generator -> executor -> analyst. The executor/generator may loop via GC fix tasks when coverage is below target (max 3 rounds).
|
|
163
|
+
|
|
164
|
+
### Agent Health Check
|
|
165
|
+
|
|
166
|
+
Use `list_agents({})` in handleResume and handleComplete:
|
|
167
|
+
|
|
168
|
+
```
|
|
169
|
+
// Reconcile session state with actual running agents
|
|
170
|
+
const running = list_agents({})
|
|
171
|
+
// Compare with tasks.json active_agents
|
|
172
|
+
// Reset orphaned tasks (in_progress but agent gone) to pending
|
|
173
|
+
```
|
|
174
|
+
|
|
175
|
+
### Named Agent Targeting
|
|
176
|
+
|
|
177
|
+
Workers are spawned with `task_name: "<task-id>"` enabling direct addressing:
|
|
178
|
+
- `send_message({ target: "QASTRAT-001", items: [...] })` -- queue scout findings to running strategist
|
|
179
|
+
- `close_agent({ target: "SCOUT-001" })` -- cleanup by name after completion
|
|
180
|
+
|
|
181
|
+
## Completion Action
|
|
182
|
+
|
|
183
|
+
When pipeline completes, coordinator presents:
|
|
184
|
+
|
|
185
|
+
```
|
|
186
|
+
functions.request_user_input({
|
|
187
|
+
questions: [{
|
|
188
|
+
question: "Quality Assurance pipeline complete. What would you like to do?",
|
|
189
|
+
header: "Completion",
|
|
190
|
+
multiSelect: false,
|
|
191
|
+
options: [
|
|
192
|
+
{ label: "Archive & Clean (Recommended)", description: "Archive session, clean up" },
|
|
193
|
+
{ label: "Keep Active", description: "Keep session for follow-up work" },
|
|
194
|
+
{ label: "Export Results", description: "Export deliverables to target directory" }
|
|
195
|
+
]
|
|
196
|
+
}]
|
|
197
|
+
})
|
|
198
|
+
```
|
|
199
|
+
|
|
200
|
+
## Session Directory
|
|
201
|
+
|
|
202
|
+
```
|
|
203
|
+
.workflow/.team/QA-<slug>-<date>/
|
|
204
|
+
├── .msg/messages.jsonl # Team message bus
|
|
205
|
+
├── .msg/meta.json # Session state + shared memory
|
|
206
|
+
├── wisdom/ # Cross-task knowledge
|
|
207
|
+
├── scan/ # Scout output
|
|
208
|
+
├── strategy/ # Strategist output
|
|
209
|
+
├── tests/ # Generator output (L1/, L2/, L3/)
|
|
210
|
+
├── results/ # Executor output
|
|
211
|
+
└── analysis/ # Analyst output
|
|
212
|
+
```
|
|
213
|
+
|
|
214
|
+
## Specs Reference
|
|
215
|
+
|
|
216
|
+
- [specs/pipelines.md](specs/pipelines.md) — Pipeline definitions and task registry
|
|
217
|
+
- [specs/team-config.json](specs/team-config.json) — Team configuration and shared memory schema
|
|
218
|
+
|
|
219
|
+
## Error Handling
|
|
220
|
+
|
|
221
|
+
| Scenario | Resolution |
|
|
222
|
+
|----------|------------|
|
|
223
|
+
| Unknown --role value | Error with available role list |
|
|
224
|
+
| Role not found | Error with expected path (roles/<name>/role.md) |
|
|
225
|
+
| CLI tool fails | Worker fallback to direct implementation |
|
|
226
|
+
| Scout finds no issues | Report clean scan, skip to testing mode |
|
|
227
|
+
| GC loop exceeded | Accept current coverage with warning |
|
|
228
|
+
| Fast-advance conflict | Coordinator reconciles on next callback |
|
|
229
|
+
| Completion action fails | Default to Keep Active |
|