Refactor team collaboration skills and update documentation

- Renamed `team-lifecycle-v5` to `team-lifecycle` across various documentation files for consistency.
- Updated references in code examples and usage sections to reflect the new skill name.
- Added a new command file for the `monitor` functionality in the `team-iterdev` skill, detailing the coordinator's monitoring events and task management.
- Introduced new components for dynamic pipeline visualization and session coordinates display in the frontend.
- Implemented utility functions for pipeline stage detection and status derivation based on message history.
- Enhanced the team role panel to map members to their respective pipeline roles with status indicators.
- Updated Chinese documentation to reflect the changes in skill names and descriptions.
This commit is contained in:
catlog22
2026-03-04 11:07:48 +08:00
parent 5e96722c09
commit ffd5282932
132 changed files with 2938 additions and 18916 deletions

View File

@@ -1,164 +0,0 @@
# Command: evaluate
> CLI 分析评估债务项。对每项债务评估业务影响(1-5)、修复成本(1-5)、未修复风险,产出优先级象限分配。
## When to Use
- Phase 3 of Assessor
- 需要对债务清单中的项目进行量化评估
- 债务项数量较多需要 CLI 辅助分析
**Trigger conditions**:
- TDEVAL-* 任务进入 Phase 3
- 债务清单包含 >10 项需要评估的条目
- 需要上下文理解来评估影响和成本
## Strategy
### Delegation Mode
**Mode**: CLI Batch Analysis
**CLI Tool**: `gemini` (primary)
**CLI Mode**: `analysis`
### Decision Logic
```javascript
// 评估策略选择
if (debtInventory.length <= 10) {
// 少量项目:内联评估(基于严重性和工作量启发式)
mode = 'heuristic'
} else if (debtInventory.length <= 50) {
// 中等规模:单次 CLI 批量评估
mode = 'cli-batch'
} else {
// 大规模:分批 CLI 评估
mode = 'cli-chunked'
chunkSize = 25
}
```
## Execution Steps
### Step 1: Context Preparation
```javascript
// 准备评估上下文
const debtSummary = debtInventory.map(item =>
`[${item.id}] [${item.dimension}] [${item.severity}] ${item.file}:${item.line} - ${item.description}`
).join('\n')
// 读取项目元信息用于上下文
const projectContext = []
try {
const pkg = JSON.parse(Read('package.json'))
projectContext.push(`Project: ${pkg.name}, Dependencies: ${Object.keys(pkg.dependencies || {}).length}`)
} catch {}
```
### Step 2: Execute Strategy
```javascript
if (mode === 'heuristic') {
// 内联启发式评估
for (const item of debtInventory) {
const severityImpact = { critical: 5, high: 4, medium: 3, low: 1 }
const effortCost = { small: 1, medium: 3, large: 5 }
item.impact_score = severityImpact[item.severity] || 3
item.cost_score = effortCost[item.estimated_effort] || 3
item.risk_if_unfixed = getRiskDescription(item)
item.priority_quadrant = assignQuadrant(item.impact_score, item.cost_score)
}
} else {
// CLI 批量评估
const prompt = `PURPOSE: Evaluate technical debt items for business impact and fix cost to create a priority matrix
TASK: • For each debt item, assess business impact (1-5 scale: 1=negligible, 5=critical) • Assess fix complexity/cost (1-5 scale: 1=trivial, 5=major refactor) • Describe risk if unfixed • Assign priority quadrant: quick-win (high impact + low cost), strategic (high impact + high cost), backlog (low impact + low cost), defer (low impact + high cost)
MODE: analysis
CONTEXT: ${projectContext.join(' | ')}
EXPECTED: JSON array with: [{id, impact_score, cost_score, risk_if_unfixed, priority_quadrant}] for each item
CONSTRAINTS: Be realistic about costs, consider dependencies between items
## Debt Items to Evaluate
${debtSummary}`
Bash(`ccw cli -p "${prompt}" --tool gemini --mode analysis --rule analysis-analyze-code-patterns`, {
run_in_background: true
})
// 等待 CLI 完成,解析结果,合并回 debtInventory
}
function assignQuadrant(impact, cost) {
if (impact >= 4 && cost <= 2) return 'quick-win'
if (impact >= 4 && cost >= 3) return 'strategic'
if (impact <= 3 && cost <= 2) return 'backlog'
return 'defer'
}
function getRiskDescription(item) {
const risks = {
'code': 'Increased maintenance cost and bug probability',
'architecture': 'Growing coupling makes changes harder and riskier',
'testing': 'Reduced confidence in changes, higher regression risk',
'dependency': 'Security vulnerabilities and compatibility issues',
'documentation': 'Onboarding friction and knowledge loss'
}
return risks[item.dimension] || 'Technical quality degradation over time'
}
```
### Step 3: Result Processing
```javascript
// 验证评估结果完整性
const evaluated = debtInventory.filter(i => i.priority_quadrant)
const unevaluated = debtInventory.filter(i => !i.priority_quadrant)
if (unevaluated.length > 0) {
// 未评估的项目使用启发式兜底
for (const item of unevaluated) {
item.impact_score = item.impact_score || 3
item.cost_score = item.cost_score || 3
item.priority_quadrant = assignQuadrant(item.impact_score, item.cost_score)
item.risk_if_unfixed = item.risk_if_unfixed || getRiskDescription(item)
}
}
// 生成统计
const stats = {
total: debtInventory.length,
evaluated_by_cli: evaluated.length,
evaluated_by_heuristic: unevaluated.length,
avg_impact: (debtInventory.reduce((s, i) => s + i.impact_score, 0) / debtInventory.length).toFixed(1),
avg_cost: (debtInventory.reduce((s, i) => s + i.cost_score, 0) / debtInventory.length).toFixed(1)
}
```
## Output Format
```
## Evaluation Results
### Method: [heuristic|cli-batch|cli-chunked]
### Total Items: [count]
### Average Impact: [score]/5
### Average Cost: [score]/5
### Priority Distribution
| Quadrant | Count | % |
|----------|-------|---|
| Quick-Win | [n] | [%] |
| Strategic | [n] | [%] |
| Backlog | [n] | [%] |
| Defer | [n] | [%] |
```
## Error Handling
| Scenario | Resolution |
|----------|------------|
| CLI returns invalid JSON | Fall back to heuristic scoring |
| CLI timeout | Evaluate processed items, heuristic for rest |
| Debt inventory too large (>200) | Chunk into batches of 25 |
| Missing severity/effort data | Use dimension-based defaults |
| All items same quadrant | Re-evaluate with adjusted thresholds |

