10 KiB
Implementation Roadmap
Purpose
This document is the handoff-oriented implementation plan for the project. It is intentionally short and execution-focused.
A new agent should be able to read this file, understand the current project state, and immediately know what to build next without re-deriving the whole design.
Current Status
As of now:
- architecture and workflow docs are written
- CLI surfaces for
inbox,orch, worktree execution, andcouncil-revieware defined - embedded SQLite schema and migrations exist in code
- JSON output shapes are defined for the major flows
- Go module and initial command skeletons exist
inboxandorchboth compile- shared SQLite schema initialization exists
inboxis implemented end-to-end, including send/fetch/claim/renew/update/reply/done/fail/cancel/list/show/watch/wait-replyinboxsupports blocking waits, lease renewal, unread fetches backed by per-agent read cursors,--body-file, artifact attachments, and structured JSON errors with stable exit codes- integration tests cover the main inbox lifecycle, wait/watch flows, artifact persistence, and JSON error contracts
- a human-readable inbox command test-plan set has not been authored yet
orchcurrently exists as a command skeleton only- no scheduler workflows have been implemented yet
This means the project is past design discovery and ready for orch implementation.
Source Of Truth
Read these docs first:
Use this roadmap for implementation order, not for protocol design.
Project Goal
Build a Go-based local agent orchestration stack with:
inbox: worker-facing durable coordination busorch: leader-facing scheduler and control plane- strict worktree-backed execution for code-writing task attempts
council-review: a user-facing three-reviewer brainstorm workflow implemented on top oforch
Implementation Principles
- Do not redesign the protocol unless implementation reveals a real contradiction.
- Keep
inboxandorchas separate CLIs or command groups, but share one SQLite file. - Prefer one small working path over broad unfinished scaffolding.
- Make JSON output stable early.
- Implement the happy path first, then add wait/retry/cleanup.
Recommended v1 Order
Progress Snapshot
Current implementation status:
Milestone 1: Go Skeletonis completeMilestone 2: Shared DB Layeris complete enough for both CLIsMilestone 3: Inbox Happy Pathis completeMilestone 6: Waiting Primitivesis partially complete throughinbox wait-reply
The next practical coding target is Milestone 4: Orch Core Scheduling.
Milestone 1: Go Skeleton
Goal:
- initialize the Go module
- choose CLI framework and SQLite driver
- create package layout
- make empty commands compile
Recommended shape:
cmd/inboxcmd/orchinternal/dbinternal/storeinternal/protocolinternal/cli
Definition of done:
go build ./...succeedsinbox --helpworksorch --helpworks
Status:
- completed
Milestone 2: Shared DB Layer
Goal:
- create the SQLite connection layer
- enable required pragmas
- add schema initialization and migration mechanism
Minimum scope:
- communication tables for
inbox - scheduling tables for
orch - shared
eventstable
Definition of done:
inbox initinitializes the databaseorchcan open the same database successfully
Status:
- completed for current inbox needs
Completed so far:
- shared DB open layer exists
- required SQLite pragmas are applied
- embedded schema files exist
inbox initapplies schema successfully
Remaining:
- decide whether
orchshould gain an explicit DB bootstrap check or continue to rely oninbox init
Milestone 3: Inbox Happy Path
Goal:
- implement worker-facing coordination primitives first
First commands:
inbox initinbox sendinbox fetchinbox claiminbox updateinbox replyinbox doneinbox failinbox show
Delay if needed:
watchwait-replycancellist
Definition of done:
- one thread can be created, claimed, updated, replied to, and completed
- all major commands support
--json
Status:
- completed
Completed so far:
inbox initinbox sendinbox fetchinbox claiminbox renewinbox updateinbox replyinbox doneinbox failinbox cancelinbox listinbox showinbox watchinbox wait-reply
Milestone 4: Orch Core Scheduling
Goal:
- implement run/task/dependency/attempt orchestration on top of
inbox
First commands:
orch run initorch task addorch dep addorch readyorch dispatchorch reconcileorch blockedorch answerorch status
Delay if needed:
retryreassigncancelcleanupwait
Definition of done:
- a leader can create a run
- add tasks and dependencies
- dispatch a task through
orch - see worker state reflected back after
reconcile
Milestone 5: Strict Worktree Support
Goal:
- ensure code-writing tasks execute in isolated worktrees
First scope:
orch dispatchresolvesbase_ref- strict mode fails when the repo is dirty and no explicit base is provided
- worktree path and branch name are stored on the attempt
Definition of done:
- a code task dispatch creates a real worktree
- the assigned worktree path appears in attempt metadata and inbox payload
Milestone 6: Waiting Primitives
Goal:
- replace blind polling with blocking CLI waits
Commands:
orch waitinbox wait-reply
Definition of done:
- leader can block on new task events
- blocked worker can block on reply events
Milestone 7: Council Review
Goal:
- implement the user-facing three-reviewer brainstorming workflow
First commands:
orch council startorch council waitorch council tallyorch council report
Definition of done:
- one council run can dispatch three reviewers
- tally grouped recommendations into
consensus,majority, andminority - produce stable JSON and a markdown report artifact
Immediate Next Task
If a new agent is taking over now, the next concrete step should be:
- create the inbox test documentation tree under
docs/tests/inbox/ - write the shared testing conventions in
docs/tests/inbox/README.md - add
_shared/README.mdfor common fixtures and assertion rules - add command-level
README.mdfiles for the implemented inbox commands - add
workflows/README.mdfor cross-command cases such as unread, wait, and reply flows
This is the smallest meaningful documentation slice because the inbox implementation is already present and stable enough to document in detail before orch work begins.
Recommended Driver Choices
Current recommendation:
- CLI framework:
Cobra - SQLite driver: pure-Go driver
Reason:
- command surfaces are already command-group heavy
- pure-Go SQLite keeps distribution simpler
Suggested Early Tests
Add these tests before the codebase grows too much:
- schema init test
- inbox thread lifecycle test
- single-task orch dispatch and reconcile test
- worktree path generation test
- council tally grouping test
Inbox Test Documentation Roadmap
Goal:
- make inbox behavior easy for a new agent to understand and convert into automated tests without re-reading all code paths
Directory layout:
docs/tests/inbox/README.mddocs/tests/inbox/_shared/README.mddocs/tests/inbox/workflows/README.mddocs/tests/inbox/<command>/README.md
Initial command folders:
initsendfetchclaimrenewupdatereplydonefailcancellistshowwatchwait-reply
Documentation rules:
- organize by folder and
README.md, not one file per test case - do not use numeric test case IDs
- identify cases by file path plus a stable case title or
slug - keep one command per directory, plus
workflows/for cross-command behavior - use
_shared/for common fixtures, database conventions, exit-code rules, and shared JSON assertions
Required per-case structure:
用例意义前置条件输入预期输出断言结论
Recommended case-title pattern:
## case: <stable-slug>
Authoring order:
- global conventions in
docs/tests/inbox/README.md - shared fixtures and assertion helpers in
docs/tests/inbox/_shared/README.md - lifecycle flow in
docs/tests/inbox/workflows/README.md - core command docs:
send,fetch,claim,reply,done,show - secondary command docs:
renew,update,fail,cancel,list - waiting and read-state docs:
watch,wait-reply, unread and mark-read workflow cases
Definition of done:
- every implemented inbox command has a dedicated document directory
- every documented case contains concrete input and expected output
- shared assumptions are centralized instead of copied into each command file
- a new agent can pick any case and implement it as an automated test with minimal additional discovery
Out Of Scope For First Pass
Do not block v1 on these:
- distributed execution
- advanced auth or permissions
- patch-producing council mode
- configurable reviewer counts beyond three
- rich similarity engines for proposal grouping
- background daemons beyond blocking CLI commands
Handoff Notes For Future Agents
- The design phase is complete enough to start coding.
- Avoid reopening major design questions unless implementation forces it.
- The repository already has compiling binaries and working schema init.
- Finish the inbox test-plan docs before starting broad
orchimplementation. - Preserve the separation:
inboxhandles communicationorchhandles schedulingcouncil-reviewis a workflow on top oforch
- When writing inbox test docs, use the folder-per-command structure described above and keep cross-command cases inside
docs/tests/inbox/workflows/. - Treat this file as the implementation entrypoint for new agents.