跳转到主要内容

任务管理全流程

6.1 任务生命周期

create → init-context → add-context → start → implement/check → finish → archive
  │           │              │           │          │               │         │
  │           │              │           │          │               │         │
  ▼           ▼              ▼           ▼          ▼               ▼         ▼
创建目录    初始化JSONL   添加上下文    设为当前     开发/检查      清除当前   归档到
task.json   配置文件      条目         任务指针     循环           任务      archive/

6.2 task.py 14 个子命令详解

任务创建

# 创建任务
TASK_DIR=$(./.trellis/scripts/task.py create "添加用户登录" \
  --slug user-login \          # 目录名后缀 (可选,否则自动 slugify)
  --assignee alice \           # 指派人 (可选)
  --priority P1 \              # 优先级: P0/P1/P2/P3 (可选,默认 P2)
  --description "实现JWT登录")  # 描述 (可选)

# 创建的目录: .trellis/tasks/02-27-user-login/
# 创建的文件: task.json

上下文配置

# 初始化 JSONL 配置
./.trellis/scripts/task.py init-context "$TASK_DIR" backend
# dev_type: backend | frontend | fullstack | test | docs
# 可选: --platform cursor (默认 claude)

# 添加额外上下文条目
./.trellis/scripts/task.py add-context "$TASK_DIR" implement \
  "src/services/auth.ts" "Existing auth patterns"
# 目标: implement | check | debug (简写,自动加 .jsonl)
# 会自动检测是文件还是目录

# 验证所有 JSONL 引用的文件是否存在
./.trellis/scripts/task.py validate "$TASK_DIR"

# 查看所有 JSONL 条目
./.trellis/scripts/task.py list-context "$TASK_DIR"

任务控制

# 设为当前任务(Hook 会读取此指针进行注入)
./.trellis/scripts/task.py start "$TASK_DIR"

# 清除当前任务(无需参数,自动读取 .current-task)
./.trellis/scripts/task.py finish

# 设置 Git 分支名
./.trellis/scripts/task.py set-branch "$TASK_DIR" "feature/user-login"

# 设置 PR 目标分支
./.trellis/scripts/task.py set-base-branch "$TASK_DIR" "main"

# 设置 scope(用于 commit message: feat(scope): ...)
./.trellis/scripts/task.py set-scope "$TASK_DIR" "auth"

任务管理

# 列出活跃任务
./.trellis/scripts/task.py list
./.trellis/scripts/task.py list --mine        # 只看自己的
./.trellis/scripts/task.py list --status review  # 按状态过滤

# 归档完成的任务
./.trellis/scripts/task.py archive user-login
# 移动到 archive/2026-02/

# 列出归档任务
./.trellis/scripts/task.py list-archive
./.trellis/scripts/task.py list-archive 2026-02  # 按月过滤

# 创建 PR(委托给 multi-agent/create-pr.py)
./.trellis/scripts/task.py create-pr

6.3 task.json Schema

{
  "id": "02-27-user-login",
  "name": "user-login",
  "title": "添加用户登录",
  "description": "实现 JWT 登录流程",
  "status": "in_progress",
  "dev_type": "backend",
  "scope": "auth",
  "priority": "P1",
  "creator": "alice",
  "assignee": "alice",
  "createdAt": "2026-02-27T10:00:00Z",
  "completedAt": null,
  "branch": "feature/user-login",
  "base_branch": "main",
  "worktree_path": null,
  "current_phase": 1,
  "next_action": [
    { "phase": 1, "action": "implement" },
    { "phase": 2, "action": "check" },
    { "phase": 3, "action": "finish" },
    { "phase": 4, "action": "create-pr" }
  ],
  "commit": null,
  "pr_url": null,
  "subtasks": [],
  "relatedFiles": [],
  "notes": ""
}
状态流转
planning → in_progress → review → completed
       ↘ rejected

6.4 JSONL 上下文配置实战

自动生成的默认配置

task.py init-context 会根据 dev_type 生成默认的 JSONL 文件: backend 类型默认 implement.jsonl
{"file": ".trellis/workflow.md", "reason": "Project workflow and conventions"}
{"file": ".trellis/spec/shared/index.md", "reason": "Shared coding standards"}
{"file": ".trellis/spec/backend/index.md", "reason": "Backend development guide"}
{"file": ".trellis/spec/backend/api-module.md", "reason": "API module conventions"}
{"file": ".trellis/spec/backend/quality.md", "reason": "Code quality requirements"}
backend 类型默认 check.jsonl(Claude Code 平台):
{"file": ".claude/commands/trellis/finish-work.md", "reason": "Finish work checklist"}
{"file": ".trellis/spec/shared/index.md", "reason": "Shared coding standards"}
{"file": ".claude/commands/trellis/check-backend.md", "reason": "Backend check spec"}
fullstack 类型会同时包含前端和后端的 spec 文件。

