5.9 KiB
| title | state | created_at | updated_at | queued_by | queued_at |
|---|---|---|---|---|---|
| Add non-hierarchical typed Ticket relations | inprogress | 2026-06-08T07:27:32Z | 2026-06-09T05:43:42Z | workspace-panel | 2026-06-09T02:27:31Z |
Background
Ticket orchestration needs two distinct kinds of cross-Ticket coordination:
-
Project-level Ticket relations that are intrinsic to the Tickets themselves:
- this feature depends on that Ticket;
- this problem must be resolved before that Ticket is meaningful;
- this Ticket blocks another Ticket;
- this Ticket is related to, supersedes, or duplicates another Ticket.
-
Orchestrator execution-plan decisions:
- these two Tickets are conceptually independent but touch conflicting code paths, so do not run them in parallel;
- start Ticket A before B for the current batch;
- wait for current reviewer/coder capacity;
- this Ticket is planned queued but not yet accepted.
The existing ticket-orchestration-plan-tool belongs to the second category. It may be durable, but it is still about Orchestrator execution planning and local/current workset coordination.
This Ticket covers the first category: typed, durable Ticket-to-Ticket relations that can be shown and validated before the Orchestrator runs.
Goal
Add typed Ticket relation metadata for project-level dependencies, blockers, related links, superseding links, and duplication links, stored with the Ticket system and visible through CLI/Panel/Ticket APIs independently of Orchestrator runtime plans. Do not model hierarchy, umbrella, parent/child, sub-ticket, or part-of relations.
Requirements
- Provide a typed way to record Ticket-to-Ticket relations as project records.
- Support at least these non-hierarchical relation kinds, with final naming to be decided during implementation:
depends_on: this Ticket requires another Ticket to be completed/resolved first;blocks: this Ticket blocks another Ticket;related: non-blocking relation worth showing;supersedes/superseded_byorduplicate_of: replacement/duplication relationship.
- Do not support hierarchy/container relation kinds in the first version:
- no
parent/child; - no
sub-ticket; - no
umbrella; - no
part_of/containsdecomposition semantics.
- no
- Decide whether inverse non-hierarchical relations such as
blocked_byandsuperseded_byare stored explicitly or derived from forward relations. - Store relations in the Ticket backend in a durable, git-trackable form.
- Prefer a typed field/artifact/event model that can be validated by the Ticket backend.
- Avoid relying only on freeform Markdown thread text for mechanical relationships.
- Make relations visible before Orchestrator execution:
TicketShowshould display relevant relations;TicketListor Panel summaries should show at least blocking/dependency hints where space allows;- Panel/CLI should be able to indicate that a Ticket is blocked by unresolved dependencies.
- Add validation:
ticket doctorshould detect dangling Ticket references;- invalid relation kinds should fail validation;
- self-dependencies and obvious invalid cycles should be rejected or diagnosed;
- closed/resolved dependencies should be distinguishable from open blockers.
- Integrate with Intake/Planning:
- Intake/Planning should be able to record known project-level relations when materializing/refining a Ticket;
- dependency/blocking/related/supersedes/duplicate relations should be available for Ticket shaping and review;
- Intake/Planning must not create parent/child or umbrella-style relations as a replacement for umbrella Tickets.
- Integrate with Orchestrator routing as input, not as runtime plan state:
- Orchestrator should consult Ticket relations before accepting queued work;
- unresolved
depends_on/ blocking relations should prevent acceptance or return the Ticket to planning/blocked with a visible reason; - OrchestrationPlan may use Ticket relations as constraints, but should not own or invent project-level dependency metadata.
- Keep this distinct from local execution state:
- do not store Pod/session claims, worktree paths, active branch ownership, or reviewer/coder assignments in Ticket relation metadata;
- those remain in the local role session registry / OrchestrationPlan / Pod metadata as appropriate.
Non-goals
- Replacing OrchestrationPlan execution decisions such as current capacity, do-not-parallelize because of code conflicts, or planned queued order for the current batch.
- Implementing a full dependency graph scheduler.
- Making every related Ticket relation block queuing automatically.
- Encoding transient local Pod/worktree claims in git-tracked Ticket metadata.
- Representing Ticket hierarchy, umbrella containers, parent/child decomposition, sub-tickets, or part-of grouping.
Acceptance criteria
- Project-level Ticket relations can be recorded in a typed durable form.
TicketShowdisplays relation metadata.ticket doctorvalidates dangling references, invalid kinds, self-relations, and at least obvious invalid dependency cycles or reports bounded diagnostics.- Panel or Ticket list can surface dependency/blocking hints before the Orchestrator runs.
- Intake/Planning workflow guidance explains when to create project-level relations.
- Orchestrator routing guidance treats these relations as input constraints distinct from OrchestrationPlan runtime decisions.
- Documentation clearly distinguishes:
depends_on/blocksas non-hierarchical Ticket relation metadata;related/supersedes/duplicate_ofas non-blocking or replacement metadata;- unsupported hierarchy/container semantics such as parent/child, umbrella, sub-ticket, and part-of;
do_not_parallelize/ capacity / current planned order as OrchestrationPlan execution decisions;- Pod/session/worktree ownership as local runtime claims.
- Focused tests,
target/debug/yoi ticket doctor,cargo fmt --check, andgit diff --checkpass.