mirror of
https://github.com/catlog22/Claude-Code-Workflow.git
synced 2026-03-10 17:11:04 +08:00
- Implement tests for AssociationHighlight, DashboardToolbar, QueuePanel, SessionGroupTree, and TerminalDashboardPage to ensure proper functionality and state management. - Create tests for cliSessionStore, issueQueueIntegrationStore, queueExecutionStore, queueSchedulerStore, sessionManagerStore, and terminalGridStore to validate state resets and workspace scoping. - Mock necessary dependencies and state management hooks to isolate tests and ensure accurate behavior.
207 lines
9.0 KiB
Markdown
207 lines
9.0 KiB
Markdown
# Team PlanEx -- CSV Schema
|
|
|
|
## Master CSV: tasks.csv
|
|
|
|
### Column Definitions
|
|
|
|
#### Input Columns (Set by Decomposer)
|
|
|
|
| Column | Type | Required | Description | Example |
|
|
|--------|------|----------|-------------|---------|
|
|
| `id` | string | Yes | Unique task identifier | `"PLAN-001"` |
|
|
| `title` | string | Yes | Short task title | `"Plan ISS-20260308-120000"` |
|
|
| `description` | string | Yes | Detailed task description (self-contained) | `"Generate implementation solution for issue ISS-20260308-120000"` |
|
|
| `role` | enum | Yes | Worker role: `planner` or `executor` | `"planner"` |
|
|
| `issue_ids` | string | Yes | Semicolon-separated issue IDs | `"ISS-20260308-120000"` |
|
|
| `input_type` | string | No | Input source type (planner only): `issues`, `text`, or `plan` | `"issues"` |
|
|
| `raw_input` | string | No | Raw input text (planner only) | `"ISS-20260308-120000"` |
|
|
| `exec_mode` | enum | Yes | Execution mechanism: `csv-wave` or `interactive` | `"csv-wave"` |
|
|
| `execution_method` | string | No | CLI tool for EXEC tasks: codex, gemini, qwen, or empty | `"gemini"` |
|
|
| `deps` | string | No | Semicolon-separated dependency task IDs | `"PLAN-001"` |
|
|
| `context_from` | string | No | Semicolon-separated task IDs for context | `"PLAN-001"` |
|
|
|
|
#### Computed Columns (Set by Wave Engine)
|
|
|
|
| Column | Type | Description | Example |
|
|
|--------|------|-------------|---------|
|
|
| `wave` | integer | Wave number (1-based, from topological sort) | `2` |
|
|
| `prev_context` | string | Aggregated findings from context_from tasks (per-wave CSV only) | `"[PLAN-001] Designed 4-task solution..."` |
|
|
|
|
#### Output Columns (Set by Agent)
|
|
|
|
| Column | Type | Description | Example |
|
|
|--------|------|-------------|---------|
|
|
| `status` | enum | `pending` -> `completed` / `failed` / `skipped` | `"completed"` |
|
|
| `findings` | string | Key discoveries (max 500 chars) | `"Solution designed with 4 implementation tasks..."` |
|
|
| `artifact_path` | string | Path to generated artifact file | `"artifacts/solutions/ISS-20260308-120000.json"` |
|
|
| `error` | string | Error message if failed | `""` |
|
|
|
|
---
|
|
|
|
### exec_mode Values
|
|
|
|
| Value | Mechanism | Description |
|
|
|-------|-----------|-------------|
|
|
| `csv-wave` | `spawn_agents_on_csv` | One-shot batch execution within wave |
|
|
| `interactive` | `spawn_agent`/`wait`/`send_input`/`close_agent` | Multi-round individual execution (edge cases) |
|
|
|
|
> In standard PlanEx, all tasks use `csv-wave`. Interactive mode is reserved for rare multi-round coordination scenarios.
|
|
|
|
---
|
|
|
|
### Role Values
|
|
|
|
| Role | Task Prefixes | Responsibility |
|
|
|------|---------------|----------------|
|
|
| `planner` | PLAN-* | Requirement decomposition, solution design, issue creation |
|
|
| `executor` | EXEC-* | Solution implementation, testing, verification, commit |
|
|
|
|
---
|
|
|
|
### Example Data
|
|
|
|
```csv
|
|
id,title,description,role,issue_ids,input_type,raw_input,exec_mode,execution_method,deps,context_from,wave,status,findings,artifact_path,error
|
|
"PLAN-001","Plan issue-1","Generate solution for ISS-20260308-120000","planner","ISS-20260308-120000","issues","ISS-20260308-120000","csv-wave","","","","1","pending","","",""
|
|
"PLAN-002","Plan issue-2","Generate solution for ISS-20260308-120001","planner","ISS-20260308-120001","issues","ISS-20260308-120001","csv-wave","","","","1","pending","","",""
|
|
"EXEC-001","Implement issue-1","Implement solution for ISS-20260308-120000","executor","ISS-20260308-120000","","","csv-wave","gemini","PLAN-001","PLAN-001","2","pending","","",""
|
|
"EXEC-002","Implement issue-2","Implement solution for ISS-20260308-120001","executor","ISS-20260308-120001","","","csv-wave","gemini","PLAN-002","PLAN-002","2","pending","","",""
|
|
```
|
|
|
|
---
|
|
|
|
### Column Lifecycle
|
|
|
|
```
|
|
Decomposer (Phase 1) Wave Engine (Phase 2) Agent (Execution)
|
|
--------------------- -------------------- -----------------
|
|
id ----------> id ----------> id
|
|
title ----------> title ----------> (reads)
|
|
description ----------> description ----------> (reads)
|
|
role ----------> role ----------> (reads)
|
|
issue_ids ----------> issue_ids ----------> (reads)
|
|
input_type ----------> input_type ----------> (reads, planner)
|
|
raw_input ----------> raw_input ----------> (reads, planner)
|
|
exec_mode ----------> exec_mode ----------> (reads)
|
|
execution_method ------> execution_method -----> (reads, executor)
|
|
deps ----------> deps ----------> (reads)
|
|
context_from----------> context_from----------> (reads)
|
|
wave ----------> (reads)
|
|
prev_context ----------> (reads)
|
|
status
|
|
findings
|
|
artifact_path
|
|
error
|
|
```
|
|
|
|
---
|
|
|
|
## Output Schema (JSON)
|
|
|
|
Agent output via `report_agent_job_result` (csv-wave tasks):
|
|
|
|
```json
|
|
{
|
|
"id": "PLAN-001",
|
|
"status": "completed",
|
|
"findings": "Designed solution for ISS-20260308-120000: 4 implementation tasks, 6 files affected. Approach: refactor authentication handler to support token refresh.",
|
|
"artifact_path": "artifacts/solutions/ISS-20260308-120000.json",
|
|
"error": ""
|
|
}
|
|
```
|
|
|
|
---
|
|
|
|
## Discovery Types
|
|
|
|
| Type | Dedup Key | Data Schema | Description |
|
|
|------|-----------|-------------|-------------|
|
|
| `solution_designed` | `issue_id` | `{issue_id, approach, task_count, estimated_files}` | Planner: solution plan completed |
|
|
| `conflict_warning` | `issue_ids` | `{issue_ids, overlapping_files}` | Planner: file overlap between issues |
|
|
| `pattern_found` | `pattern+location` | `{pattern, location, description}` | Any: code pattern identified |
|
|
| `impl_result` | `issue_id` | `{issue_id, files_changed, tests_pass, commit}` | Executor: implementation outcome |
|
|
| `test_failure` | `issue_id` | `{issue_id, test_file, error_msg}` | Executor: test failure details |
|
|
|
|
### Discovery NDJSON Format
|
|
|
|
```jsonl
|
|
{"ts":"2026-03-08T10:00:00Z","worker":"PLAN-001","type":"solution_designed","data":{"issue_id":"ISS-20260308-120000","approach":"refactor","task_count":4,"estimated_files":6}}
|
|
{"ts":"2026-03-08T10:05:00Z","worker":"PLAN-002","type":"conflict_warning","data":{"issue_ids":["ISS-20260308-120000","ISS-20260308-120001"],"overlapping_files":["src/auth/handler.ts"]}}
|
|
{"ts":"2026-03-08T10:10:00Z","worker":"EXEC-001","type":"impl_result","data":{"issue_id":"ISS-20260308-120000","files_changed":3,"tests_pass":true,"commit":"abc123"}}
|
|
```
|
|
|
|
> All agents (planner and executor) read/write the same discoveries.ndjson file.
|
|
|
|
---
|
|
|
|
## Cross-Wave Context Flow
|
|
|
|
| Source | Target | Mechanism |
|
|
|--------|--------|-----------|
|
|
| PLAN-N findings | EXEC-N prev_context | Injected via prev_context column in wave-2.csv |
|
|
| PLAN-N artifact_path | EXEC-N | Executor reads solution file from artifact_path |
|
|
| Any agent discovery | Any agent | Shared via discoveries.ndjson |
|
|
|
|
---
|
|
|
|
## Pipeline Structure
|
|
|
|
### Standard Two-Wave Pipeline
|
|
|
|
| Wave | Tasks | Role | Parallelism |
|
|
|------|-------|------|-------------|
|
|
| 1 | PLAN-001..N | planner | All concurrent (up to max_concurrency) |
|
|
| 2 | EXEC-001..N | executor | All concurrent (up to max_concurrency) |
|
|
|
|
Each EXEC-NNN depends on its corresponding PLAN-NNN. If PLAN-NNN fails, EXEC-NNN is automatically skipped.
|
|
|
|
---
|
|
|
|
## Solution Artifact Schema
|
|
|
|
Written by planner agents to `artifacts/solutions/{issueId}.json`:
|
|
|
|
```json
|
|
{
|
|
"session_id": "planex-xxx-20260308",
|
|
"issue_id": "ISS-20260308-120000",
|
|
"solution": {
|
|
"title": "Add rate limiting middleware",
|
|
"approach": "Create express middleware with sliding window",
|
|
"tasks": [
|
|
{
|
|
"order": 1,
|
|
"description": "Create rate limiter middleware in src/middleware/rate-limit.ts",
|
|
"files_touched": ["src/middleware/rate-limit.ts"]
|
|
},
|
|
{
|
|
"order": 2,
|
|
"description": "Add per-route configuration in src/config/routes.ts",
|
|
"files_touched": ["src/config/routes.ts"]
|
|
}
|
|
],
|
|
"estimated_complexity": "Medium",
|
|
"estimated_files": 4
|
|
},
|
|
"planned_at": "2026-03-08T10:00:00Z"
|
|
}
|
|
```
|
|
|
|
---
|
|
|
|
## Validation Rules
|
|
|
|
| Rule | Check | Error |
|
|
|------|-------|-------|
|
|
| Unique IDs | No duplicate `id` values | "Duplicate task ID: {id}" |
|
|
| Valid deps | All dep IDs exist in tasks | "Unknown dependency: {dep_id}" |
|
|
| No self-deps | Task cannot depend on itself | "Self-dependency: {id}" |
|
|
| No circular deps | Topological sort completes | "Circular dependency detected involving: {ids}" |
|
|
| context_from valid | All context IDs exist and in earlier waves | "Invalid context_from: {id}" |
|
|
| exec_mode valid | Value is `csv-wave` or `interactive` | "Invalid exec_mode: {value}" |
|
|
| Role valid | Value in {planner, executor} | "Invalid role: {role}" |
|
|
| Description non-empty | Every task has description | "Empty description for task: {id}" |
|
|
| Status enum | status in {pending, completed, failed, skipped} | "Invalid status" |
|
|
| EXEC deps on PLAN | Every EXEC-N must depend on PLAN-N | "EXEC task without PLAN dependency: {id}" |
|
|
| Issue IDs non-empty | Every task has at least one issue_id | "No issue_ids for task: {id}" |
|