agent-patterns-plugin/skills/agent-teams/SKILL.md
Configure Claude Code agent teams (TeamCreate, SendMessage, TaskUpdate). Use when running parallel agents, coordinating with messaging, or setting up a lead/teammate architecture.
npx skillsauth add laurigates/claude-plugins agent-teamsInstall this skill globally with one command. Works with Claude Code, Cursor, and Windsurf.
3 of 9 scanners reported clean
Some scanners were skipped, did not run, or reported a non-clean status. Review each row below.
Experimental: Agent teams require the
--enable-teamsflag and may change between Claude Code versions.
| Use agent teams when... | Use subagents instead when... | |------------------------|------------------------------| | Multiple agents need to work in parallel | Tasks are sequential and interdependent | | Ongoing communication between agents is needed | One focused task produces one result | | Background tasks need progress reporting | Agent output feeds directly into next step | | Complex workflows benefit from task coordination | Simple, bounded, isolated execution | | Independent changes to the same codebase (with worktrees) | Context sharing is fine and efficient |
TeamCreate, Agent, and the related parallel-spawn tools may not be present in a sub-agent's tool surface, even if the parent conversation has them. A sub-agent designed to orchestrate its own team can silently degrade to sequential single-thread execution — same content, much longer wall-clock — without surfacing the failure until its post-completion summary.
Authoring guidance:
| Situation | Recommended pattern |
|-----------|---------------------|
| Fan-out from the main conversation | Spawn the team / parallel Agent calls directly — full tool surface available |
| Sub-agent orchestrating its own team | Avoid by design when possible: split the work so the main thread does the fan-out |
| Sub-agent must orchestrate a team | Detect tool availability up front; report sequential fallback as a first-class outcome |
Detection contract for coordinating sub-agents:
Brief the orchestrating sub-agent to verify before dispatching:
1. Confirm Agent / TeamCreate are callable. If unavailable (e.g. ToolSearch
does not surface them, or invocation returns "tool not found"), do NOT
silently fall back.
2. Report the constraint as the first line of the final summary:
"Parallel fan-out unavailable in this sandbox; executed sequentially."
3. Continue sequentially with the same input contract — outputs should be
identical in content, only longer in wall-clock.
The wall-clock cost is real: a 5-way fan-out that degrades to sequential takes ~5× longer. Plan top-level orchestration in the main conversation when you can; reserve sub-agent orchestrators for cases where the team's outputs do not need to feed back into the main thread.
Evidence: a Phase 2 portability-audit dispatch instructed a coordinating sub-agent to spawn 5 parallel auditors via
Agent; theAgenttool was not registered in the sub-agent's sandbox. Output was equivalent but wall-clock was much longer than designed, and the failure surfaced only in the post-completion note.
Lead Agent (orchestrator)
├── TeamCreate — creates team + shared task list
├── Agent tool — spawns teammate agents
├── SendMessage — communicates with teammates
├── TaskUpdate — assigns tasks to teammates
└── Teammates (run in parallel)
├── Read team config from ~/.claude/teams/<name>/config.json
├── TaskList/TaskUpdate — claim and complete tasks
└── SendMessage — report back to lead
| Tool | Purpose |
|------|---------|
| TeamCreate | Create team and shared task list directory |
| TeamDelete | Clean up team when all work is complete |
| SendMessage | Send DMs, broadcasts, shutdown requests, plan approvals |
| TaskOutput | Get output from a background agent |
| TaskStop | Stop a running background agent |
TeamCreate({
team_name: "my-project",
description: "Working on feature X"
})
This creates:
~/.claude/teams/<team-name>/ — team config directory~/.claude/tasks/<team-name>/ — shared task list directoryTaskCreate({
team_name: "my-project",
title: "Implement security review",
description: "Audit auth module for vulnerabilities",
status: "pending"
})
Use the Agent tool to spawn each teammate with the team context:
Agent tool with:
subagent_type: "agents-plugin:security-audit"
team_name: "my-project"
name: "security-reviewer"
prompt: "Join team my-project and work on security review task..."
TaskUpdate({
team_name: "my-project",
task_id: "task-1",
owner: "security-reviewer",
status: "in_progress"
})
Teammates send messages automatically — they are delivered to the lead's inbox between turns. No polling needed.
| State | Meaning |
|-------|---------|
| pending | Not yet started |
| in_progress | Assigned and active (one at a time per teammate) |
| completed | Finished successfully |
| blocked | Waiting on another task |
Teammates should claim tasks in ID order (lowest first) — earlier tasks often set up context for later ones.
Teammates should check TaskList after completing each task to find available work:
TaskList({ team_name: "my-project" })
→ Returns all tasks with status, owner, and blocked-by info
Claim an unassigned task:
TaskUpdate({ team_name: "my-project", task_id: "N", owner: "my-name" })
| Type | Use When |
|------|----------|
| message | Direct message to a specific teammate |
| broadcast | Critical team-wide announcement (use sparingly — expensive) |
| shutdown_request | Ask a teammate to gracefully exit |
| shutdown_response | Approve or reject a shutdown request |
| plan_approval_response | Approve or reject a teammate's plan |
SendMessage({
type: "message",
recipient: "security-reviewer", // Use NAME, not agent ID
content: "Please also check the payment module",
summary: "Adding payment module to scope"
})
SendMessage({
type: "broadcast",
content: "Stop all work — critical blocker found in auth module",
summary: "Critical blocker: halt work"
})
Broadcasting sends a separate delivery to every teammate. With N teammates, that's N API round-trips. Reserve for genuine team-wide blockers.
Read the team config to find other members:
Read ~/.claude/teams/<team-name>/config.json
→ members array with name, agentId, agentType
Always use the name field (not agentId) for recipient in SendMessage.
Teammates go idle after every turn — this is normal. Idle ≠ unavailable. Sending a message to an idle teammate wakes them.
in_progress at a timeTaskUpdate (not SendMessage) to report task completionSendMessage — plain text output is NOT visible to the team leadSendMessage({
type: "shutdown_request",
recipient: "security-reviewer",
content: "All tasks complete, wrapping up"
})
SendMessage({
type: "shutdown_response",
request_id: "<id from shutdown_request JSON>",
approve: true
})
After all teammates shut down:
TeamDelete()
→ Removes ~/.claude/teams/<name>/ and ~/.claude/tasks/<name>/
TeamDelete fails if teammates are still active.
Before drafting the PRP and launching agents, run these checks:
| Check | Command | Why |
|-------|---------|-----|
| Next ADR/PRD/PRP sequence number | ls docs/blueprint/adrs/ \| sort -V \| tail -1 | Prevents numbering collisions when agents write docs in parallel |
| Filename conflicts | git ls-files \| grep <filename> | Agent scope tables can't guard against a stale mental model of the tree |
| Hardware pin budget (embedded) | Read pin_config.h or equivalent | Prevents pin assignments overlapping across Phase 1 agents |
A 30-second sweep prevents multi-edit renaming work after agents return.
Include this protocol in every agent's prompt when that agent has an exclusive write scope:
### Out-of-scope discovery protocol
If you discover that a file outside your declared write scope needs to change
for your deliverables to work:
1. **STOP immediately.** Do not read, investigate, or edit the out-of-scope file.
2. In your final summary, include a section titled `Out-of-scope dependencies` that lists:
- The file(s) that need changes
- What changes are needed (one line each)
- Which of your deliverables is blocked without those changes
3. Exit. The lead will triage and either expand your scope, reassign to another agent,
or handle it directly.
This prevents the "investigate out of scope → exhaust budget → truncated summary" failure mode. The lead can then address the dependency before the next phase or assign a follow-up issue.
Known failure mode (worktree isolation): Agents launched with
isolation: "worktree"may haveEdit/Writetool calls silently resolve relative paths against the parent repo rather than the agent's worktree, even thoughBashcommands andgit statuscorrectly operate inside the worktree. The agent gets no immediate signal that file writes are landing on the wrong branch — commits can land on a sibling agent's branch or on the parent repo's working tree. Cleanup requires cherry-pick + rebase drop-if-upstream after the fact.Tracking: laurigates/claude-plugins#1091
The bug lives in Claude Code's worktree path-resolution layer (upstream). Until it is fixed, harden every worktree-isolated agent prompt with the preamble below and run the post-flight check before merging.
Paste this verbatim at the top of any worktree-isolated agent's prompt — before any other instructions or task description:
**First action MUST be:**
pwd
git rev-parse --show-toplevel
ls -la
**All file edits must use absolute paths rooted at your worktree.**
**If `Edit` or `Write` appears to target anything outside your worktree,
stop and report — do not retry.**
The three commands give the agent (and the transcript reader) an unambiguous signal of where it actually is. Absolute paths bypass the relative-resolution bug entirely. The "stop and report" clause prevents the recovery-by-retry loop that compounds the damage.
After agents return, run from the parent repo before merging:
git diff origin/main..HEAD # parent's intended branch should be clean
git status --porcelain # no straggler edits in parent worktree
If either is non-empty, an agent's Edit/Write leaked into the parent.
Inspect the diff before any further git operations.
If a stray commit lands on the wrong branch:
git cherry-pick <stray-sha>.git rebase --onto <new-base> <old-base> <wrong-branch> (run with
git config rebase.dropOnUpstream true or use git rebase -i and
delete the duplicate line).git log --oneline <wrong-branch> ^<intended-branch>
that only the wrong-branch's own commits remain.For the broader concurrency context (shared-clone vs. worktree
coordination), see .claude/rules/agent-coworker-detection.md.
TeamCreate: "code-review"
Tasks: security-audit, performance-review, correctness-check
Teammates: security-agent, performance-agent, correctness-agent (all parallel)
Lead: collects results, synthesizes findings
TeamCreate: "feature-impl"
Tasks: backend-api, frontend-ui, tests
Teammates: each spawned with isolation: "worktree"
Lead: delegates git push (sub-agents must not push independently in sandbox)
Phase 1 (3 parallel): Framework upgrade + new module scaffolding + ADR draft
Phase 2 (1 serialized): Reactive executor — depends on Phase 1 contracts
Phase 3 (1 serialized): Wire-up + legacy deletion — exclusive main.c owner
Phase 4 (2 parallel): Host tests + documentation finalization
Key rules:
- One owner per file across ALL phases (exclusive write scope per agent)
- "Agent writes, lead commits" — keep branch coherent between phases
- Phase boundaries = commit points (clean checkpoint semantics)
- Phase 3 deletion runs AFTER Phases 1–2 finalize their contracts
Real-world outcome: +1850/−1826 lines, zero file-scope collisions across 6 agents, tests exposed a bug on first build. See also: the Out-of-Scope Discovery Protocol above — include it in every focused-scope agent prompt.
If a task is blocked on another, set the blocked_by field in TaskCreate. Teammates check TaskList and skip blocked tasks until the blocking task is completed.
| Role | Behavior | When to Use | |------|----------|-------------| | Lead | Orchestrates, assigns tasks, receives results | Always — coordinates the team | | Teammate | Parallel execution with messaging | Ongoing collaboration, progress reporting | | Subagent | Focused, isolated, returns single result | Simple bounded tasks, no coordination needed |
In web sessions (CLAUDE_CODE_REMOTE=true):
git push — delegate all push/PR operations to the lead| Context | Approach |
|---------|----------|
| Quick parallel review | Spawn 2–4 teammates, broadcast task assignments |
| Large codebase split | Assign directory subsets as separate tasks |
| Long-running work | Background teammates, poll via TaskList |
| Minimize API cost | Prefer message over broadcast |
| Fast shutdown | Send shutdown_request to each teammate, then TeamDelete |
TeamCreate with team name and descriptionTaskCreate for each work unitteam_name and nameTaskUpdate to assign tasks to teammates (or let teammates self-assign)SendMessageSendMessage shutdown_request to each teammate when doneTeamDelete after all teammates shut down| Path | Contents |
|------|----------|
| ~/.claude/teams/<name>/config.json | Team members (name, agentId, agentType) |
| ~/.claude/tasks/<name>/ | Shared task list directory |
| Mistake | Correct Approach |
|---------|-----------------|
| Using agentId as recipient | Use name field from config.json |
| Sending broadcast for every update | Use message for single-recipient comms |
| Polling for messages | Messages delivered automatically — just wait |
| Sending JSON status messages | Use TaskUpdate for status, plain text for messages |
| Sub-agent pushes to remote | Delegate push to lead orchestrator |
| TeamDelete before shutdown | Shutdown all teammates first |
parallel-agent-dispatch — worktree preflight, scope budgets, and the Return Contract that every teammate must emit on exit. Team dispatches are a superset of plain parallel fan-out; follow both..claude/rules/agent-development.md — agent file structure, model selection, worktree isolation.claude/rules/agentic-permissions.md — granular tool permission patterns.claude/rules/sandbox-guidance.md — web sandbox constraints and push delegationtools
Scaffold a new ComfyUI custom-node repo (pyproject, CI, release-please, vitest+pytest, JS extension skeleton) in the picker/gesture vein. Use when bootstrapping or init-ing a comfyui node pack.
tools
Orchestrate a ComfyUI node pack from idea to registry: scaffold, create + seed the repo, open the gitops adoption PR. Use when releasing or spinning up a new comfyui node pack.
testing
macOS EndpointSecurity/EDR high CPU & battery drain. Use when Kandji ESF / XProtect pegs a core; trace the exec storm via powermetrics + eslogger.
development
odiff pixel-by-pixel image diffing. Use when comparing screenshots, detecting visual regressions, diffing before/after PNGs, asserting golden images.