Files
seaweedfs/test/volume_server/DEV_PLAN.md

1335 lines
69 KiB
Markdown

# Volume Server Integration Test Dev Plan (Go)
## Goal
Create a Go integration test suite under `test/volume_server` that validates **drop-in behavior parity** for the Volume Server HTTP and gRPC APIs, so a Rust rewrite can be verified against the current Go behavior.
## Current Program Focus (2026-02-16)
- Primary execution focus has shifted to implementing native Rust volume-server parity.
- This integration suite is now the parity gate for Rust implementation work.
- New tests should be added only when native Rust implementation reveals uncovered Go behavior that is not yet captured.
- Rust implementation roadmap lives in `rust/volume_server/DEV_PLAN.md`.
## Hard Requirements
- Tests live under `test/volume_server`.
- Tests are written in Go.
- HTTP + gRPC APIs are both covered.
- Coverage targets execution-path parity (happy path + edge/failure/state variants), not only API reachability.
- During implementation, commit each logic change separately for reviewability.
## Ground Truth (API Surface)
- HTTP handlers:
- `weed/server/volume_server.go`
- `weed/server/volume_server_handlers.go`
- `weed/server/volume_server_handlers_read.go`
- `weed/server/volume_server_handlers_write.go`
- `weed/server/volume_server_handlers_admin.go`
- `weed/server/common.go` (path parsing and range handling)
- gRPC service and handlers:
- `weed/pb/volume_server.proto`
- `weed/server/volume_grpc_*.go`
## Proposed Test Directory Tree
```text
test/volume_server/
DEV_PLAN.md
README.md
Makefile
framework/
cluster.go # test cluster lifecycle, ports, process control
volume_fixture.go # test data provisioning and seed volumes
http_client.go # request helpers, auth helpers, assertions
grpc_client.go # grpc dial + common call wrappers
fault_injection.go # kill/restart peers, network/error simulation hooks
matrix/
config_profiles.go # runtime matrix profiles (jwt, readMode, public port split, etc.)
http/
admin_test.go # /status, /healthz, /ui, static resources
read_test.go # GET/HEAD read behaviors + variations
write_test.go # POST/PUT write behaviors + variations
delete_test.go # DELETE behaviors + variations
cors_and_options_test.go
throttling_test.go # upload/download in-flight limit paths
auth_test.go # jwt/no-jwt/bad-jwt/fid mismatch
grpc/
admin_lifecycle_test.go
vacuum_test.go
data_rw_test.go
copy_sync_test.go
tail_test.go
erasure_coding_test.go
tiering_test.go
remote_fetch_test.go
scrub_test.go
query_test.go
health_state_test.go
compatibility/
golden_behavior_test.go # protocol-level parity checks for selected canonical flows
```
## Environment/Matrix Profiles (Execution Dimensions)
Each API should be exercised across the smallest set of profiles that still covers behavior divergence:
- `P1`: Single volume server, no JWT, `readMode=proxy`, single HTTP port.
- `P2`: Public/admin port split (`port.public != port`) to verify public read-only behavior.
- `P3`: JWT enabled (`jwt.signing.key` and `jwt.signing.read.key`) with valid/invalid/missing tokens.
- `P4`: Replicated volume layout (>=2 volume servers) to cover proxy/redirect/replicate paths.
- `P5`: Erasure coding volumes present.
- `P6`: Remote tier backend configured.
- `P7`: Maintenance mode enabled.
- `P8`: Upload/download throttling limits enabled.
## HTTP API Test Case Tree
### 1. Admin and service endpoints
- [ ] `GET /status`
- [ ] baseline payload fields (`Version`, `DiskStatuses`, `Volumes`)
- [ ] response headers (`Server`, request ID)
- [ ] `GET /healthz`
- [ ] healthy -> `200`
- [ ] server stopping -> `503`
- [ ] heartbeat disabled -> `503`
- [ ] `GET /ui/index.html`
- [ ] enabled path renders page
- [ ] disabled/secured behavior matches current config
- [ ] static assets (`/favicon.ico`, `/seaweedfsstatic/*`) reachable
### 2. Data read endpoints (`GET`/`HEAD` on `/...`)
- [ ] URL shape variants
- [ ] `/{vid},{fid}`
- [ ] `/{vid}/{fid}`
- [ ] `/{vid}/{fid}/{filename}`
- [ ] malformed vid/fid -> `400`
- [ ] auth variants
- [ ] no JWT required
- [ ] read JWT missing/invalid/fid-mismatch -> `401`
- [ ] valid JWT -> success
- [ ] locality/read mode variants
- [ ] local volume read success
- [ ] missing local volume with `readMode=local` -> `404`
- [ ] missing local volume with `readMode=proxy` -> proxied response
- [ ] missing local volume with `readMode=redirect` -> `301`
- [ ] proxied-loop guard (`proxied=true`) behavior
- [ ] object state variants
- [ ] not found/deleted -> `404`
- [ ] cookie mismatch -> `404`
- [ ] internal read failure -> `500`
- [ ] `readDeleted=true` behavior
- [ ] conditional headers
- [ ] `If-Modified-Since` -> `304`
- [ ] `If-None-Match` -> `304`
- [ ] normal ETag emission
- [ ] range handling
- [ ] full read (no `Range`)
- [ ] single range -> `206`, `Content-Range`
- [ ] multi-range -> `206`, multipart body
- [ ] invalid range -> `416`
- [ ] oversized-range-sum behavior parity
- [ ] content transformations
- [ ] compressed data + `Accept-Encoding=gzip`
- [ ] compressed data without accepted encoding (decompress path)
- [ ] image resize (`width`,`height`,`mode`)
- [ ] image crop (`crop_*`)
- [ ] chunk manifest behavior
- [ ] manifest auto-expansion path
- [ ] `cm=false` bypass path
- [ ] response header passthrough queries
- [ ] `response-*` overrides and `dl` content-disposition behavior
- [ ] `HEAD` parity
- [ ] headers same as `GET` minus body
- [ ] content-length behavior parity
### 3. Data write endpoints (`PUT`/`POST` on `/...`)
- [ ] URL shape and parse validation
- [ ] write JWT variants (missing/invalid/mismatch)
- [ ] payload variants
- [ ] standard upload success -> `201`
- [ ] unchanged write -> `204` with ETag
- [ ] oversize file rejected (file-size limit)
- [ ] malformed multipart/form data -> `400`
- [ ] metadata variants (name/mime/pairs/md5 headers)
- [ ] replication path
- [ ] `type=replicate` bypasses upload throttling
- [ ] replication write failure behavior
- [ ] throttling paths
- [ ] limit disabled
- [ ] over limit wait then proceed
- [ ] timeout -> `429`
- [ ] canceled request -> `499`
### 4. Data delete endpoint (`DELETE` on `/...`)
- [ ] normal volume delete success (`202` + size)
- [ ] non-existing needle (`404` size=0)
- [ ] EC volume delete path
- [ ] cookie mismatch -> `400`
- [ ] chunk manifest delete (children first)
- [ ] chunk delete success
- [ ] chunk delete failure -> `500`
- [ ] `ts` override behavior
- [ ] auth variants as in write path
### 5. Method/CORS behavior
- [ ] private port `OPTIONS` -> allow `PUT,POST,GET,DELETE,OPTIONS`
- [ ] public port `OPTIONS` -> allow `GET,OPTIONS`
- [ ] CORS origin headers on requests with `Origin`
- [ ] unsupported method behavior parity (private and public ports)
### 6. Concurrency-limit and replica fallback behavior
- [ ] download over-limit + replica available -> proxy/redirect fallback
- [ ] download over-limit + no replica -> wait/timeout/cancel outcomes
- [ ] upload/download inflight counters update and release (no leaks)
## gRPC API Test Case Tree
For each RPC below: cover baseline success, validation/argument errors, state preconditions (maintenance, missing volume), and stream interruption where applicable.
### A. Admin/Lifecycle
- [ ] `DeleteCollection`
- [ ] existing collection
- [ ] non-existing collection idempotence/error parity
- [ ] `AllocateVolume`
- [ ] success
- [ ] maintenance mode reject
- [ ] duplicate/invalid allocation parity
- [ ] `VolumeMount`
- [ ] success
- [ ] missing/not-mountable volume
- [ ] `VolumeUnmount`
- [ ] success
- [ ] missing/not-mounted volume
- [ ] `VolumeDelete`
- [ ] `only_empty=true` and `false`
- [ ] maintenance mode reject
- [ ] `VolumeConfigure`
- [ ] success
- [ ] invalid replication string -> `resp.Error` path
- [ ] unmount failure path
- [ ] configure failure + remount rollback path
- [ ] mount failure path
- [ ] `VolumeMarkReadonly`
- [ ] success with `persist=false/true`
- [ ] volume not found
- [ ] notify-master failure (pre/post local transition)
- [ ] `VolumeMarkWritable`
- [ ] success
- [ ] volume not found
- [ ] notify-master failure
- [ ] `VolumeStatus`
- [ ] success
- [ ] volume not found
- [ ] data backend missing
- [ ] `VolumeServerStatus`
- [ ] payload completeness (`State`, `MemoryStatus`, disk statuses)
- [ ] `VolumeServerLeave`
- [ ] heartbeat stopped effect
- [ ] `GetState`
- [ ] `SetState`
- [ ] state transition success
- [ ] invalid update error path
- [ ] `Ping`
- [ ] target type: filer / volume / master
- [ ] unreachable target error wrapping
- [ ] unknown target type behavior parity
### B. Vacuum / compaction
- [ ] `VacuumVolumeCheck`
- [ ] success + garbage ratio
- [ ] missing volume/error path
- [ ] `VacuumVolumeCompact` (stream)
- [ ] progress events emitted
- [ ] maintenance mode reject
- [ ] compact failure
- [ ] client stream receive interruption
- [ ] `VacuumVolumeCommit`
- [ ] success (readonly + size fields)
- [ ] maintenance mode reject
- [ ] commit failure
- [ ] `VacuumVolumeCleanup`
- [ ] success
- [ ] maintenance mode reject
- [ ] cleanup failure
### C. Data read/write
- [ ] `ReadNeedleBlob`
- [ ] success
- [ ] missing volume
- [ ] invalid offset/size path
- [ ] `ReadNeedleMeta`
- [ ] success
- [ ] missing volume
- [ ] EC-only volume unsupported path
- [ ] read metadata failure
- [ ] `WriteNeedleBlob`
- [ ] success
- [ ] maintenance mode reject
- [ ] missing volume
- [ ] write failure
- [ ] `VolumeNeedleStatus`
- [ ] normal volume success
- [ ] EC volume success
- [ ] volume missing
- [ ] needle missing/read error
### D. Batch and scan
- [ ] `BatchDelete`
- [ ] `skip_cookie_check=true/false`
- [ ] invalid fid parse
- [ ] not found
- [ ] cookie mismatch path
- [ ] chunk manifest reject path (`406` in result)
- [ ] regular and EC delete paths
- [ ] `ReadAllNeedles` (stream)
- [ ] multiple volumes success
- [ ] one missing volume abort behavior
### E. Copy/sync/replication streams
- [ ] `VolumeSyncStatus`
- [ ] success
- [ ] missing volume
- [ ] `VolumeIncrementalCopy` (stream)
- [ ] data streamed from `since_ns`
- [ ] `isLastOne` no-data path
- [ ] missing volume/error path
- [ ] `VolumeCopy` (stream)
- [ ] full copy success (`.dat/.idx/.vif`) + mount
- [ ] existing destination volume delete-before-copy path
- [ ] source unavailable / read status failure
- [ ] no free location
- [ ] remote-dat-file branch
- [ ] copy integrity mismatch failures
- [ ] final progress/append timestamp behavior
- [ ] `ReadVolumeFileStatus`
- [ ] success field validation
- [ ] missing volume
- [ ] `CopyFile` (stream)
- [ ] normal volume path
- [ ] EC volume path
- [ ] compaction revision mismatch
- [ ] missing source file with ignore flag true/false
- [ ] zero-byte and stop-offset edge cases
- [ ] `ReceiveFile` (client stream)
- [ ] happy path regular volume
- [ ] happy path EC file target
- [ ] info-first protocol violation
- [ ] unknown message type
- [ ] maintenance mode reject
- [ ] write/create failure cleanup behavior
### F. Tailing
- [ ] `VolumeTailSender` (stream)
- [ ] volume not found
- [ ] heartbeat chunks when no updates
- [ ] idle-timeout drain completion
- [ ] large needle chunking behavior
- [ ] `VolumeTailReceiver`
- [ ] success applies streamed writes
- [ ] destination volume missing
- [ ] source stream/connect failure
### G. Erasure coding
- [ ] `VolumeEcShardsGenerate`
- [ ] success default config
- [ ] success with existing `.vif` EC config
- [ ] maintenance mode reject
- [ ] collection mismatch
- [ ] generate/write cleanup on failure
- [ ] `VolumeEcShardsRebuild`
- [ ] rebuild missing shards success
- [ ] no shards found path
- [ ] rebuild failures
- [ ] `VolumeEcShardsCopy`
- [ ] shard copy success
- [ ] `copy_ecx`/`copy_ecj`/`copy_vif` toggles
- [ ] explicit `disk_id` valid/invalid
- [ ] no-space/source-copy failure
- [ ] `VolumeEcShardsDelete`
- [ ] delete selected shard ids
- [ ] delete-last-shard cleanup (`.ecx/.ecj` + optional `.vif`)
- [ ] missing shard no-op parity
- [ ] `VolumeEcShardsMount`
- [ ] multi-shard success
- [ ] per-shard failure abort behavior
- [ ] `VolumeEcShardsUnmount`
- [ ] multi-shard success
- [ ] per-shard failure abort behavior
- [ ] `VolumeEcShardRead` (stream)
- [ ] success
- [ ] not-found volume/shard
- [ ] deleted file key returns `IsDeleted`
- [ ] chunked streaming for large reads
- [ ] `VolumeEcBlobDelete`
- [ ] delete existing blob
- [ ] already deleted idempotence
- [ ] locate failure
- [ ] `VolumeEcShardsToVolume`
- [ ] success path from EC -> normal
- [ ] missing EC volume/shard
- [ ] invalid data-shard config
- [ ] no-live-entries failed-precondition path
- [ ] write dat/idx failures
- [ ] `VolumeEcShardsInfo`
- [ ] success counts (including deleted)
- [ ] missing EC volume
- [ ] walk-index failure
### H. Tiering and remote
- [ ] `VolumeTierMoveDatToRemote` (stream)
- [ ] success with progress events
- [ ] maintenance mode reject
- [ ] volume missing / collection mismatch
- [ ] destination backend missing
- [ ] destination exists already
- [ ] keep-local true/false branches
- [ ] `VolumeTierMoveDatFromRemote` (stream)
- [ ] success with progress events
- [ ] volume missing / collection mismatch
- [ ] already-local path
- [ ] backend missing/download failure
- [ ] keep-remote true/false branches
- [ ] `FetchAndWriteNeedle`
- [ ] success without replicas
- [ ] success with replica fanout
- [ ] maintenance mode reject
- [ ] missing volume
- [ ] remote client/read failure
- [ ] local write failure
- [ ] one replica write failure behavior
### I. Query and scrub
- [ ] `Query` (stream)
- [ ] JSON input selection/filter success
- [ ] malformed fid parse failure
- [ ] read/cookie mismatch failure
- [ ] CSV-input current behavior parity
- [ ] `ScrubVolume`
- [ ] auto-select all volumes when request empty
- [ ] mode `INDEX`
- [ ] mode `LOCAL` (not-implemented detail reporting)
- [ ] mode `FULL` (not-implemented detail reporting)
- [ ] unsupported mode error
- [ ] `ScrubEcVolume`
- [ ] auto-select all EC volumes when request empty
- [ ] mode `INDEX`
- [ ] mode `LOCAL`
- [ ] mode `FULL` (not-implemented detail reporting)
- [ ] unsupported mode error
## Phased Implementation Plan (Tracking)
### Phase 0: Harness and scaffolding
- [x] Create `framework/` cluster bootstrap and teardown
- [x] Add profile-based environment builder (P1..P8)
- [x] Add common assertion helpers (HTTP and gRPC)
- [x] Add `README.md` with run instructions
- [x] Add `Makefile` targets (`test-volume-server`, profile filters)
### Phase 1: HTTP parity suites
- [ ] Admin/status/health/UI/static
- [ ] Read path variants and headers/range/transforms
- [ ] Write/delete/auth/throttling/public-port behavior
### Phase 2: gRPC parity suites (core)
- [x] Admin/lifecycle/state/ping
- [ ] Vacuum + batch + data rw
- [ ] Copy/sync/tail
### Phase 3: gRPC parity suites (advanced)
- [ ] Erasure coding family
- [ ] Tiering + remote fetch
- [ ] Query + scrub
### Phase 4: Compatibility hardening
- [ ] Golden behavior assertions for canonical flows
- [ ] Flake reduction and deterministic retries/timeouts
- [ ] CI runtime tuning and sharding
## Commit Strategy (for implementation)
Use one commit per logical change set. Suggested sequence:
1. `test(volume_server): add integration framework and cluster lifecycle`
2. `test(volume_server): add config profile matrix and test utilities`
3. `test(volume_server/http): add admin and health endpoint coverage`
4. `test(volume_server/http): add read-path matrix coverage`
5. `test(volume_server/http): add write/delete/auth/throttling coverage`
6. `test(volume_server/grpc): add admin lifecycle and state/ping coverage`
7. `test(volume_server/grpc): add vacuum batch and data rw coverage`
8. `test(volume_server/grpc): add copy sync and tail coverage`
9. `test(volume_server/grpc): add erasure coding coverage`
10. `test(volume_server/grpc): add tiering and remote fetch coverage`
11. `test(volume_server/grpc): add query and scrub coverage`
12. `test(volume_server): add compatibility golden scenarios and docs`
## Progress Log
Update this section during implementation:
- Date: 2026-02-12
- Change: Added initial dev plan and project scaffold.
- APIs covered: Planning only.
- Profiles covered: Planning only.
- Gaps introduced/remaining: Implementation not started yet.
- Commit: `21c10a9ec`
- Date: 2026-02-12
- Change: Added integration harness, profile matrix, and auto-build support for missing `weed` binary. Master now starts with `-peers=none` and low `-volumeSizeLimitMB`.
- APIs covered: Harness only.
- Profiles covered: P1, P2, P3, P8 definitions in place.
- Gaps introduced/remaining: Full API case matrix still pending.
- Commit: `5e9c437e0`, `1be296139`
- Date: 2026-02-12
- Change: Added HTTP integration coverage for admin endpoints, method options, and upload/read/range/head/delete roundtrip.
- APIs covered: `/status`, `/healthz`, `/ui/index.html`, `OPTIONS /`, `POST/GET/HEAD/DELETE /{fid}`.
- Profiles covered: P1, P2.
- Gaps introduced/remaining: Remaining HTTP branch variants (JWT/proxy/redirect/throttling/etc.) still pending.
- Commit: `038e9161e`, `1df1e3812`
- Date: 2026-02-12
- Change: Added gRPC integration coverage for state/status/ping and admin lifecycle/maintenance checks.
- APIs covered: `GetState`, `SetState`, `VolumeServerStatus`, `Ping`, `AllocateVolume`, `VolumeStatus`, `VolumeMount`, `VolumeUnmount`, `VolumeDelete`.
- Profiles covered: P1.
- Gaps introduced/remaining: Remaining gRPC methods and advanced branches still pending.
- Commit: `9a9b8c500`, `3c562a64c`
- Date: 2026-02-12
- Change: Added HTTP cache/range branch tests.
- APIs covered: `GET /{fid}` with `If-None-Match` (`304`) and invalid `Range` (`416`).
- Profiles covered: P1.
- Gaps introduced/remaining: Remaining HTTP auth/proxy/redirect/throttling branches pending.
- Commit: `317346b51`
- Date: 2026-02-12
- Change: Added gRPC `BatchDelete` integration checks for invalid fid mapping and maintenance-mode rejection.
- APIs covered: `BatchDelete`.
- Profiles covered: P1.
- Gaps introduced/remaining: Remaining gRPC method families still pending.
- Commit: `7a8aed127`
- Date: 2026-02-12
- Change: Added gRPC integration tests for needle status, configure validation branch, ping volume-target branch, and leave/health interaction.
- APIs covered: `VolumeNeedleStatus`, `VolumeConfigure` (invalid replication response path), `Ping` (`volumeServer` target), `VolumeServerLeave`.
- Profiles covered: P1.
- Gaps introduced/remaining: Still pending large RPC groups (vacuum/copy/tail/ec/tiering/query/scrub).
- Commit: `59a571a10`
- Date: 2026-02-12
- Change: Added gRPC vacuum integration coverage for success/missing-volume and maintenance-mode rejection branches.
- APIs covered: `VacuumVolumeCheck`, `VacuumVolumeCompact`, `VacuumVolumeCommit`, `VacuumVolumeCleanup`.
- Profiles covered: P1.
- Gaps introduced/remaining: Copy/sync/tail, EC, tiering, query, scrub, and many HTTP matrix branches still pending.
- Commit: `0f7cc53dd`
- Date: 2026-02-12
- Change: Added gRPC data read/write error-path coverage for missing-volume and maintenance-mode branches.
- APIs covered: `ReadNeedleBlob`, `ReadNeedleMeta`, `WriteNeedleBlob`.
- Profiles covered: P1.
- Gaps introduced/remaining: Positive-path blob/meta and stream/copy/tail/EC/tiering/query/scrub families remain.
- Commit: `f83ad41b5`
- Date: 2026-02-12
- Change: Added HTTP JWT integration coverage for missing/invalid/valid token behavior across write and read paths.
- APIs covered: HTTP `POST /{fid}` and `GET /{fid}` auth paths with read/write signing keys.
- Profiles covered: P3.
- Gaps introduced/remaining: Remaining HTTP proxy/redirect/throttling branches still pending.
- Commit: `def509acb`
- Date: 2026-02-12
- Change: Added gRPC sync/copy family tests for success and missing-volume or maintenance-mode stream error paths.
- APIs covered: `VolumeSyncStatus`, `VolumeIncrementalCopy`, `ReadAllNeedles`, `ReadVolumeFileStatus`, `CopyFile`, `VolumeCopy`, `ReceiveFile`.
- Profiles covered: P1.
- Gaps introduced/remaining: Tail/EC/tiering/query/scrub and positive-path copy/tail flows still pending.
- Commit: `b13642838`
- Date: 2026-02-12
- Change: Added gRPC scrub and query integration coverage for supported/unsupported modes and invalid/missing fid paths.
- APIs covered: `ScrubVolume`, `ScrubEcVolume`, `Query`.
- Profiles covered: P1.
- Gaps introduced/remaining: Query success path and broader scrub mode matrix remain pending.
- Commit: `a2ab4cde8`
- Date: 2026-02-12
- Change: Added gRPC tail integration coverage for sender heartbeat/EOF behavior and sender/receiver missing-volume errors.
- APIs covered: `VolumeTailSender`, `VolumeTailReceiver`.
- Profiles covered: P1.
- Gaps introduced/remaining: Tail success replication path and large-needle chunking remain pending.
- Commit: `fd582ba58`
- Date: 2026-02-12
- Change: Expanded gRPC admin/lifecycle coverage with readonly/writable transitions, collection delete behavior, non-empty delete `only_empty` branch, and ping unknown/unreachable target variants.
- APIs covered: `VolumeMarkReadonly`, `VolumeMarkWritable`, `DeleteCollection`, `VolumeDelete` (`only_empty=true/false`), `Ping` (unknown and unreachable master target).
- Profiles covered: P1.
- Gaps introduced/remaining: Notify-master failure paths for readonly/writable and additional admin error branches still pending.
- Commit: `2e6d577f7`, `a3a2da791`, `9f887f25c`, `724bbe2d9`
- Date: 2026-02-12
- Change: Added gRPC positive-path data coverage for blob/meta read/write roundtrip and stream-all-needles payload validation.
- APIs covered: `ReadNeedleBlob`, `ReadNeedleMeta`, `WriteNeedleBlob`, `ReadAllNeedles`.
- Profiles covered: P1.
- Gaps introduced/remaining: Additional blob/meta offset/size corruption branches remain.
- Commit: `21e94d1d2`
- Date: 2026-02-12
- Change: Expanded gRPC scrub/query coverage for auto-select volume behavior, local/full scrub detail branches, JSON query success filtering, CSV no-output behavior, and EC auto-select empty result.
- APIs covered: `ScrubVolume` (`INDEX`, `LOCAL`, `FULL`, auto-select), `ScrubEcVolume` (missing-volume + auto-select empty), `Query` (JSON success + CSV no-output + invalid paths).
- Profiles covered: P1.
- Gaps introduced/remaining: EC scrub full/local positive paths need EC fixture setup.
- Commit: `8cdf3589a`, `12150a9a2`
- Date: 2026-02-12
- Change: Added gRPC tiering/remote early-branch error coverage.
- APIs covered: `FetchAndWriteNeedle` (maintenance + missing volume), `VolumeTierMoveDatToRemote` (missing volume, collection mismatch, maintenance), `VolumeTierMoveDatFromRemote` (missing volume, collection mismatch, already-local path).
- Profiles covered: P1.
- Gaps introduced/remaining: Tier upload/download success flows with real remote backend remain.
- Commit: `51e6fa749`
- Date: 2026-02-12
- Change: Expanded HTTP behavior coverage for split public port semantics, CORS on origin requests, unsupported-method parity, unchanged-write `204`, delete edge branches, and JWT fid-mismatch auth rejection.
- APIs covered: public/admin method divergence (`GET/HEAD/POST/DELETE/PATCH`), CORS headers, write unchanged response path, delete cookie-mismatch/missing-needle paths, JWT fid mismatch for write/read.
- Profiles covered: P1, P2, P3.
- Gaps introduced/remaining: Remaining HTTP proxy/redirect/throttling and transformation branches still pending.
- Commit: `2de39c548`, `9998d19dd`, `ea5d8b7b3`
- Date: 2026-02-12
- Change: Expanded tier/remote gRPC variation coverage with invalid remote config and missing destination backend branches.
- APIs covered: `FetchAndWriteNeedle` (invalid `RemoteConf`), `VolumeTierMoveDatToRemote` (destination backend not found).
- Profiles covered: P1.
- Gaps introduced/remaining: Tier upload/download success flows with an actual remote backend and replica fanout behavior remain.
- Commit: `855c84f31`
- Date: 2026-02-12
- Change: Expanded copy/receive stream coverage with incremental-copy data/no-data branches and receive-file protocol violation handling.
- APIs covered: `VolumeIncrementalCopy` (stream data + EOF no-data), `CopyFile` (ignore missing source + `stop_offset=0`), `ReceiveFile` (content-before-info and unknown message type response errors).
- Profiles covered: P1.
- Gaps introduced/remaining: Full `VolumeCopy` happy path with a real source volume node remains.
- Commit: `1e99407e1`
- Date: 2026-02-12
- Change: Added additional copy/receive branches for compaction mismatch and regular-volume receive-file success with byte-for-byte verification via `CopyFile`.
- APIs covered: `CopyFile` (compaction revision mismatch), `ReceiveFile` (successful regular volume write path).
- Profiles covered: P1.
- Gaps introduced/remaining: EC receive-file success path and cleanup failure branches remain.
- Commit: `4c710463e`
- Date: 2026-02-12
- Change: Added HTTP read-path variants and conditional request coverage.
- APIs covered: `GET /{vid}/{fid}`, `GET /{vid}/{fid}/{filename}`, malformed `/{vid}/{fid}` parse error path, `If-Modified-Since` (`304`) behavior.
- Profiles covered: P1.
- Gaps introduced/remaining: Proxy/redirect read mode matrix and image/chunk-manifest transformation branches remain.
- Commit: `1f64ebe1d`
- Date: 2026-02-12
- Change: Added HTTP passthrough header and static resource coverage.
- APIs covered: query-based `response-*` header passthrough, `dl=true` content-disposition attachment handling, `/favicon.ico`, `/seaweedfsstatic/seaweed50x50.png`.
- Profiles covered: P1.
- Gaps introduced/remaining: Additional static resource variants and multi-range response formatting checks remain.
- Commit: `f1ad1ec50`
- Date: 2026-02-12
- Change: Added gRPC ping branch coverage for unreachable filer target.
- APIs covered: `Ping` (`target_type=filer` unreachable target path).
- Profiles covered: P1.
- Gaps introduced/remaining: Successful ping path for filer/master targets in multi-service integration setup remains.
- Commit: `c6ace0331`
- Date: 2026-02-12
- Change: Added initial erasure-coding RPC integration coverage for maintenance-gate, missing-volume, invalid-disk, and no-op behaviors.
- APIs covered: `VolumeEcShardsGenerate`, `VolumeEcShardsRebuild`, `VolumeEcShardsCopy`, `VolumeEcShardsDelete`, `VolumeEcShardsMount`, `VolumeEcShardsUnmount`, `VolumeEcShardRead`, `VolumeEcBlobDelete`, `VolumeEcShardsToVolume`, `VolumeEcShardsInfo`.
- Profiles covered: P1.
- Gaps introduced/remaining: Positive EC data-path flows (generate/copy/mount/read/delete/to-volume/info with actual shard files) still require EC fixture setup.
- Commit: `c7592d118`
- Date: 2026-02-12
- Change: Added HTTP multi-range response coverage for multipart `206` behavior.
- APIs covered: `GET /{fid}` with multi-range header (`Range: bytes=0-1,4-5`) and multipart response validation.
- Profiles covered: P1.
- Gaps introduced/remaining: Oversized multi-range sum behavior and deeper range-edge normalization remain.
- Commit: `39c68c679`
- Date: 2026-02-12
- Change: Added query no-match parity coverage to lock current stream semantics.
- APIs covered: `Query` JSON filter no-match path (returns one empty stripe, then EOF).
- Profiles covered: P1.
- Gaps introduced/remaining: CSV parsing behavior beyond current no-output branch still pending.
- Commit: `39895cb84`
- Date: 2026-02-12
- Change: Added HTTP upload throttling integration coverage with deterministic timeout and replicate-bypass behavior.
- APIs covered: upload limit timeout path (`429`) and `type=replicate` bypass branch under concurrent upload pressure.
- Profiles covered: P8 (with short inflight timeout in test profile).
- Gaps introduced/remaining: download throttling wait/proxy branches remain.
- Commit: `464d0b2b6`
- Date: 2026-02-12
- Change: Added HTTP download throttling timeout coverage under concurrent large-read pressure.
- APIs covered: download limit timeout path (`429`) when another large response keeps in-flight download data above limit.
- Profiles covered: P8 (short inflight download timeout).
- Gaps introduced/remaining: download replica proxy fallback branch (`proxied=true`/replica redirect) remains.
- Commit: `a929e6ddc`
- Date: 2026-02-12
- Change: Expanded JWT auth mismatch variations for same-needle wrong-cookie tokens.
- APIs covered: write/read JWT rejection when token fid differs only by cookie from requested fid.
- Profiles covered: P3.
- Gaps introduced/remaining: token expiry boundary behavior remains untested.
- Commit: `61fe52398`
- Date: 2026-02-12
- Change: Added JWT expired-token rejection coverage for both write and read auth paths.
- APIs covered: write/read auth rejection when token signature is valid but `exp` is in the past.
- Profiles covered: P3.
- Gaps introduced/remaining: additional JWT transport variants (query/cookie token sources) remain.
- Commit: `6e808623f`
- Date: 2026-02-12
- Change: Added JWT token transport coverage via query parameter and HTTP-only cookie.
- APIs covered: write auth using `?jwt=` token and read auth using `AT` cookie token.
- Profiles covered: P3.
- Gaps introduced/remaining: JWT precedence rules when multiple token sources are present remain.
- Commit: `ccefdfe8d`
- Date: 2026-02-12
- Change: Added JWT token-source precedence coverage when both query and header tokens are present.
- APIs covered: query-token precedence over header-token for write/read auth checks.
- Profiles covered: P3.
- Gaps introduced/remaining: explicit query-vs-cookie precedence combination remains.
- Commit: `605054e5d`
- Date: 2026-02-12
- Change: Added JWT token-source precedence coverage when both header and cookie tokens are present.
- APIs covered: header-token precedence over cookie-token for write/read auth checks.
- Profiles covered: P3.
- Gaps introduced/remaining: JWT transport precedence matrix for query/header/cookie is now covered for tested combinations.
- Commit: `3fcaf845c`
- Date: 2026-02-12
- Change: Added JWT token-source precedence coverage when both query and cookie tokens are present.
- APIs covered: query-token precedence over cookie-token for write/read auth checks, including positive path when query is valid and cookie is invalid.
- Profiles covered: P3.
- Gaps introduced/remaining: none in current JWT token source precedence matrix.
- Commit: `4ea552973`
- Date: 2026-02-12
- Change: Added gRPC state update validation coverage for optimistic versioning and nil-state requests.
- APIs covered: `SetState` stale-version mismatch error path and nil-state no-op path.
- Profiles covered: P1.
- Gaps introduced/remaining: persistent state save failure branch remains environment-dependent.
- Commit: `34ff97996`
- Date: 2026-02-12
- Change: Added readonly lifecycle variation for persisted readonly flag path.
- APIs covered: `VolumeMarkReadonly` success path with `persist=true`.
- Profiles covered: P1.
- Gaps introduced/remaining: notify-master failure branches remain untested.
- Commit: `c37e6cd95`
- Date: 2026-02-12
- Change: Added CORS header validation on `OPTIONS` requests with `Origin` for admin and public ports.
- APIs covered: `OPTIONS /` CORS headers (`Access-Control-Allow-Origin`, `Access-Control-Allow-Credentials`) for split-port profile.
- Profiles covered: P2.
- Gaps introduced/remaining: unsupported-method parity for additional verbs beyond `PATCH`/`TRACE` remains.
- Commit: `ca08af7ba`
- Date: 2026-02-12
- Change: Added unsupported-method parity coverage for `TRACE` on admin/public split ports.
- APIs covered: admin `TRACE` error (`400`) vs public `TRACE` passthrough (`200`) behavior.
- Profiles covered: P2.
- Gaps introduced/remaining: broader unsupported verb matrix remains.
- Commit: `b03ddf855`
- Date: 2026-02-12
- Change: Added gRPC batch-delete cookie-check variation coverage.
- APIs covered: `BatchDelete` mismatch-cookie rejection path (`skip_cookie_check=false`) and skip-cookie-check acceptance/deletion path (`skip_cookie_check=true`).
- Profiles covered: P1.
- Gaps introduced/remaining: batch-delete malformed entry combinations are partially covered; mixed per-entry status permutations can be expanded.
- Commit: `87d75e786`
- Date: 2026-02-12
- Change: Expanded gRPC admin lifecycle variants for allocate/mount/unmount/delete edge cases.
- APIs covered: duplicate `AllocateVolume` rejection, missing-volume `VolumeMount` error, idempotent `VolumeUnmount` behavior for missing/already-unmounted volumes, and `VolumeDelete` maintenance-mode rejection.
- Profiles covered: P1.
- Gaps introduced/remaining: `VolumeConfigure` rollback/mount-failure branches still need dedicated fault-path coverage.
- Commit: `bc1faec8e`
- Date: 2026-02-12
- Change: Added mixed gRPC `BatchDelete` result-matrix coverage including early-stop behavior on cookie mismatch.
- APIs covered: per-entry status matrix in one request (`400` invalid fid, `202` accepted delete, `404` missing fid) and early break semantics when cookie mismatch occurs before later entries.
- Profiles covered: P1.
- Gaps introduced/remaining: chunk-manifest rejection (`406`) and EC batch-delete success path still require dedicated fixtures.
- Commit: `450f63ac4`
- Date: 2026-02-12
- Change: Added secured-UI HTTP behavior coverage under JWT-enabled profile.
- APIs covered: `/ui/index.html` route behavior when admin UI is not exposed due signing key; verified fallback auth-gated response path (`401`).
- Profiles covered: P3.
- Gaps introduced/remaining: explicit `access.ui=true` override scenario remains untested.
- Commit: `9c10ccb38`
- Date: 2026-02-12
- Change: Expanded split-port unsupported HTTP method matrix with non-standard verb coverage.
- APIs covered: admin/public parity for `PROPFIND` (`400` on admin, passthrough `200` on public) with post-call data-integrity verification.
- Profiles covered: P2.
- Gaps introduced/remaining: remaining unsupported-verb breadth now primarily around less common methods (e.g., `CONNECT`) and proxy-specific edge semantics.
- Commit: `1d7afd11e`
- Date: 2026-02-12
- Change: Expanded gRPC `VolumeConfigure` coverage for both success and configure-failure rollback reporting.
- APIs covered: valid replication success path and missing-volume configure failure path with remount-restore failure detail propagation.
- Profiles covered: P1.
- Gaps introduced/remaining: explicit unmount-failure and mount-failure branches via injected I/O faults are still pending.
- Commit: `287a60197`
- Date: 2026-02-12
- Change: Added `VolumeNeedleStatus` error-path coverage.
- APIs covered: missing-volume error path and missing-needle error path on existing normal volumes.
- Profiles covered: P1.
- Gaps introduced/remaining: EC-backed positive/error status permutations still require dedicated EC fixture state.
- Commit: `bf0c609a7`
- Date: 2026-02-12
- Change: Added HTTP deleted-needle read recovery coverage.
- APIs covered: `GET` with `readDeleted=true` returning deleted needle content, alongside normal post-delete `404` behavior.
- Profiles covered: P1.
- Gaps introduced/remaining: proxy/redirect interactions with `readDeleted` remain unverified.
- Commit: `2ed9434cf`
- Date: 2026-02-12
- Change: Added HTTP delete `ts` query parity coverage for deleted-read metadata behavior.
- APIs covered: `DELETE ?ts=` followed by `GET ?readDeleted=true`, asserting current Last-Modified parity with pre-delete reads.
- Profiles covered: P1.
- Gaps introduced/remaining: explicit externally visible timestamp override effects remain limited in current API responses.
- Commit: `225b8e800`
- Date: 2026-02-12
- Change: Added gRPC invalid-offset coverage for needle blob/meta reads.
- APIs covered: `ReadNeedleBlob` and `ReadNeedleMeta` failure paths on existing volumes with out-of-range offsets.
- Profiles covered: P1.
- Gaps introduced/remaining: low-level corrupted-size and backend I/O fault branches still require fault-injection hooks.
- Commit: `33ed77ad6`
- Date: 2026-02-12
- Change: Added mixed-volume `ReadAllNeedles` stream abort coverage.
- APIs covered: stream progression from an existing volume followed by missing-volume abort error in the same request.
- Profiles covered: P1.
- Gaps introduced/remaining: multi-volume happy-path ordering/volume-boundary assertions can be expanded further.
- Commit: `7799b28b1`
- Date: 2026-02-12
- Change: Tightened HTTP `HEAD` parity assertions for read path.
- APIs covered: `HEAD` behavior now verifies empty response body while retaining `Content-Length` parity expectations.
- Profiles covered: P1.
- Gaps introduced/remaining: additional conditional-header parity checks on `HEAD` can still be expanded.
- Commit: `9499e5400`
- Date: 2026-02-12
- Change: Expanded `VolumeServerStatus` payload assertions.
- APIs covered: `VolumeServerStatus` now validates presence of `State` and `MemoryStatus` (including non-zero goroutine count), in addition to version/disk payload checks.
- Profiles covered: P1.
- Gaps introduced/remaining: heartbeat-disabled and stopping-state transitions are still exercised indirectly rather than in a dedicated status-payload transition test.
- Commit: `374411418`
- Date: 2026-02-12
- Change: Added gRPC `BatchDelete` chunk-manifest rejection coverage.
- APIs covered: `BatchDelete` result status/error path for chunk-manifest needles (`406`, `ChunkManifest` message) and non-deletion parity after rejection.
- Profiles covered: P1.
- Gaps introduced/remaining: EC-backed `BatchDelete` positive path still pending dedicated EC fixture setup.
- Commit: `326be22a9`
- Date: 2026-02-12
- Change: Added gRPC `Query` cookie-mismatch branch parity coverage.
- APIs covered: `Query` behavior when fid id exists but cookie mismatches; verified current EOF/no-record stream outcome.
- Profiles covered: P1.
- Gaps introduced/remaining: CSV parsing behavior beyond current no-output path remains pending.
- Commit: `2aaf0a339`
- Date: 2026-02-12
- Change: Added positive gRPC `Ping` coverage for master targets.
- APIs covered: `Ping` success path for `target_type=master` with non-zero remote timestamp and valid timing envelope.
- Profiles covered: P1.
- Gaps introduced/remaining: positive filer-target ping path still requires a filer fixture in the integration harness.
- Commit: `fa5cad6dc`
- Date: 2026-02-12
- Change: Expanded HTTP conditional-header parity for `HEAD`.
- APIs covered: `HEAD` with `If-None-Match` now verifies `304` behavior and empty-body semantics.
- Profiles covered: P1.
- Gaps introduced/remaining: explicit `HEAD` + `If-Modified-Since` parity remains expandable.
- Commit: `9984f2ec4`
- Date: 2026-02-12
- Change: Added HTTP `HEAD` + `If-Modified-Since` conditional parity coverage.
- APIs covered: `HEAD` conditional path returning `304` with empty-body semantics when `If-Modified-Since` matches Last-Modified.
- Profiles covered: P1.
- Gaps introduced/remaining: deeper conditional-header combinations (`If-None-Match` + `If-Modified-Since` precedence) remain expandable.
- Commit: `e87563a3c`
- Date: 2026-02-12
- Change: Expanded split-port unsupported-method matrix with `CONNECT` parity coverage.
- APIs covered: admin/public behavior for `CONNECT` (`400` on admin, passthrough `200` on public) with post-call data-integrity verification.
- Profiles covered: P2.
- Gaps introduced/remaining: unsupported-method parity now covers `PATCH`, `TRACE`, `PROPFIND`, and `CONNECT`; additional uncommon verbs can still be sampled as needed.
- Commit: `2a893d10d`
- Date: 2026-02-12
- Change: Added explicit CORS `Access-Control-Allow-Headers` assertions for `OPTIONS`.
- APIs covered: admin/public `OPTIONS` now verify `Access-Control-Allow-Headers: *` in addition to allowed-method matrices.
- Profiles covered: P2.
- Gaps introduced/remaining: CORS method/header semantics are now covered for baseline split-port flows.
- Commit: `6fcb9fa9c`
- Date: 2026-02-12
- Change: Added dual-volume integration harness and read-mode matrix tests for missing-local volume behavior.
- APIs covered: HTTP read path when volume is missing locally across `readMode=proxy` (forward success), `readMode=redirect` (`301` + `proxied=true`), and `readMode=local` (`404`).
- Profiles covered: custom P1-derived profiles with `ReadMode` overrides.
- Gaps introduced/remaining: throttling-specific proxy fallback (`checkDownloadLimit` replica path) is still pending targeted pressure setup.
- Commits: `74b04a3f8`, `70ce0c8b8`
- Date: 2026-02-12
- Change: Added HTTP download-throttling replica fallback coverage under over-limit pressure.
- APIs covered: `checkDownloadLimit` replica-proxy branch (`download over limit + replica available -> proxy fallback`) with replicated dual-node setup.
- Profiles covered: P8-derived profile (`readMode=proxy`) with dual volume servers.
- Gaps introduced/remaining: cancellation branch (`499`) for download-limit waiting remains pending.
- Commit: `316cfb7a3`
- Date: 2026-02-12
- Change: Expanded missing-local deleted-read parity across proxy and redirect modes.
- APIs covered: `readDeleted=true` behavior from non-owning servers in `readMode=proxy` (forwarded success) and `readMode=redirect` (redirect query-drop parity leading to `404` on follow).
- Profiles covered: custom P1-derived profiles with `ReadMode` overrides.
- Gaps introduced/remaining: explicit proxied-loop edge behavior remains pending dedicated setup.
- Commit: `0164a383d`
- Date: 2026-02-12
- Change: Added filer-enabled harness and positive gRPC `Ping` coverage for filer targets.
- APIs covered: `Ping` success path for `target_type=filer` with non-zero remote timestamp and valid timing envelope.
- Profiles covered: P1 (single volume + filer auxiliary process).
- Gaps introduced/remaining: no additional ping target-type gaps remain in current harness scope.
- Commits: `5f09d86a8`, `2fc1dde3f`
- Date: 2026-02-12
- Change: Added download-limit proxied-loop guard coverage.
- APIs covered: over-limit download path with `proxied=true` now verifies replica fallback is skipped and timeout returns `429`.
- Profiles covered: P8-derived profile (`readMode=proxy`) with dual volume servers.
- Gaps introduced/remaining: explicit cancellation (`499`) branch for wait loops remains difficult to assert over HTTP transport semantics.
- Commit: `6d532eddc`
- Date: 2026-02-12
- Change: Added explicit no-limit throttling coverage for baseline profile.
- APIs covered: upload/download limit-disabled branches (`concurrent*Limit=0`) under concurrent pressure, verifying requests proceed (`200`/`201`) without throttling.
- Profiles covered: P1.
- Gaps introduced/remaining: cancellation (`499`) path remains pending due client-transport observability constraints.
- Commit: `2cd9a9c6f`
- Date: 2026-02-12
- Change: Added gRPC `VolumeServerLeave` idempotence coverage.
- APIs covered: repeated `VolumeServerLeave` calls (already-stopped heartbeat path) with persistent `healthz=503` verification.
- Profiles covered: P1.
- Gaps introduced/remaining: none for leave semantics in current harness.
- Commit: `0fd666916`
- Date: 2026-02-12
- Change: Expanded redirect read-mode query handling coverage for collection-aware redirects.
- APIs covered: non-owning redirect path now verifies `collection` query parameter preservation in `Location` alongside `proxied=true`.
- Profiles covered: P1-derived profile with `ReadMode=redirect` using dual volume servers.
- Gaps introduced/remaining: redirect branch currently preserves only `collection`; broader query propagation is intentionally untested for parity with current behavior.
- Commit: `ad287b392`
- Date: 2026-02-12
- Change: Tightened HTTP admin endpoint header parity checks.
- APIs covered: `/status` and `/healthz` now assert `Server` header format (`SeaweedFS Volume ...`) in addition to status and payload checks.
- Profiles covered: P1.
- Gaps introduced/remaining: none for baseline admin header checks.
- Commit: `cad34314b`
- Date: 2026-02-12
- Change: Expanded admin middleware parity checks for request-id propagation.
- APIs covered: `/healthz` now explicitly verifies request-id echo behavior via `x-amz-request-id` response header.
- Profiles covered: P1.
- Gaps introduced/remaining: none for request-id propagation on covered admin endpoints.
- Commit: `e0268a5b7`
- Date: 2026-02-12
- Change: Added over-limit invalid-vid branch coverage in download throttling proxy path.
- APIs covered: `checkDownloadLimit` -> `tryProxyToReplica` invalid volume-id parse path now explicitly verified as `400` under over-limit pressure.
- Profiles covered: P8.
- Gaps introduced/remaining: cancellation (`499`) branch remains pending due client-side transport observability limits.
- Commit: `b4984b335`
- Date: 2026-02-12
- Change: Expanded static-resource coverage to split public-port topology.
- APIs covered: public-port static endpoints (`/favicon.ico`, `/seaweedfsstatic/seaweed50x50.png`) under P2.
- Profiles covered: P2.
- Gaps introduced/remaining: static asset baseline coverage is now present for both admin and public ports.
- Commit: `e4c329811`
- Date: 2026-02-12
- Change: Added split public-port `HEAD` method parity coverage.
- APIs covered: public-port `HEAD` read behavior (`200`, content-length parity, empty-body semantics) for existing files.
- Profiles covered: P2.
- Gaps introduced/remaining: none for baseline public-port `GET/HEAD/OPTIONS` method coverage.
- Commit: `127c43b1a`
- Date: 2026-02-12
- Change: Added throttling wait-then-proceed branch coverage for both upload and download paths.
- APIs covered: over-limit `wait then proceed` behavior (`waitForUploadSlot` and `waitForDownloadSlot`) when in-flight pressure is released before timeout.
- Profiles covered: P8.
- Gaps introduced/remaining: explicit cancellation (`499`) path remains pending due client-side transport observability limits.
- Commit: `f7b362a2a`
- Date: 2026-02-12
- Change: Added HTTP read cookie-mismatch parity coverage.
- APIs covered: `GET` and `HEAD` wrong-cookie reads now explicitly verify `404` not-found semantics.
- Profiles covered: P1.
- Gaps introduced/remaining: internal read-failure (`500`) branch remains fault-injection dependent.
- Commit: `8fc192827`
- Date: 2026-02-12
- Change: Added throttling timeout-recovery coverage to validate in-flight counter release behavior.
- APIs covered: upload/download timeout (`429`) scenarios followed by successful recovery requests after pressure release.
- Profiles covered: P8.
- Gaps introduced/remaining: explicit cancellation (`499`) path remains pending due client-side transport observability limits.
- Commit: `3214972fa`
- Date: 2026-02-12
- Change: Added positive erasure-coding lifecycle coverage for generate/mount/info/unmount flows.
- APIs covered: `VolumeEcShardsGenerate` success, `VolumeEcShardsMount` success, `VolumeEcShardsInfo` success after mount, and expected not-found after unmount.
- Profiles covered: P1.
- Gaps introduced/remaining: multi-shard, rebuild/copy/blob-delete/to-volume positive permutations remain for broader EC matrix completeness.
- Commit: `80dce7c5b`
- Date: 2026-02-12
- Change: Expanded EC positive-path coverage for shard-read and blob-delete behavior.
- APIs covered: `VolumeEcShardRead` success, `VolumeEcBlobDelete` first-delete + idempotent second-delete, and `VolumeEcShardRead` deleted-marker (`IsDeleted`) path.
- Profiles covered: P1.
- Gaps introduced/remaining: EC copy/rebuild/to-volume multi-node success permutations remain for broader matrix completeness.
- Commit: `1f405f52d`
- Date: 2026-02-13
- Change: Added EC rebuild and `ShardsToVolume` branch coverage for missing-shard and no-live-entry conditions.
- APIs covered: `VolumeEcShardsRebuild` (missing-shard regenerate path), `VolumeEcShardsToVolume` (missing data shard error and no-live-entries `FailedPrecondition` path).
- Profiles covered: P1.
- Gaps introduced/remaining: `VolumeEcShardsToVolume` full success conversion path and EC copy/rebuild multi-node permutations remain pending.
- Commit: `e8c449c16`
- Date: 2026-02-13
- Change: Added positive `VolumeEcShardsToVolume` conversion coverage with post-conversion read verification.
- APIs covered: `VolumeEcShardsToVolume` success path (mounted data shards -> convert -> readable needle payload parity).
- Profiles covered: P1.
- Gaps introduced/remaining: EC multi-node shard-copy/rebuild permutations and last-shard cleanup edge cases remain pending.
- Commit: `6d223338a`
- Date: 2026-02-13
- Change: Added EC file-stream integration coverage for `ReceiveFile` and `CopyFile`.
- APIs covered: `ReceiveFile` success with `is_ec_volume=true`, and `CopyFile` EC missing-source behavior with `ignore_source_file_not_found=true/false`.
- Profiles covered: P1.
- Gaps introduced/remaining: multi-node EC shard copy/rebuild permutations and last-shard cleanup edge assertions remain pending.
- Commit: `a78290d56`
- Date: 2026-02-13
- Change: Added EC last-shard deletion cleanup coverage.
- APIs covered: `VolumeEcShardsDelete` branch where deleting the final shard set removes EC index files (`.ecx` cleanup), validated via EC `CopyFile` pre/post behavior.
- Profiles covered: P1.
- Gaps introduced/remaining: EC multi-node shard copy/rebuild permutations remain pending for broader distributed parity.
- Commit: `e8ef35346`
- Date: 2026-02-13
- Change: Added dual-node `VolumeCopy` integration success coverage.
- APIs covered: `VolumeCopy` full happy path (source status read, stream copy, destination mount) with post-copy HTTP read parity from destination node.
- Profiles covered: P4-derived dual-volume topology.
- Gaps introduced/remaining: additional distributed copy branches (e.g., existing-destination overwrite and remote-dat variations) remain pending.
- Commit: `7538653ad`
- Date: 2026-02-13
- Change: Added dual-node `VolumeCopy` overwrite coverage when destination volume already exists.
- APIs covered: existing-destination delete-before-copy branch, with pre-copy destination payload assertion and post-copy source parity validation.
- Profiles covered: P4-derived dual-volume topology.
- Gaps introduced/remaining: remote-dat-file and no-space source-copy branches remain pending.
- Commit: `2d49019e9`
- Date: 2026-02-13
- Change: Added HTTP write error-path integration coverage.
- APIs covered: `POST` invalid vid/fid parse rejections (`400`), malformed multipart form parse failure (`400`), and `Content-MD5` mismatch validation failure (`400`).
- Profiles covered: P1.
- Gaps introduced/remaining: file-size limit rejection and replicated-write failure branches remain pending for write-path breadth.
- Commit: `046390e54`
- Date: 2026-02-13
- Change: Added HTTP conditional-header precedence coverage.
- APIs covered: `GET` with combined `If-Modified-Since` + mismatched `If-None-Match` (`304` by current precedence), plus invalid `If-Modified-Since` fallback behavior (`200` body path).
- Profiles covered: P1.
- Gaps introduced/remaining: range-sum oversized-request behavior and image transform/chunk-manifest read branches remain pending.
- Commit: `31d59f0b8`
- Date: 2026-02-13
- Change: Added HTTP oversized-multi-range guard coverage.
- APIs covered: `GET` `Range` requests where combined ranges exceed total object size (`sumRangesSize > totalSize`) with current parity response (`200` + empty body).
- Profiles covered: P1.
- Gaps introduced/remaining: image resize/crop and chunk-manifest read branches remain pending.
- Commit: `612e5f61c`
- Date: 2026-02-13
- Change: Added HTTP image transformation integration coverage.
- APIs covered: read-path image resize (`width`,`height`) and crop (`crop_*`) branches with decoded output-dimension assertions.
- Profiles covered: P1.
- Gaps introduced/remaining: chunk-manifest read/`cm=false` parity and compressed-content encoding matrix remain pending.
- Commit: `d68803ecc`
- Date: 2026-02-13
- Change: Added HTTP chunk-manifest integration coverage for expansion and bypass.
- APIs covered: chunk-manifest auto-expansion read path (`X-File-Store: chunked`) and `cm=false` raw-manifest bypass parity.
- Profiles covered: P1.
- Gaps introduced/remaining: compressed-content encoding matrix and some write/delete failure-injection branches remain pending.
- Commit: `8ecf427c4`
- Date: 2026-02-13
- Change: Added HTTP compressed-read encoding matrix coverage.
- APIs covered: compressed needle read branch with `Accept-Encoding=gzip` passthrough (`Content-Encoding: gzip`) and `Accept-Encoding=identity` decompression parity.
- Profiles covered: P1.
- Gaps introduced/remaining: write/delete failure-injection and request-cancel (`499`) paths remain pending due transport/fault observability constraints.
- Commit: `e17604c57`
- Date: 2026-02-13
- Change: Added dual-node gRPC tail receiver success-path coverage.
- APIs covered: `VolumeTailReceiver` end-to-end replication from source server stream into destination volume, with post-tail HTTP payload parity verification.
- Profiles covered: P4-derived dual-volume topology.
- Gaps introduced/remaining: sender large-needle chunking specifics and transport-interruption branches remain pending.
- Commit: `3989bc6e5`
- Date: 2026-02-13
- Change: Added gRPC tail sender large-needle chunking coverage.
- APIs covered: `VolumeTailSender` stream chunk-splitting path for oversized needle bodies (multiple chunks with non-last and final `IsLastChunk=true` markers).
- Profiles covered: P1.
- Gaps introduced/remaining: sender/receiver transport interruption branches remain pending.
- Commit: `514c05131`
- Date: 2026-02-13
- Change: Added EC-backed `VolumeNeedleStatus` integration coverage.
- APIs covered: `VolumeNeedleStatus` EC execution path (normal volume unmounted + EC shards mounted), including missing-needle error behavior.
- Profiles covered: P1.
- Gaps introduced/remaining: transport-interruption and deep fault-injection branches remain pending.
- Commit: `4ef666791`
- Date: 2026-02-13
- Change: Added dual-node EC shard copy success coverage.
- APIs covered: `VolumeEcShardsCopy` positive path from source peer (including `copy_ecx_file`/`copy_vif_file`) with copied artifact verification via EC `CopyFile` on destination.
- Profiles covered: P4-derived dual-volume topology.
- Gaps introduced/remaining: EC rebuild/copy distributed failure injection permutations remain pending.
- Commit: `c9f6710c2`
- Date: 2026-02-13
- Change: Added HTTP chunk-manifest delete cleanup coverage.
- APIs covered: chunk-manifest delete success path with child-chunk deletion verification and expected delete response size parity.
- Profiles covered: P1.
- Gaps introduced/remaining: chunk-manifest delete failure-injection branch remains pending.
- Commit: `c6df98a02`
- Date: 2026-02-13
- Change: Added HTTP chunk-manifest delete failure-path coverage.
- APIs covered: chunk-manifest child-delete error branch (`500`) and non-deletion parity of manifest metadata after failed delete.
- Profiles covered: P1.
- Gaps introduced/remaining: request-cancel (`499`) and deep transport-interruption branches remain pending.
- Commit: `38a1f4f4f`
- Date: 2026-02-13
- Change: Added EC shard-copy source-unavailable error coverage.
- APIs covered: `VolumeEcShardsCopy` network/source-unreachable failure path with wrapped RPC error propagation.
- Profiles covered: P1.
- Gaps introduced/remaining: `499` cancellation and transport-interruption branches remain pending.
- Commit: `d1e5f390a`
- Date: 2026-02-15
- Change: Added Rust volume-server migration bootstrap wiring.
- APIs covered: Harness now supports Go master + selectable volume binary (`VOLUME_SERVER_IMPL=rust` or `VOLUME_SERVER_BINARY`), with Rust-mode smoke coverage for representative HTTP/gRPC integration tests.
- Profiles covered: P1 smoke and default Go matrix unchanged.
- Gaps introduced/remaining: native Rust handler implementations are tracked in `rust/volume_server/DEV_PLAN.md`; current Rust mode is a compatibility launcher phase.
- Commit: `7beab85c2`, `880c2e1da`, `63d08e8a9`, `d402573ea`
- Date: 2026-02-15
- Change: Validated Rust-mode compatibility path with full integration suites.
- APIs covered: full `/test/volume_server/http` and `/test/volume_server/grpc` suites executed successfully with `VOLUME_SERVER_IMPL=rust`.
- Profiles covered: existing integration matrix in Rust launcher mode.
- Gaps introduced/remaining: native Rust endpoint and storage/RPC implementation remains pending; current mode delegates execution to Go volume server.
- Commit: `6ce4d7ede`
- Date: 2026-02-15
- Change: Added Rust proxy-supervision launcher mode and validated all volume-server integration suites in proxy mode.
- APIs covered: full `/test/volume_server/http` and `/test/volume_server/grpc` suites executed successfully with `VOLUME_SERVER_IMPL=rust` and `VOLUME_SERVER_RUST_MODE=proxy`.
- Profiles covered: existing integration matrix in Rust proxy launcher mode.
- Gaps introduced/remaining: native Rust endpoint/storage/RPC logic remains pending; current proxy mode still delegates backend handlers to Go.
- Commit: `a7f50d23b`
- Date: 2026-02-15
- Change: Expanded GitHub CI Rust smoke job to run both launcher modes (`exec` and `proxy`).
- APIs covered: representative HTTP/gRPC smoke flows now validated in CI for both Rust launcher execution paths.
- Profiles covered: CI smoke profile for P1 representative calls.
- Gaps introduced/remaining: CI still runs Rust mode as smoke scope; full-suite Rust-mode CI remains optional due runtime cost.
- Commit: `548b3d9a3`
- Date: 2026-02-15
- Change: Added JWT UI override integration coverage with explicit `access.ui=true` profile support.
- APIs covered: `/ui/index.html` behavior under JWT profile now verifies both default auth-gated path (`401`) and explicit UI-enable override path (`200` with rendered UI).
- Profiles covered: P3 and P3+`access.ui=true`.
- Gaps introduced/remaining: UI exposure behavior under JWT profiles is now covered for both secured and override branches.
- Commit: `de974c05d`
- Date: 2026-02-15
- Change: Added oversized upload integration coverage using explicit `-fileSizeLimitMB` profile configuration.
- APIs covered: HTTP write path now verifies payloads larger than configured file-size limit are rejected (`400`) with limit-related error context.
- Profiles covered: P1-derived profile with `FileSizeLimitMB=1`.
- Gaps introduced/remaining: file-size limit rejection branch is now covered; replicate-write failure and cancellation (`499`) branches remain pending.
- Commit: `4d61cbdee`
- Date: 2026-02-15
- Change: Added gRPC EC-only metadata-read unsupported-path coverage.
- APIs covered: `ReadNeedleMeta` now verifies the explicit unsupported branch when a volume is unmounted and only EC shards are mounted.
- Profiles covered: P1 with EC shard generation/mount lifecycle setup.
- Gaps introduced/remaining: low-level read metadata fault-injection and transport interruption branches remain pending.
- Commit: `37bf9b5eb`
- Date: 2026-02-15
- Change: Added deterministic replicated-write failure coverage for unmet replication requirements.
- APIs covered: HTTP write path now verifies replication error handling (`500`) and no-local-commit outcome (`404` on follow-up read) when volume replication is configured (`001`) but replica set cannot be satisfied.
- Profiles covered: P1-derived single-node profile with per-volume replication override.
- Gaps introduced/remaining: replicated-write failure branch is now covered; cancellation (`499`) and deeper transport fault-injection branches remain pending.
- Commit: `4835d3443`
- Date: 2026-02-15
- Change: Added EC-backed `BatchDelete` positive-path integration coverage.
- APIs covered: `BatchDelete` now validates successful EC-needle deletion (`202`) with post-delete `VolumeEcShardRead` deleted-marker verification (`IsDeleted=true`).
- Profiles covered: P1 with EC shard generate/mount lifecycle; includes test-local gRPC offset proxy for EC internal dial-path parity.
- Gaps introduced/remaining: EC `BatchDelete` success branch is now covered; deeper distributed failure-injection permutations remain pending.
- Commit: `1bb40b6bc`
- Date: 2026-02-15
- Change: Expanded HTTP conditional-header matrix for `HEAD` requests with combined header scenarios.
- APIs covered: `HEAD` now verifies `If-Modified-Since` precedence over mismatched `If-None-Match`, and `If-None-Match` precedence when IMS is stale but ETag matches.
- Profiles covered: P1.
- Gaps introduced/remaining: combined conditional-header precedence paths for `HEAD`/`GET` are now explicitly covered.
- Commit: `ed23e290f`
- Date: 2026-02-15
- Change: Added multi-volume success-stream coverage for `ReadAllNeedles`.
- APIs covered: `ReadAllNeedles` now verifies happy-path streaming across two existing volumes in one request, with per-volume payload validation.
- Profiles covered: P1.
- Gaps introduced/remaining: multi-volume stream boundary coverage is now present for successful reads; transport interruption branches remain pending.
- Commit: `ab95a6ef1`
- Date: 2026-02-15
- Change: Expanded split-port unsupported HTTP method matrix with `MKCOL` coverage.
- APIs covered: admin/public parity for `MKCOL` (`400` on admin, passthrough `200` on public) with post-call data-integrity verification.
- Profiles covered: P2.
- Gaps introduced/remaining: unsupported-method sampling now covers `PATCH`, `TRACE`, `PROPFIND`, `CONNECT`, and `MKCOL`; cancellation/transport fault paths remain the main unaddressed area.
- Commit: `2ab30900d`
- Date: 2026-02-15
- Change: Hardened framework port allocation to keep volume ports within `10000..55535`.
- APIs covered: test harness now guarantees valid `admin+10000` gRPC offset ranges, eliminating EC batch-delete flake scenarios that rely on offset dialing.
- Profiles covered: all profiles using shared framework port allocation.
- Gaps introduced/remaining: no new API gaps; transport cancellation/fault-injection branches remain the primary uncovered area.
- Commit: `90e82b15c`
- Date: 2026-02-15
- Change: Re-validated full Rust proxy-mode integration suite after latest HTTP/gRPC coverage additions and framework hardening.
- APIs covered: full `/test/volume_server/http` and `/test/volume_server/grpc` packages.
- Profiles covered: existing matrix in Rust proxy launcher mode.
- Gaps introduced/remaining: native Rust endpoint/storage/RPC implementation remains pending (current Rust mode still delegates to Go backend handlers).
- Commit: `6bb9d8bac`
- Date: 2026-02-15
- Change: Added tail sender stream-cancellation interruption coverage.
- APIs covered: `VolumeTailSender` now verifies client-side context cancellation behavior (`codes.Canceled`) after stream start/heartbeat.
- Profiles covered: P1.
- Gaps introduced/remaining: tail transport interruption coverage is now partially closed; receiver-side interruption and deeper network fault injection remain pending.
- Commit: `27a80f760`
- Date: 2026-02-15
- Change: Added receiver-side tail stream interruption coverage for unavailable source node.
- APIs covered: `VolumeTailReceiver` now verifies source connect/dial failure branch when `SourceVolumeServer` is unreachable.
- Profiles covered: P1.
- Gaps introduced/remaining: both sender and receiver transport interruption branches are now covered at integration level; deeper injected network faults remain pending.
- Commit: `a5864c3eb`
- Date: 2026-02-15
- Change: Expanded query CSV matrix with explicit CSV-payload parity coverage.
- APIs covered: `Query` now verifies current CSV-input behavior (no streamed rows / immediate EOF) even when source needle content is valid CSV text.
- Profiles covered: P1.
- Gaps introduced/remaining: CSV parsing/selection implementation still absent in current server behavior; integration parity now locks the current no-output semantics for both JSON and CSV payload shapes.
- Commit: `a12dd5f8d`
- Date: 2026-02-15
- Change: Expanded ping unreachable-target matrix with volume-server target coverage.
- APIs covered: `Ping` now explicitly verifies unreachable-target error wrapping for `target_type=volumeServer`, alongside existing master/filer variants.
- Profiles covered: P1.
- Gaps introduced/remaining: ping target-type matrix is covered for success and unreachable branches across master/filer/volume-server.
- Commit: `b9fbb85af`
- Date: 2026-02-15
- Change: Expanded deleted-read HTTP matrix with `HEAD` parity coverage.
- APIs covered: `HEAD` with `readDeleted=true` now validates current behavior (`200`, empty body, payload-size `Content-Length`) after delete.
- Profiles covered: P1.
- Gaps introduced/remaining: deleted-read parity now covers both `GET` and `HEAD` semantics on local-volume path.
- Commit: `cc80ad364`
- Date: 2026-02-16
- Change: Shifted planning priority to native Rust implementation parity.
- APIs covered: no new API additions in this plan entry; integration suite remains the validation gate.
- Profiles covered: unchanged.
- Gaps introduced/remaining: primary remaining gap is native Rust handler/storage/RPC implementation replacing Go backend delegation.
- Commit: `14c863dbf`
- Date: 2026-02-16
- Change: Added Rust launcher `native` mode bootstrap, made it the default Rust launcher mode, and expanded CI Rust smoke matrix coverage to include `native`.
- APIs covered: full `/test/volume_server/http` and `/test/volume_server/grpc` packages re-validated in `VOLUME_SERVER_RUST_MODE=native`; default Rust launcher path (`VOLUME_SERVER_IMPL=rust`) smoke-validated for HTTP and gRPC control tests.
- Profiles covered: existing HTTP/gRPC matrix in native launcher mode; default-mode smoke checks on P1 control flows.
- Gaps introduced/remaining: native Rust API/storage/RPC handlers still pending; current `native` mode remains a delegation bootstrap while parity replacement proceeds.
- Commit: `70ddbee37`, `61befd10f`, `2e65966c0`
- Date: 2026-02-16
- Change: Implemented first native Rust HTTP control handlers in `native` mode for `/status` and `/healthz` (admin listener path), with proxy fallback retained for remaining endpoints.
- APIs covered: `/status` and `/healthz` now served by Rust-native code path in `VOLUME_SERVER_RUST_MODE=native`; full HTTP and gRPC integration suites re-validated.
- Profiles covered: full existing HTTP/gRPC matrix under native mode.
- Gaps introduced/remaining: gRPC control/data APIs and most HTTP data/static/auth paths remain delegated and require incremental native replacement.
- Commit: `7e6e0261a`
- Date: 2026-02-16
- Change: Implemented native Rust HTTP `OPTIONS` handling for admin/public listeners in `VOLUME_SERVER_RUST_MODE=native`.
- APIs covered: admin/public `OPTIONS` method allow-list and CORS origin handling now served from Rust-native path; full HTTP and gRPC packages re-validated.
- Profiles covered: P2 split-port CORS/OPTIONS profiles plus full existing matrix in native mode.
- Gaps introduced/remaining: static/UI/auth and data-path HTTP handlers, plus gRPC control/data/stream handlers, remain delegated and pending native replacement.
- Commit: `fbff2cb39`
- Date: 2026-02-16
- Change: Implemented broader native Rust HTTP surface in `native` mode:
- `/ui/index.html` auth-gating parity (JWT + access.ui handling)
- static asset paths (`/favicon.ico`, `/seaweedfsstatic/*`)
- public non-read method no-op parity (`200`) and admin unsupported-method rejection parity (`400`)
- APIs covered: UI/static/admin/public control-surface behavior now served by Rust-native path; full `/test/volume_server/http` and `/test/volume_server/grpc` packages re-validated.
- Profiles covered: P1/P2/P3 variants touched by UI/static/CORS/method behavior, plus full matrix in native mode.
- Gaps introduced/remaining: HTTP data-path handlers and all gRPC handlers remain delegated and still require native replacement.
- Commit: `23e4497b2`
- Date: 2026-02-16
- Change: Improved native Rust control-path parity for health/status and request-target parsing.
- APIs covered: native `/healthz` now mirrors backend service health transitions (`200`/`503`) and native route matching now handles absolute-form HTTP request targets before path dispatch.
- Profiles covered: full existing HTTP/gRPC integration matrix in native mode (`VOLUME_SERVER_IMPL=rust`, `VOLUME_SERVER_RUST_MODE=native`).
- Gaps introduced/remaining: core HTTP data handlers and all gRPC RPC handlers are still delegated and remain the primary native implementation gap.
- Commit: `d6ff6ed6d`
- Date: 2026-02-16
- Change: Added Rust-native malformed fid-route validation ahead of delegated data handlers.
- APIs covered: GET/HEAD/POST/PUT fid-shaped paths now return native `400` for invalid vid/fid tokens (including invalid-read and invalid-write path variants) while valid routes continue through delegated storage handlers.
- Profiles covered: full existing HTTP/gRPC integration matrix in native mode, plus targeted invalid-path parity runs.
- Gaps introduced/remaining: data-path success branches and all gRPC handler bodies remain delegated; native replacement work continues on those core execution paths.
- Commit: `1ce0174b2`
- Date: 2026-02-16
- Change: Added Rust-native write error prevalidation for delegated fid routes.
- APIs covered: native path now rejects malformed multipart boundary requests, `Content-MD5` writes, and over-limit `Content-Length` writes (using `-fileSizeLimitMB`) with `400` parity behavior before delegation.
- Profiles covered: P1 default and P1 with explicit file-size limit profile, plus full existing HTTP/gRPC native-mode matrix revalidation.
- Gaps introduced/remaining: positive write/read/delete data handlers and all gRPC handler bodies are still delegated; native implementation continues incrementally.
- Commit: `94cefd6f4`
- Date: 2026-02-16
- Change: Broadened Rust-native malformed-fid handling to slash-form read/write URL shapes with reserved-route exclusions.
- APIs covered: `/{vid}/{fid}` and `/{vid}/{fid}/{filename}` malformed cases now hit native `400` validation path, while `/status`, `/healthz`, `/ui/index.html`, `/stats/*`, and static asset routes remain excluded from fid parsing.
- Profiles covered: full existing HTTP/gRPC native-mode matrix, plus targeted admin/read-path malformed-slash validation run.
- Gaps introduced/remaining: successful data-path read/write/delete handlers and all gRPC method bodies remain delegated and are still the primary native implementation gap.
- Commit: `e66983e9b`