View File

@@ -1,185 +0,0 @@
# Assessor Role
技术债务量化评估师。对扫描发现的每项债务进行影响评分(1-5)和修复成本评分(1-5),划分优先级象限,生成 priority-matrix.json。
## Identity
- **Name**: `assessor` | **Tag**: `[assessor]`
- **Task Prefix**: `TDEVAL-*`
- **Responsibility**: Read-only analysis (量化评估)
## Boundaries
### MUST
- Only process `TDEVAL-*` prefixed tasks
- All output (SendMessage, team_msg, logs) must carry `[assessor]` identifier
- Only communicate with coordinator via SendMessage
- Work strictly within quantitative assessment responsibility scope
- Base evaluations on data from debt inventory
### MUST NOT
- Modify source code or test code
- Execute fix operations
- Create tasks for other roles
- Communicate directly with other worker roles (must go through coordinator)
- Omit `[assessor]` identifier in any output
---
## Toolbox
### Available Commands
| Command | File | Phase | Description |
|---------|------|-------|-------------|
| `evaluate` | [commands/evaluate.md](commands/evaluate.md) | Phase 3 | 影响/成本矩阵评估 |
### Tool Capabilities
| Tool | Type | Used By | Purpose |
|------|------|---------|---------|
| `gemini` | CLI | evaluate.md | 债务影响与修复成本评估 |
> Assessor does not directly use subagents
---
## Message Types
| Type | Direction | Trigger | Description |
|------|-----------|---------|-------------|
| `assessment_complete` | assessor -> coordinator | 评估完成 | 包含优先级矩阵摘要 |
| `error` | assessor -> coordinator | 评估失败 | 阻塞性错误 |
## Message Bus
Before every SendMessage, log via `mcp__ccw-tools__team_msg`:
```
mcp__ccw-tools__team_msg({
operation: "log",
session_id: <session-id>,
from: "assessor",
type: <message-type>,
ref: <artifact-path>
})
```
**CLI fallback** (when MCP unavailable):
```
Bash("ccw team log --session-id <session-id> --from assessor --type <message-type> --ref <artifact-path> --json")
```
---
## Execution (5-Phase)
### Phase 1: Task Discovery
> See SKILL.md Shared Infrastructure -> Worker Phase 1: Task Discovery
Standard task discovery flow: TaskList -> filter by prefix `TDEVAL-*` + owner match + pending + unblocked -> TaskGet -> TaskUpdate in_progress.
### Phase 2: Load Debt Inventory
| Input | Source | Required |
|-------|--------|----------|
| Session folder | task.description (regex: `session:\s*(.+)`) | Yes |
| Shared memory | `<session-folder>/.msg/meta.json` | Yes |
| Debt inventory | meta.json:debt_inventory OR `<session-folder>/scan/debt-inventory.json` | Yes |
**Loading steps**:
1. Extract session path from task description
2. Read .msg/meta.json
3. Load debt_inventory from shared memory or fallback to debt-inventory.json file
4. If debt_inventory is empty -> report empty assessment and exit
### Phase 3: Evaluate Each Item
Delegate to `commands/evaluate.md` if available, otherwise execute inline.
**Core Strategy**: For each debt item, evaluate impact(1-5) + cost(1-5) + priority quadrant
**Impact Score Mapping**:
| Severity | Impact Score |
|----------|--------------|
| critical | 5 |
| high | 4 |
| medium | 3 |
| low | 1 |
**Cost Score Mapping**:
| Estimated Effort | Cost Score |
|------------------|------------|
| small | 1 |
| medium | 3 |
| large | 5 |
| unknown | 3 |
**Priority Quadrant Classification**:
| Impact | Cost | Quadrant | Description |
|--------|------|----------|-------------|
| >= 4 | <= 2 | quick-win | High impact, low cost |
| >= 4 | >= 3 | strategic | High impact, high cost |
| <= 3 | <= 2 | backlog | Low impact, low cost |
| <= 3 | >= 3 | defer | Low impact, high cost |
**Evaluation record**:
| Field | Description |
|-------|-------------|
| `impact_score` | 1-5, business impact |
| `cost_score` | 1-5, fix effort |
| `risk_if_unfixed` | Risk description |
| `priority_quadrant` | quick-win/strategic/backlog/defer |
### Phase 4: Generate Priority Matrix
**Matrix structure**:
| Field | Description |
|-------|-------------|
| `evaluation_date` | ISO timestamp |
| `total_items` | Count of evaluated items |
| `by_quadrant` | Items grouped by quadrant |
| `summary` | Count per quadrant |
**Sorting**: Within each quadrant, sort by impact_score descending
**Save outputs**:
1. Write `<session-folder>/assessment/priority-matrix.json`
2. Update .msg/meta.json with `priority_matrix` summary and evaluated `debt_inventory`
### Phase 5: Report to Coordinator
> See SKILL.md Shared Infrastructure -> Worker Phase 5: Report
Standard report flow: team_msg log -> SendMessage with `[assessor]` prefix -> TaskUpdate completed -> Loop to Phase 1 for next task.
**Report content**:
| Field | Value |
|-------|-------|
| Task | task.subject |
| Total Items | Count of evaluated items |
| Priority Matrix | Count per quadrant |
| Top Quick-Wins | Top 5 quick-win items with details |
| Priority Matrix File | Path to priority-matrix.json |
---
## Error Handling
| Scenario | Resolution |
|----------|------------|
| No TDEVAL-* tasks available | Idle, wait for coordinator |
| Debt inventory empty | Report empty assessment, notify coordinator |
| Shared memory corrupted | Re-read from debt-inventory.json file |
| CLI analysis fails | Fall back to severity-based heuristic scoring |
| Too many items (>200) | Batch-evaluate top 50 critical/high first |