添加自定义上下文

# 添加现有代码作为参考(文件)
./.trellis/scripts/task.py add-context "$TASK_DIR" implement \
  "src/services/user.ts" "Existing user service patterns"

# 添加整个目录(自动读取所有 .md 文件)
./.trellis/scripts/task.py add-context "$TASK_DIR" implement \
  "src/services/" "Existing service patterns"

# 添加自定义 check 上下文
./.trellis/scripts/task.py add-context "$TASK_DIR" check \
  ".trellis/spec/guides/cross-layer-thinking-guide.md" "Cross-layer verification"

6.5 Plan Agent 与需求评估

Plan Agent 在接受需求前会进行严格评估,可能会拒绝。 5 类拒绝原因
拒绝类型触发条件示例
Unclear or Vague没有具体结果定义”Make it better”、“Fix the bugs”
Incomplete Information缺少关键实现细节引用了未知系统
Out of Scope不属于本项目需要修改外部系统
Potentially Harmful安全风险故意开后门
Too Large应该拆分一次要做 6 个功能
拒绝时
  • task.json 状态设为 "rejected"
  • 生成 REJECTED.md 包含原因和改进建议
  • 任务目录保留供用户查看
拒绝示例
Input: "Add user authentication, authorization, password reset,
        2FA, OAuth integration, and audit logging"

=== PLAN REJECTED ===

Reason: Too Large / Should Be Split

Details:
This requirement bundles 6 distinct features:
1. User authentication (login/logout)
2. Authorization (roles/permissions)
3. Password reset flow
4. Two-factor authentication
5. OAuth integration
6. Audit logging

Suggestions:
- Start with basic authentication first
- Create separate features for each capability

6.6 任务生命周期 Hooks

你可以配置在任务生命周期事件发生时自动执行的 shell 命令。适用于同步任务到 Linear、发送 Slack 通知、触发 CI 流水线等场景。

配置方式

.trellis/config.yaml 中添加 hooks 块:
hooks:
  after_create:
    - 'python3 .trellis/scripts/hooks/linear_sync.py create'
  after_start:
    - 'python3 .trellis/scripts/hooks/linear_sync.py start'
  after_finish:
    - "echo 'Task finished'"
  after_archive:
    - 'python3 .trellis/scripts/hooks/linear_sync.py archive'
默认的 config.yaml 中 hooks 部分是注释掉的。需要手动取消注释并编辑才能激活。

支持的事件

事件触发时机典型用途
after_createtask.py create 完成后在项目管理工具中创建关联 issue
after_starttask.py start 设置当前任务后更新 issue 状态为 “In Progress”
after_finishtask.py finish 清除当前任务后通知团队、触发评审
after_archivetask.py archive 归档任务后标记 issue 为 “Done”

环境变量

每个 Hook 都会收到:
变量
TASK_JSON_PATH任务 task.json 的绝对路径
父进程的所有其他环境变量也会被继承。

执行行为

  • 工作目录:仓库根目录
  • Shell:命令通过系统 shell 执行(shell=True
  • 失败不阻塞:Hook 失败会在 stderr 输出 [WARN],但不会阻止任务操作完成
  • 顺序执行:同一事件的多个 Hook 按列表顺序执行;某个失败不会跳过后续 Hook
  • stdout 被捕获:Hook 的 stdout 不会显示给用户 — 诊断信息请输出到 stderr
after_archive Hook 收到的 TASK_JSON_PATH 指向的是归档后的位置(如 .trellis/tasks/archive/2026-03/task-name/task.json),不是原始路径。

示例:Linear 同步 Hook

Trellis 内置了一个示例 Hook 脚本 .trellis/scripts/hooks/linear_sync.py,可将任务生命周期事件同步到 Linear 功能说明
动作触发事件效果
createafter_create从 task.json 创建 Linear issue(标题、优先级、指派人、父任务)
startafter_start更新关联 issue 状态为 “In Progress”
archiveafter_archive更新关联 issue 状态为 “Done”
sync手动调用prd.md 内容推送到 Linear issue 描述
前置条件
  1. 安装 linearis CLI 并设置 LINEAR_API_KEY
  2. 创建 .trellis/hooks.local.json(已被 gitignore)并填入团队配置:
{
  "linear": {
    "team": "ENG",
    "project": "My Project",
    "assignees": {
      "alice": "linear-user-id-for-alice"
    }
  }
}
Hook 会将 Linear issue 标识符写回 task.jsonmeta.linear_issue 字段(如 "ENG-123"),确保后续事件幂等。