claude-mpm 5.4.55__py3-none-any.whl → 5.4.85__py3-none-any.whl
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.
- claude_mpm/VERSION +1 -1
- claude_mpm/agents/CLAUDE_MPM_FOUNDERS_OUTPUT_STYLE.md +405 -0
- claude_mpm/agents/CLAUDE_MPM_OUTPUT_STYLE.md +63 -241
- claude_mpm/agents/CLAUDE_MPM_TEACHER_OUTPUT_STYLE.md +109 -1925
- claude_mpm/agents/PM_INSTRUCTIONS.md +36 -9
- claude_mpm/cli/__init__.py +5 -1
- claude_mpm/cli/commands/agents.py +2 -4
- claude_mpm/cli/commands/agents_reconcile.py +197 -0
- claude_mpm/cli/commands/configure.py +620 -21
- claude_mpm/cli/commands/skills.py +166 -14
- claude_mpm/cli/executor.py +1 -0
- claude_mpm/cli/interactive/__init__.py +10 -0
- claude_mpm/cli/interactive/agent_wizard.py +30 -50
- claude_mpm/cli/interactive/questionary_styles.py +65 -0
- claude_mpm/cli/interactive/skill_selector.py +481 -0
- claude_mpm/cli/parsers/base_parser.py +5 -0
- claude_mpm/cli/startup.py +223 -388
- claude_mpm/constants.py +1 -0
- claude_mpm/core/claude_runner.py +2 -2
- claude_mpm/core/interactive_session.py +7 -7
- claude_mpm/core/output_style_manager.py +21 -13
- claude_mpm/core/unified_config.py +50 -8
- claude_mpm/core/unified_paths.py +30 -13
- claude_mpm/scripts/start_activity_logging.py +0 -0
- claude_mpm/services/agents/deployment/agent_template_builder.py +8 -0
- claude_mpm/services/agents/deployment/deployment_reconciler.py +577 -0
- claude_mpm/services/agents/deployment/startup_reconciliation.py +138 -0
- claude_mpm/services/agents/sources/git_source_sync_service.py +7 -4
- claude_mpm/services/agents/startup_sync.py +5 -2
- claude_mpm/services/pm_skills_deployer.py +4 -0
- claude_mpm/services/skills/git_skill_source_manager.py +24 -8
- claude_mpm/services/skills/selective_skill_deployer.py +82 -83
- claude_mpm/skills/bundled/collaboration/brainstorming/SKILL.md +79 -0
- claude_mpm/skills/bundled/collaboration/dispatching-parallel-agents/SKILL.md +178 -0
- claude_mpm/skills/bundled/collaboration/dispatching-parallel-agents/references/agent-prompts.md +577 -0
- claude_mpm/skills/bundled/collaboration/dispatching-parallel-agents/references/coordination-patterns.md +467 -0
- claude_mpm/skills/bundled/collaboration/dispatching-parallel-agents/references/examples.md +537 -0
- claude_mpm/skills/bundled/collaboration/dispatching-parallel-agents/references/troubleshooting.md +730 -0
- claude_mpm/skills/bundled/collaboration/git-worktrees.md +317 -0
- claude_mpm/skills/bundled/collaboration/requesting-code-review/SKILL.md +112 -0
- claude_mpm/skills/bundled/collaboration/requesting-code-review/references/code-reviewer-template.md +146 -0
- claude_mpm/skills/bundled/collaboration/requesting-code-review/references/review-examples.md +412 -0
- claude_mpm/skills/bundled/collaboration/stacked-prs.md +251 -0
- claude_mpm/skills/bundled/collaboration/writing-plans/SKILL.md +81 -0
- claude_mpm/skills/bundled/collaboration/writing-plans/references/best-practices.md +362 -0
- claude_mpm/skills/bundled/collaboration/writing-plans/references/plan-structure-templates.md +312 -0
- claude_mpm/skills/bundled/debugging/root-cause-tracing/SKILL.md +152 -0
- claude_mpm/skills/bundled/debugging/root-cause-tracing/references/advanced-techniques.md +668 -0
- claude_mpm/skills/bundled/debugging/root-cause-tracing/references/examples.md +587 -0
- claude_mpm/skills/bundled/debugging/root-cause-tracing/references/integration.md +438 -0
- claude_mpm/skills/bundled/debugging/root-cause-tracing/references/tracing-techniques.md +391 -0
- claude_mpm/skills/bundled/debugging/systematic-debugging/CREATION-LOG.md +119 -0
- claude_mpm/skills/bundled/debugging/systematic-debugging/SKILL.md +148 -0
- claude_mpm/skills/bundled/debugging/systematic-debugging/references/anti-patterns.md +483 -0
- claude_mpm/skills/bundled/debugging/systematic-debugging/references/examples.md +452 -0
- claude_mpm/skills/bundled/debugging/systematic-debugging/references/troubleshooting.md +449 -0
- claude_mpm/skills/bundled/debugging/systematic-debugging/references/workflow.md +411 -0
- claude_mpm/skills/bundled/debugging/systematic-debugging/test-academic.md +14 -0
- claude_mpm/skills/bundled/debugging/systematic-debugging/test-pressure-1.md +58 -0
- claude_mpm/skills/bundled/debugging/systematic-debugging/test-pressure-2.md +68 -0
- claude_mpm/skills/bundled/debugging/systematic-debugging/test-pressure-3.md +69 -0
- claude_mpm/skills/bundled/debugging/verification-before-completion/SKILL.md +131 -0
- claude_mpm/skills/bundled/debugging/verification-before-completion/references/gate-function.md +325 -0
- claude_mpm/skills/bundled/debugging/verification-before-completion/references/integration-and-workflows.md +490 -0
- claude_mpm/skills/bundled/debugging/verification-before-completion/references/red-flags-and-failures.md +425 -0
- claude_mpm/skills/bundled/debugging/verification-before-completion/references/verification-patterns.md +499 -0
- claude_mpm/skills/bundled/infrastructure/env-manager/INTEGRATION.md +611 -0
- claude_mpm/skills/bundled/infrastructure/env-manager/README.md +596 -0
- claude_mpm/skills/bundled/infrastructure/env-manager/SKILL.md +260 -0
- claude_mpm/skills/bundled/infrastructure/env-manager/examples/nextjs-env-structure.md +315 -0
- claude_mpm/skills/bundled/infrastructure/env-manager/references/frameworks.md +436 -0
- claude_mpm/skills/bundled/infrastructure/env-manager/references/security.md +433 -0
- claude_mpm/skills/bundled/infrastructure/env-manager/references/synchronization.md +452 -0
- claude_mpm/skills/bundled/infrastructure/env-manager/references/troubleshooting.md +404 -0
- claude_mpm/skills/bundled/infrastructure/env-manager/references/validation.md +420 -0
- claude_mpm/skills/bundled/main/artifacts-builder/SKILL.md +86 -0
- claude_mpm/skills/bundled/main/internal-comms/SKILL.md +43 -0
- claude_mpm/skills/bundled/main/internal-comms/examples/3p-updates.md +47 -0
- claude_mpm/skills/bundled/main/internal-comms/examples/company-newsletter.md +65 -0
- claude_mpm/skills/bundled/main/internal-comms/examples/faq-answers.md +30 -0
- claude_mpm/skills/bundled/main/internal-comms/examples/general-comms.md +16 -0
- claude_mpm/skills/bundled/main/mcp-builder/SKILL.md +160 -0
- claude_mpm/skills/bundled/main/mcp-builder/reference/design_principles.md +412 -0
- claude_mpm/skills/bundled/main/mcp-builder/reference/evaluation.md +602 -0
- claude_mpm/skills/bundled/main/mcp-builder/reference/mcp_best_practices.md +915 -0
- claude_mpm/skills/bundled/main/mcp-builder/reference/node_mcp_server.md +916 -0
- claude_mpm/skills/bundled/main/mcp-builder/reference/python_mcp_server.md +752 -0
- claude_mpm/skills/bundled/main/mcp-builder/reference/workflow.md +1237 -0
- claude_mpm/skills/bundled/main/skill-creator/SKILL.md +189 -0
- claude_mpm/skills/bundled/main/skill-creator/references/best-practices.md +500 -0
- claude_mpm/skills/bundled/main/skill-creator/references/creation-workflow.md +464 -0
- claude_mpm/skills/bundled/main/skill-creator/references/examples.md +619 -0
- claude_mpm/skills/bundled/main/skill-creator/references/progressive-disclosure.md +437 -0
- claude_mpm/skills/bundled/main/skill-creator/references/skill-structure.md +231 -0
- claude_mpm/skills/bundled/php/espocrm-development/SKILL.md +170 -0
- claude_mpm/skills/bundled/php/espocrm-development/references/architecture.md +602 -0
- claude_mpm/skills/bundled/php/espocrm-development/references/common-tasks.md +821 -0
- claude_mpm/skills/bundled/php/espocrm-development/references/development-workflow.md +742 -0
- claude_mpm/skills/bundled/php/espocrm-development/references/frontend-customization.md +726 -0
- claude_mpm/skills/bundled/php/espocrm-development/references/hooks-and-services.md +764 -0
- claude_mpm/skills/bundled/php/espocrm-development/references/testing-debugging.md +831 -0
- claude_mpm/skills/bundled/pm/pm-bug-reporting/pm-bug-reporting.md +248 -0
- claude_mpm/skills/bundled/pm/pm-delegation-patterns/SKILL.md +167 -0
- claude_mpm/skills/bundled/pm/pm-git-file-tracking/SKILL.md +113 -0
- claude_mpm/skills/bundled/pm/pm-pr-workflow/SKILL.md +124 -0
- claude_mpm/skills/bundled/pm/pm-teaching-mode/SKILL.md +657 -0
- claude_mpm/skills/bundled/pm/pm-ticketing-integration/SKILL.md +154 -0
- claude_mpm/skills/bundled/pm/pm-verification-protocols/SKILL.md +198 -0
- claude_mpm/skills/bundled/react/flexlayout-react.md +742 -0
- claude_mpm/skills/bundled/rust/desktop-applications/SKILL.md +226 -0
- claude_mpm/skills/bundled/rust/desktop-applications/references/architecture-patterns.md +901 -0
- claude_mpm/skills/bundled/rust/desktop-applications/references/native-gui-frameworks.md +901 -0
- claude_mpm/skills/bundled/rust/desktop-applications/references/platform-integration.md +775 -0
- claude_mpm/skills/bundled/rust/desktop-applications/references/state-management.md +937 -0
- claude_mpm/skills/bundled/rust/desktop-applications/references/tauri-framework.md +770 -0
- claude_mpm/skills/bundled/rust/desktop-applications/references/testing-deployment.md +961 -0
- claude_mpm/skills/bundled/tauri/tauri-async-patterns.md +495 -0
- claude_mpm/skills/bundled/tauri/tauri-build-deploy.md +599 -0
- claude_mpm/skills/bundled/tauri/tauri-command-patterns.md +535 -0
- claude_mpm/skills/bundled/tauri/tauri-error-handling.md +613 -0
- claude_mpm/skills/bundled/tauri/tauri-event-system.md +648 -0
- claude_mpm/skills/bundled/tauri/tauri-file-system.md +673 -0
- claude_mpm/skills/bundled/tauri/tauri-frontend-integration.md +767 -0
- claude_mpm/skills/bundled/tauri/tauri-performance.md +669 -0
- claude_mpm/skills/bundled/tauri/tauri-state-management.md +573 -0
- claude_mpm/skills/bundled/tauri/tauri-testing.md +384 -0
- claude_mpm/skills/bundled/tauri/tauri-window-management.md +628 -0
- claude_mpm/skills/bundled/testing/condition-based-waiting/SKILL.md +119 -0
- claude_mpm/skills/bundled/testing/condition-based-waiting/references/patterns-and-implementation.md +253 -0
- claude_mpm/skills/bundled/testing/test-driven-development/SKILL.md +145 -0
- claude_mpm/skills/bundled/testing/test-driven-development/references/anti-patterns.md +543 -0
- claude_mpm/skills/bundled/testing/test-driven-development/references/examples.md +741 -0
- claude_mpm/skills/bundled/testing/test-driven-development/references/integration.md +470 -0
- claude_mpm/skills/bundled/testing/test-driven-development/references/philosophy.md +458 -0
- claude_mpm/skills/bundled/testing/test-driven-development/references/workflow.md +639 -0
- claude_mpm/skills/bundled/testing/test-quality-inspector/SKILL.md +458 -0
- claude_mpm/skills/bundled/testing/test-quality-inspector/examples/example-inspection-report.md +411 -0
- claude_mpm/skills/bundled/testing/test-quality-inspector/references/assertion-quality.md +317 -0
- claude_mpm/skills/bundled/testing/test-quality-inspector/references/inspection-checklist.md +270 -0
- claude_mpm/skills/bundled/testing/test-quality-inspector/references/red-flags.md +436 -0
- claude_mpm/skills/bundled/testing/testing-anti-patterns/SKILL.md +140 -0
- claude_mpm/skills/bundled/testing/testing-anti-patterns/references/completeness-anti-patterns.md +572 -0
- claude_mpm/skills/bundled/testing/testing-anti-patterns/references/core-anti-patterns.md +411 -0
- claude_mpm/skills/bundled/testing/testing-anti-patterns/references/detection-guide.md +569 -0
- claude_mpm/skills/bundled/testing/testing-anti-patterns/references/tdd-connection.md +695 -0
- claude_mpm/skills/bundled/testing/webapp-testing/SKILL.md +184 -0
- claude_mpm/skills/bundled/testing/webapp-testing/decision-tree.md +459 -0
- claude_mpm/skills/bundled/testing/webapp-testing/playwright-patterns.md +479 -0
- claude_mpm/skills/bundled/testing/webapp-testing/reconnaissance-pattern.md +687 -0
- claude_mpm/skills/bundled/testing/webapp-testing/server-management.md +758 -0
- claude_mpm/skills/bundled/testing/webapp-testing/troubleshooting.md +868 -0
- claude_mpm/utils/agent_dependency_loader.py +103 -4
- claude_mpm/utils/robust_installer.py +45 -24
- {claude_mpm-5.4.55.dist-info → claude_mpm-5.4.85.dist-info}/METADATA +47 -23
- {claude_mpm-5.4.55.dist-info → claude_mpm-5.4.85.dist-info}/RECORD +159 -47
- claude_mpm/hooks/claude_hooks/__pycache__/__init__.cpython-311.pyc +0 -0
- claude_mpm/hooks/claude_hooks/__pycache__/correlation_manager.cpython-311.pyc +0 -0
- claude_mpm/hooks/claude_hooks/__pycache__/event_handlers.cpython-311.pyc +0 -0
- claude_mpm/hooks/claude_hooks/__pycache__/hook_handler.cpython-311.pyc +0 -0
- claude_mpm/hooks/claude_hooks/__pycache__/installer.cpython-311.pyc +0 -0
- claude_mpm/hooks/claude_hooks/__pycache__/memory_integration.cpython-311.pyc +0 -0
- claude_mpm/hooks/claude_hooks/__pycache__/response_tracking.cpython-311.pyc +0 -0
- claude_mpm/hooks/claude_hooks/__pycache__/tool_analysis.cpython-311.pyc +0 -0
- claude_mpm/hooks/claude_hooks/services/__pycache__/__init__.cpython-311.pyc +0 -0
- claude_mpm/hooks/claude_hooks/services/__pycache__/connection_manager_http.cpython-311.pyc +0 -0
- claude_mpm/hooks/claude_hooks/services/__pycache__/duplicate_detector.cpython-311.pyc +0 -0
- claude_mpm/hooks/claude_hooks/services/__pycache__/state_manager.cpython-311.pyc +0 -0
- claude_mpm/hooks/claude_hooks/services/__pycache__/subagent_processor.cpython-311.pyc +0 -0
- {claude_mpm-5.4.55.dist-info → claude_mpm-5.4.85.dist-info}/WHEEL +0 -0
- {claude_mpm-5.4.55.dist-info → claude_mpm-5.4.85.dist-info}/entry_points.txt +0 -0
- {claude_mpm-5.4.55.dist-info → claude_mpm-5.4.85.dist-info}/licenses/LICENSE +0 -0
- {claude_mpm-5.4.55.dist-info → claude_mpm-5.4.85.dist-info}/licenses/LICENSE-FAQ.md +0 -0
- {claude_mpm-5.4.55.dist-info → claude_mpm-5.4.85.dist-info}/top_level.txt +0 -0
|
@@ -0,0 +1,467 @@
|
|
|
1
|
+
# Coordination Patterns
|
|
2
|
+
|
|
3
|
+
Complete guide to identifying independent domains, dispatching agents, and integrating their work.
|
|
4
|
+
|
|
5
|
+
## Domain Identification Patterns
|
|
6
|
+
|
|
7
|
+
### The Independence Test
|
|
8
|
+
|
|
9
|
+
Before dispatching parallel agents, verify true independence:
|
|
10
|
+
|
|
11
|
+
```
|
|
12
|
+
✓ Independent domains:
|
|
13
|
+
- Different test files with unrelated functionality
|
|
14
|
+
- Different subsystems (auth, payments, notifications)
|
|
15
|
+
- Different bug reports from different users
|
|
16
|
+
- Different data processing pipelines
|
|
17
|
+
|
|
18
|
+
✗ Not independent:
|
|
19
|
+
- Tests failing due to shared database state
|
|
20
|
+
- Cascading failures (one root cause, many symptoms)
|
|
21
|
+
- Features that share core business logic
|
|
22
|
+
- Components with tight coupling
|
|
23
|
+
```
|
|
24
|
+
|
|
25
|
+
### Domain Grouping Strategy
|
|
26
|
+
|
|
27
|
+
**By Test File:**
|
|
28
|
+
```
|
|
29
|
+
File A: tool-approval-flow.test.ts
|
|
30
|
+
File B: batch-completion.test.ts
|
|
31
|
+
File C: abort-handling.test.ts
|
|
32
|
+
→ 3 domains, each gets one agent
|
|
33
|
+
```
|
|
34
|
+
|
|
35
|
+
**By Subsystem:**
|
|
36
|
+
```
|
|
37
|
+
Subsystem A: Authentication module
|
|
38
|
+
Subsystem B: Payment processing
|
|
39
|
+
Subsystem C: Email notifications
|
|
40
|
+
→ 3 domains, clear boundaries
|
|
41
|
+
```
|
|
42
|
+
|
|
43
|
+
**By Feature:**
|
|
44
|
+
```
|
|
45
|
+
Feature A: User registration flow
|
|
46
|
+
Feature B: Product search
|
|
47
|
+
Feature C: Shopping cart
|
|
48
|
+
→ 3 domains, minimal overlap
|
|
49
|
+
```
|
|
50
|
+
|
|
51
|
+
### Anti-Pattern: False Independence
|
|
52
|
+
|
|
53
|
+
```
|
|
54
|
+
❌ BAD: Treat as independent when they're not
|
|
55
|
+
Problem 1: Login tests failing
|
|
56
|
+
Problem 2: Dashboard tests failing (needs login)
|
|
57
|
+
Problem 3: User profile tests failing (needs login)
|
|
58
|
+
|
|
59
|
+
→ NOT independent! Root cause is login.
|
|
60
|
+
→ Solution: Single agent investigates login first
|
|
61
|
+
```
|
|
62
|
+
|
|
63
|
+
## Dispatch Strategies
|
|
64
|
+
|
|
65
|
+
### Strategy 1: Parallel Task Creation
|
|
66
|
+
|
|
67
|
+
**Best for:** Clear, well-defined problems with no discovery needed
|
|
68
|
+
|
|
69
|
+
```typescript
|
|
70
|
+
// All tasks created at once
|
|
71
|
+
Task("Fix authentication flow - login.test.ts 3 failures")
|
|
72
|
+
Task("Fix payment processing - checkout.test.ts 2 failures")
|
|
73
|
+
Task("Fix email service - notifications.test.ts 4 failures")
|
|
74
|
+
|
|
75
|
+
// Agents work simultaneously
|
|
76
|
+
// You review results when all complete
|
|
77
|
+
```
|
|
78
|
+
|
|
79
|
+
**Advantages:**
|
|
80
|
+
- Maximum parallelization
|
|
81
|
+
- Fastest total time
|
|
82
|
+
- Clear workload distribution
|
|
83
|
+
|
|
84
|
+
**Disadvantages:**
|
|
85
|
+
- Requires upfront domain analysis
|
|
86
|
+
- Risk of conflicts if domains overlap
|
|
87
|
+
- Hard to adjust if one agent finds systemic issue
|
|
88
|
+
|
|
89
|
+
### Strategy 2: Sequential with Parallel Bursts
|
|
90
|
+
|
|
91
|
+
**Best for:** Mixed certainty - some problems clear, others need investigation
|
|
92
|
+
|
|
93
|
+
```typescript
|
|
94
|
+
// Phase 1: Investigate unclear areas
|
|
95
|
+
Task("Investigate root cause of database connection errors")
|
|
96
|
+
|
|
97
|
+
// Wait for result...
|
|
98
|
+
|
|
99
|
+
// Phase 2: Based on findings, dispatch parallel fixes
|
|
100
|
+
Task("Fix connection pool exhaustion in auth service")
|
|
101
|
+
Task("Fix timeout handling in payment service")
|
|
102
|
+
Task("Fix retry logic in notification service")
|
|
103
|
+
```
|
|
104
|
+
|
|
105
|
+
**Advantages:**
|
|
106
|
+
- Reduces risk of false independence
|
|
107
|
+
- Adapts to discoveries
|
|
108
|
+
- Maintains parallelization where safe
|
|
109
|
+
|
|
110
|
+
**Disadvantages:**
|
|
111
|
+
- Slower than pure parallel
|
|
112
|
+
- Requires decision point between phases
|
|
113
|
+
|
|
114
|
+
### Strategy 3: Hierarchical Dispatch
|
|
115
|
+
|
|
116
|
+
**Best for:** Large-scale problems with clear subsystem boundaries
|
|
117
|
+
|
|
118
|
+
```typescript
|
|
119
|
+
// Level 1: Subsystem leads
|
|
120
|
+
Task("Auth subsystem: Investigate and delegate 5 test failures")
|
|
121
|
+
Task("Payments subsystem: Investigate and delegate 4 test failures")
|
|
122
|
+
|
|
123
|
+
// Level 2: Each subsystem agent dispatches focused tasks
|
|
124
|
+
// Auth agent creates:
|
|
125
|
+
Task("Fix OAuth token refresh logic")
|
|
126
|
+
Task("Fix session timeout handling")
|
|
127
|
+
|
|
128
|
+
// Payments agent creates:
|
|
129
|
+
Task("Fix Stripe webhook handling")
|
|
130
|
+
Task("Fix refund processing")
|
|
131
|
+
```
|
|
132
|
+
|
|
133
|
+
**Advantages:**
|
|
134
|
+
- Scales to large problem sets
|
|
135
|
+
- Domain experts coordinate sub-tasks
|
|
136
|
+
- Natural verification points
|
|
137
|
+
|
|
138
|
+
**Disadvantages:**
|
|
139
|
+
- Higher coordination overhead
|
|
140
|
+
- More complex integration
|
|
141
|
+
- Requires clear subsystem boundaries
|
|
142
|
+
|
|
143
|
+
## Integration Workflows
|
|
144
|
+
|
|
145
|
+
### Integration Pattern 1: Summary Review
|
|
146
|
+
|
|
147
|
+
**When agents return:**
|
|
148
|
+
|
|
149
|
+
1. **Read all summaries first**
|
|
150
|
+
- Don't look at code yet
|
|
151
|
+
- Understand what each agent did
|
|
152
|
+
- Identify potential conflicts
|
|
153
|
+
|
|
154
|
+
2. **Check for overlaps**
|
|
155
|
+
- Did multiple agents edit same files?
|
|
156
|
+
- Did one agent's fix depend on another's?
|
|
157
|
+
- Are there conflicting approaches?
|
|
158
|
+
|
|
159
|
+
3. **Verify independently**
|
|
160
|
+
- Run each agent's tests in isolation
|
|
161
|
+
- Confirm each fix works alone
|
|
162
|
+
- Check no new failures introduced
|
|
163
|
+
|
|
164
|
+
4. **Integrate progressively**
|
|
165
|
+
- Merge one agent's work at a time
|
|
166
|
+
- Run full suite after each merge
|
|
167
|
+
- Isolate which merge causes conflicts
|
|
168
|
+
|
|
169
|
+
### Integration Pattern 2: Conflict Resolution
|
|
170
|
+
|
|
171
|
+
**When conflicts arise:**
|
|
172
|
+
|
|
173
|
+
```
|
|
174
|
+
Agent A changed: auth.service.ts (lines 50-60)
|
|
175
|
+
Agent B changed: auth.service.ts (lines 55-65)
|
|
176
|
+
→ Overlap detected!
|
|
177
|
+
|
|
178
|
+
Resolution steps:
|
|
179
|
+
1. Understand both changes - why did each agent change this?
|
|
180
|
+
2. Check if both changes needed - or is one redundant?
|
|
181
|
+
3. Determine merge strategy:
|
|
182
|
+
a) One change supersedes other
|
|
183
|
+
b) Both changes needed, manual merge
|
|
184
|
+
c) Neither optimal, new solution needed
|
|
185
|
+
4. Verify merged version passes both agents' tests
|
|
186
|
+
```
|
|
187
|
+
|
|
188
|
+
### Integration Pattern 3: Full Suite Verification
|
|
189
|
+
|
|
190
|
+
**After integration:**
|
|
191
|
+
|
|
192
|
+
```bash
|
|
193
|
+
# Run complete test suite
|
|
194
|
+
npm test
|
|
195
|
+
|
|
196
|
+
# Check for unexpected failures
|
|
197
|
+
# - Tests that weren't part of any agent's scope
|
|
198
|
+
# - Integration points between fixed domains
|
|
199
|
+
# - System-level behavior
|
|
200
|
+
|
|
201
|
+
# If new failures:
|
|
202
|
+
# 1. Identify which agent's changes caused it
|
|
203
|
+
# 2. Understand why (missing integration consideration?)
|
|
204
|
+
# 3. Fix with minimal change
|
|
205
|
+
# 4. Re-verify
|
|
206
|
+
```
|
|
207
|
+
|
|
208
|
+
## Scope Management
|
|
209
|
+
|
|
210
|
+
### Clear Scope Definition
|
|
211
|
+
|
|
212
|
+
**Good scope definition:**
|
|
213
|
+
```markdown
|
|
214
|
+
Agent scope: Fix all failures in src/auth/login.test.ts
|
|
215
|
+
|
|
216
|
+
Allowed to change:
|
|
217
|
+
- src/auth/login.service.ts
|
|
218
|
+
- src/auth/login.controller.ts
|
|
219
|
+
- Test file itself (if testing wrong behavior)
|
|
220
|
+
|
|
221
|
+
NOT allowed to change:
|
|
222
|
+
- Other auth modules
|
|
223
|
+
- Shared utilities (without consultation)
|
|
224
|
+
- Database schema
|
|
225
|
+
- API contracts (breaking changes)
|
|
226
|
+
|
|
227
|
+
Expected output:
|
|
228
|
+
- Summary of root cause
|
|
229
|
+
- List of files changed
|
|
230
|
+
- Explanation of fix approach
|
|
231
|
+
- Confirmation all 3 tests now pass
|
|
232
|
+
```
|
|
233
|
+
|
|
234
|
+
**Bad scope definition:**
|
|
235
|
+
```markdown
|
|
236
|
+
❌ "Fix the auth issues"
|
|
237
|
+
→ Too vague, agent doesn't know where to focus
|
|
238
|
+
|
|
239
|
+
❌ "Make all tests pass"
|
|
240
|
+
→ Too broad, agent will change anything
|
|
241
|
+
|
|
242
|
+
❌ "Fix login.test.ts but use your judgment"
|
|
243
|
+
→ Unclear constraints, unpredictable changes
|
|
244
|
+
```
|
|
245
|
+
|
|
246
|
+
### Scope Boundaries
|
|
247
|
+
|
|
248
|
+
**Enforce clear boundaries:**
|
|
249
|
+
|
|
250
|
+
```
|
|
251
|
+
Agent A domain: Authentication flow
|
|
252
|
+
├── login.service.ts
|
|
253
|
+
├── logout.service.ts
|
|
254
|
+
├── session.manager.ts
|
|
255
|
+
└── auth.test.ts
|
|
256
|
+
|
|
257
|
+
Agent B domain: User profile
|
|
258
|
+
├── profile.service.ts
|
|
259
|
+
├── profile.controller.ts
|
|
260
|
+
└── profile.test.ts
|
|
261
|
+
|
|
262
|
+
Shared boundary (coordination needed):
|
|
263
|
+
└── user.model.ts (both agents might need to modify)
|
|
264
|
+
→ Solution: Neither agent changes it without asking
|
|
265
|
+
→ Or: Designate one agent as owner
|
|
266
|
+
```
|
|
267
|
+
|
|
268
|
+
## Communication Patterns
|
|
269
|
+
|
|
270
|
+
### Agent-to-Coordinator Communication
|
|
271
|
+
|
|
272
|
+
**What agents should report:**
|
|
273
|
+
|
|
274
|
+
```markdown
|
|
275
|
+
# Agent Return Template
|
|
276
|
+
|
|
277
|
+
## Domain
|
|
278
|
+
Which test file / subsystem I worked on
|
|
279
|
+
|
|
280
|
+
## Root Cause
|
|
281
|
+
What was actually broken (not symptoms)
|
|
282
|
+
|
|
283
|
+
## Changes Made
|
|
284
|
+
- File A: Modified lines 50-60 to fix X
|
|
285
|
+
- File B: Added validation for Y
|
|
286
|
+
- Test file: Adjusted expectations for Z
|
|
287
|
+
|
|
288
|
+
## Verification
|
|
289
|
+
All 3 tests in my scope now pass:
|
|
290
|
+
✓ Test 1: login with valid credentials
|
|
291
|
+
✓ Test 2: login with invalid credentials
|
|
292
|
+
✓ Test 3: login with expired session
|
|
293
|
+
|
|
294
|
+
## Dependencies Discovered
|
|
295
|
+
None - my changes are isolated
|
|
296
|
+
|
|
297
|
+
## Risks
|
|
298
|
+
Watch for: Session timeout edge cases in other tests
|
|
299
|
+
```
|
|
300
|
+
|
|
301
|
+
### Coordinator-to-Agent Communication
|
|
302
|
+
|
|
303
|
+
**Clear task assignment:**
|
|
304
|
+
|
|
305
|
+
```markdown
|
|
306
|
+
# Task for Agent
|
|
307
|
+
|
|
308
|
+
## Your Scope
|
|
309
|
+
Fix 3 failures in src/auth/login.test.ts:
|
|
310
|
+
1. "should handle expired sessions" - throws TypeError
|
|
311
|
+
2. "should refresh tokens" - token undefined
|
|
312
|
+
3. "should logout on invalid token" - logout not called
|
|
313
|
+
|
|
314
|
+
## Context
|
|
315
|
+
These started failing after we upgraded auth library v2→v3
|
|
316
|
+
Library changed: TokenService API now async
|
|
317
|
+
|
|
318
|
+
## Constraints
|
|
319
|
+
- Fix the implementation or tests (your judgment)
|
|
320
|
+
- Don't change other auth files unless necessary
|
|
321
|
+
- Don't modify TokenService (external library)
|
|
322
|
+
|
|
323
|
+
## Expected Output
|
|
324
|
+
- Root cause explanation
|
|
325
|
+
- List of changes
|
|
326
|
+
- Confirmation tests pass
|
|
327
|
+
```
|
|
328
|
+
|
|
329
|
+
## Performance Optimization
|
|
330
|
+
|
|
331
|
+
### Minimizing Coordination Overhead
|
|
332
|
+
|
|
333
|
+
**Trade-off analysis:**
|
|
334
|
+
|
|
335
|
+
```
|
|
336
|
+
1 problem: Sequential (no parallelization benefit)
|
|
337
|
+
2 problems: Marginal benefit (coordination overhead ≈ parallelization gain)
|
|
338
|
+
3 problems: Clear benefit (coordination < parallelization gain)
|
|
339
|
+
5+ problems: High benefit (scales well)
|
|
340
|
+
|
|
341
|
+
Exception: Very quick fixes (<5 min each)
|
|
342
|
+
→ Sequential might be faster due to low task-switching cost
|
|
343
|
+
```
|
|
344
|
+
|
|
345
|
+
### Optimal Agent Count
|
|
346
|
+
|
|
347
|
+
```
|
|
348
|
+
Problems: 3-5 → Agents: 3-5 (1:1 mapping)
|
|
349
|
+
Problems: 6-10 → Agents: 4-6 (group related problems)
|
|
350
|
+
Problems: 10+ → Agents: 5-8 (hierarchical dispatch)
|
|
351
|
+
|
|
352
|
+
Maximum: ~8 agents (human coordination limit)
|
|
353
|
+
→ Beyond 8: Use hierarchical pattern
|
|
354
|
+
```
|
|
355
|
+
|
|
356
|
+
## Advanced Patterns
|
|
357
|
+
|
|
358
|
+
### Pattern: Dependency-Aware Dispatch
|
|
359
|
+
|
|
360
|
+
**When problems have loose dependencies:**
|
|
361
|
+
|
|
362
|
+
```
|
|
363
|
+
Problem A: Must fix first (others depend on it)
|
|
364
|
+
Problems B, C, D: Independent once A is fixed
|
|
365
|
+
|
|
366
|
+
Dispatch strategy:
|
|
367
|
+
1. Agent 1 fixes A
|
|
368
|
+
2. After A complete, dispatch B, C, D in parallel
|
|
369
|
+
3. Integrate all together
|
|
370
|
+
```
|
|
371
|
+
|
|
372
|
+
### Pattern: Speculative Parallel
|
|
373
|
+
|
|
374
|
+
**When independence is likely but uncertain:**
|
|
375
|
+
|
|
376
|
+
```
|
|
377
|
+
Dispatch all agents in parallel BUT:
|
|
378
|
+
- Each agent starts with investigation phase
|
|
379
|
+
- Agents report if they find shared dependencies
|
|
380
|
+
- Coordinator halts others if one finds systemic issue
|
|
381
|
+
|
|
382
|
+
Example:
|
|
383
|
+
3 agents start investigating 3 test files
|
|
384
|
+
Agent 1 discovers: "All failures due to config loading bug"
|
|
385
|
+
→ Coordinator halts Agent 2 & 3
|
|
386
|
+
→ Agent 1 fixes config bug
|
|
387
|
+
→ All tests pass
|
|
388
|
+
```
|
|
389
|
+
|
|
390
|
+
### Pattern: Progressive Integration
|
|
391
|
+
|
|
392
|
+
**For large-scale parallel work:**
|
|
393
|
+
|
|
394
|
+
```
|
|
395
|
+
8 agents working on different subsystems
|
|
396
|
+
|
|
397
|
+
Integration phases:
|
|
398
|
+
1. Integrate auth agents (A1, A2) → Verify auth suite
|
|
399
|
+
2. Integrate payment agents (P1, P2) → Verify payment suite
|
|
400
|
+
3. Integrate all auth + payments → Verify integration
|
|
401
|
+
4. Continue with notifications, etc.
|
|
402
|
+
|
|
403
|
+
Benefit: Catch conflicts early, smaller integration surface
|
|
404
|
+
```
|
|
405
|
+
|
|
406
|
+
## Common Mistakes
|
|
407
|
+
|
|
408
|
+
### Mistake 1: Premature Parallelization
|
|
409
|
+
|
|
410
|
+
```
|
|
411
|
+
❌ 5 test failures, immediately dispatch 5 agents
|
|
412
|
+
✓ Read all 5 failures, identify if root cause is shared
|
|
413
|
+
→ Shared: 1 agent fixes root cause
|
|
414
|
+
→ Independent: Dispatch in parallel
|
|
415
|
+
```
|
|
416
|
+
|
|
417
|
+
### Mistake 2: Ignoring Soft Dependencies
|
|
418
|
+
|
|
419
|
+
```
|
|
420
|
+
❌ "Files are separate, must be independent"
|
|
421
|
+
✓ Check runtime dependencies:
|
|
422
|
+
- Shared database state
|
|
423
|
+
- Service initialization order
|
|
424
|
+
- Global configuration
|
|
425
|
+
- Shared caches/singletons
|
|
426
|
+
```
|
|
427
|
+
|
|
428
|
+
### Mistake 3: No Integration Plan
|
|
429
|
+
|
|
430
|
+
```
|
|
431
|
+
❌ Dispatch agents, merge all changes at once, run tests
|
|
432
|
+
✓ Plan integration:
|
|
433
|
+
- Which order to merge?
|
|
434
|
+
- How to verify each step?
|
|
435
|
+
- What to do if conflicts arise?
|
|
436
|
+
```
|
|
437
|
+
|
|
438
|
+
### Mistake 4: Vague Boundaries
|
|
439
|
+
|
|
440
|
+
```
|
|
441
|
+
❌ "Fix auth stuff" + "Fix user stuff"
|
|
442
|
+
→ Overlap potential: What is "auth" vs "user"?
|
|
443
|
+
|
|
444
|
+
✓ "Fix login.test.ts" + "Fix profile.test.ts"
|
|
445
|
+
→ Clear file-based boundary
|
|
446
|
+
```
|
|
447
|
+
|
|
448
|
+
## Verification Checklist
|
|
449
|
+
|
|
450
|
+
Before dispatching:
|
|
451
|
+
- [ ] Verified problems are truly independent
|
|
452
|
+
- [ ] Defined clear scope for each agent
|
|
453
|
+
- [ ] Identified shared boundaries / risks
|
|
454
|
+
- [ ] Planned integration approach
|
|
455
|
+
- [ ] Estimated if parallelization worth overhead
|
|
456
|
+
|
|
457
|
+
During execution:
|
|
458
|
+
- [ ] Monitoring for agents reporting dependencies
|
|
459
|
+
- [ ] Ready to halt if systemic issue found
|
|
460
|
+
- [ ] Tracking which agent is working on what
|
|
461
|
+
|
|
462
|
+
After completion:
|
|
463
|
+
- [ ] Read all summaries before integrating
|
|
464
|
+
- [ ] Checked for file/scope overlaps
|
|
465
|
+
- [ ] Verified each fix in isolation
|
|
466
|
+
- [ ] Progressive integration with verification
|
|
467
|
+
- [ ] Full suite pass with all changes
|