Step 8: Polish — lint, clock abstraction, e2e test.
- golangci-lint config with errcheck, govet, staticcheck, errorlint - Fix all lint issues (unchecked error returns in cleanup paths, De Morgan) - Inject jonboulle/clockwork into Garden for deterministic timestamps - Add manifest.NewWithTime() for clock-aware initialization - E2e lifecycle test: init → add → checkpoint → modify → status → restore → verify - Update CLAUDE.md, PROJECT_PLAN.md, PROGRESS.md Phase 1 (local) is now complete. All 9 CLI commands implemented and tested. Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com>
This commit is contained in:
13
CLAUDE.md
13
CLAUDE.md
@@ -29,10 +29,16 @@ Run tests:
|
||||
go test ./...
|
||||
```
|
||||
|
||||
Lint:
|
||||
```bash
|
||||
golangci-lint run ./...
|
||||
```
|
||||
|
||||
## Dependencies
|
||||
|
||||
- `gopkg.in/yaml.v3` — manifest serialization
|
||||
- `github.com/spf13/cobra` — CLI framework
|
||||
- `github.com/jonboulle/clockwork` — injectable clock for deterministic tests
|
||||
|
||||
## Package Structure
|
||||
|
||||
@@ -47,8 +53,5 @@ Key rule: all logic lives in `garden/`. The `cmd/` layer only parses flags
|
||||
and calls `Garden` methods. This enables the future gRPC server to reuse
|
||||
the same logic with zero duplication.
|
||||
|
||||
## Legacy Files
|
||||
|
||||
Old C++ and proto source files may still be present. They are retained in
|
||||
git history for reference and should be removed as part of the Go rewrite
|
||||
(see PROJECT_PLAN.md Step 1).
|
||||
Each garden operation (remove, verify, list, diff) lives in its own file
|
||||
(`garden/<op>.go`) to minimize merge conflicts during parallel development.
|
||||
|
||||
Reference in New Issue
Block a user