5.6 KiB
External review: yoi-ticket-cli-parity
1. Result
approve
2. Summary of implementation
The implementation adds a new yoi ticket ... command surface in the product yoi binary crate, with parsing and dispatch in crates/yoi/src/main.rs and the command implementation in crates/yoi/src/ticket_cli.rs.
The CLI resolves the local Ticket backend through ticket::config::TicketConfig::load_workspace, defaults to <cwd>/work-items when no .yoi/ticket.config.toml is present, and then calls LocalTicketBackend / TicketBackend operations directly. I found no production-path shell-out to tickets.sh; the only tickets.sh process invocations found are in crates/ticket compatibility tests.
The changed files are scoped to the yoi CLI crate, the ticket backend doctor reporting shape, and necessary dependency/package hash updates. I did not find storage migration, tickets.sh removal, TUI changes, scheduler/lease work, or broad refactoring.
3. Requirement-by-requirement assessment
yoi ticketsubcommands cover create/list/show/comment/review/status/close/doctor: satisfied.TicketCommandcontains all requested operations andhelp_text()documents them.- Product CLI ownership in the
yoibinary crate: satisfied.main.rsaddsMode::Ticketand dispatchesticketbefore normal TUI argument handling. - Uses Rust Ticket backend APIs directly, no
tickets.shshell-out: satisfied for the product CLI path.ticket_cli.rscallsLocalTicketBackendandTicketBackendmethods directly. - Backend root resolution and active storage: satisfied for this ticket. The CLI uses
.yoi/ticket.config.tomlwhen present and otherwise defaults to<cwd>/work-items, preserving current local storage rather than moving to.yoi/tickets. status closedsafety: satisfied.status closedis rejected with guidance to useyoi ticket close <ticket> --resolution <text>.comment,review, andclosebody source validation: satisfied. The parser requires exactly one body source and rejects conflicting/missing inputs;reviewalso requires exactly one result flag.- Doctor success/failure behavior: satisfied for errors.
TicketCliStatus::Failuremaps to a failing process exit code, and diagnostics are printed when errors are present. - Human-useful output: broadly satisfied. Output is concise tabular/plain text for create/list/status and readable Markdown-like output for show.
- Bounded output: partially satisfied only by the natural size of the local backend;
show,list, and doctor diagnostics do not impose explicit limits. I classify this as a follow-up because the requested CLI parity is still implemented and the current compatibility CLI is also not explicitly bounded. - Tests in temp roots/fixtures: satisfied in implementation.
ticket_cli.rsexercises core operations inTempDir, including configured backend root behavior and validation edge cases;crates/ticketkeeps compatibility tests. Cargo.lock/package.nix: necessary and safe on inspection. Addingticketto theyoicrate requires the lockfile package dependency update, and the Nix cargo hash update is expected from the Cargo metadata/source change.- Non-goals: satisfied. I found no
.yoi/ticketsmigration,tickets.shremoval, TUI change, scheduler/lease addition, or broad refactor.
4. Blockers
None.
5. Non-blockers / follow-ups
yoi ticket doctorsuppresses warning-only diagnostics becausedoctor()returns early withdoctor: okwhenreport.error_count() == 0. If backend warnings are intended to be user-visible, the CLI should print warnings while still exiting successfully. This is not a merge blocker because the oldtickets.sh doctoronly had errors and the required failure behavior for errors is present.- The CLI does not explicitly bound
show,list, or diagnostic output. Consider adding limits later if this command is expected to be safe for very large Ticket stores or oversized thread bodies. - The generic body-source error text says
--message/--resolutionfor all commands, so comment/review errors mention--resolutioneven though that flag is only for close. The validation is correct; the wording can be improved in follow-up.
6. Validation assessed or rerun
Rerun/read-only validation:
git diff --check develop...HEAD— passed with no output../tickets.sh doctor— passed:doctor: ok.git status --short && git branch --show-current && git rev-parse --short=12 HEAD— confirmed branchwork/yoi-ticket-cli-parityat4d5068ba3baf; no worktree dirt was reported before this review artifact was written.git grep -n "tickets.sh\|std::process::Command\|Command::new" -- crates/yoi crates/ticket— no production CLI shell-out found; onlycrates/ticketcompatibility tests invoketickets.sh.
Inspected:
- Ticket and delegation intent.
crates/yoi/src/ticket_cli.rs.crates/yoi/src/main.rs.crates/ticket/src/lib.rsdiff.crates/ticket/src/config.rsbackend default/config behavior.crates/yoi/Cargo.toml,Cargo.lockdiff, andpackage.nixhash change.
Not rerun: cargo test, cargo check, cargo fmt --check, built yoi ticket doctor, or nix build .#yoi; I stayed to read-only validation commands as requested for this external sibling review.
7. Residual risk
The main residual risk is not semantic parity but operational validation: I did not rerun the Rust or Nix builds, so the final merge owner should rely on the coder's validation evidence or rerun the full acceptance suite before merging. There is also minor UX risk around unbounded show/list output and warning-only doctor output being hidden.