* docs(volume_server): add integration test development plan * test(volume_server): add integration harness and profile matrix * test(volume_server/http): add admin and options integration coverage * test(volume_server/grpc): add state and status integration coverage * test(volume_server): auto-build weed binary and harden cluster startup * test(volume_server/http): add upload read range head delete coverage * test(volume_server/grpc): expand admin lifecycle and state coverage * docs(volume_server): update progress tracker for implemented tests * test(volume_server/http): cover if-none-match and invalid-range branches * test(volume_server/grpc): add batch delete integration coverage * docs(volume_server): log latest HTTP and gRPC test coverage * ci(volume_server): run volume server integration tests in github actions * test(volume_server/grpc): add needle status configure ping and leave coverage * docs(volume_server): record additional grpc coverage progress * test(volume_server/grpc): add vacuum integration coverage * docs(volume_server): record vacuum test coverage progress * test(volume_server/grpc): add read and write needle blob error-path coverage * docs(volume_server): record data rw grpc coverage progress * test(volume_server/http): add jwt auth integration coverage * test(volume_server/grpc): add sync copy and stream error-path coverage * docs(volume_server): record jwt and sync/copy test coverage * test(volume_server/grpc): add scrub and query integration coverage * test(volume_server/grpc): add volume tail sender and receiver coverage * docs(volume_server): record scrub query and tail test progress * test(volume_server/grpc): add readonly writable and collection lifecycle coverage * test(volume_server/http): add public-port cors and method parity coverage * test(volume_server/grpc): add blob meta and read-all success path coverage * test(volume_server/grpc): expand scrub and query variation coverage * test(volume_server/grpc): add tiering and remote fetch error-path coverage * test(volume_server/http): add unchanged write and delete edge-case coverage * test(volume_server/grpc): add ping unknown and unreachable target coverage * test(volume_server/grpc): add volume delete only-empty variation coverage * test(volume_server/http): add jwt fid-mismatch auth coverage * test(volume_server/grpc): add scrub ec auto-select empty coverage * test(volume_server/grpc): stabilize ping timestamp assertion * docs(volume_server): update integration coverage progress log * test(volume_server/grpc): add tier remote backend and config variation coverage * docs(volume_server): record tier remote variation progress * test(volume_server/grpc): add incremental copy and receive-file protocol coverage * test(volume_server/http): add read path shape and if-modified-since coverage * test(volume_server/grpc): add copy-file compaction and receive-file success coverage * test(volume_server/http): add passthrough headers and static asset coverage * test(volume_server/grpc): add ping filer unreachable coverage * docs(volume_server): record copy receive and http variant progress * test(volume_server/grpc): add erasure coding maintenance and missing-path coverage * docs(volume_server): record initial erasure coding rpc coverage * test(volume_server/http): add multi-range multipart response coverage * docs(volume_server): record multi-range http coverage progress * test(volume_server/grpc): add query empty-stripe no-match coverage * docs(volume_server): record query no-match stream behavior coverage * test(volume_server/http): add upload throttling timeout and replicate bypass coverage * docs(volume_server): record upload throttling coverage progress * test(volume_server/http): add download throttling timeout coverage * docs(volume_server): record download throttling coverage progress * test(volume_server/http): add jwt wrong-cookie fid mismatch coverage * docs(volume_server): record jwt wrong-cookie mismatch coverage * test(volume_server/http): add jwt expired-token rejection coverage * docs(volume_server): record jwt expired-token coverage * test(volume_server/http): add jwt query and cookie transport coverage * docs(volume_server): record jwt token transport coverage * test(volume_server/http): add jwt token-source precedence coverage * docs(volume_server): record jwt token-source precedence coverage * test(volume_server/http): add jwt header-over-cookie precedence coverage * docs(volume_server): record jwt header cookie precedence coverage * test(volume_server/http): add jwt query-over-cookie precedence coverage * docs(volume_server): record jwt query cookie precedence coverage * test(volume_server/grpc): add setstate version mismatch and nil-state coverage * docs(volume_server): record setstate validation coverage * test(volume_server/grpc): add readonly persist-true lifecycle coverage * docs(volume_server): record readonly persist variation coverage * test(volume_server/http): add options origin cors header coverage * docs(volume_server): record options origin cors coverage * test(volume_server/http): add trace unsupported-method parity coverage * docs(volume_server): record trace method parity coverage * test(volume_server/grpc): add batch delete cookie-check variation coverage * docs(volume_server): record batch delete cookie-check coverage * test(volume_server/grpc): add admin lifecycle missing and maintenance variants * docs(volume_server): record admin lifecycle edge-case coverage * test(volume_server/grpc): add mixed batch delete status matrix coverage * docs(volume_server): record mixed batch delete matrix coverage * test(volume_server/http): add jwt-profile ui access gating coverage * docs(volume_server): record jwt ui-gating http coverage * test(volume_server/http): add propfind unsupported-method parity coverage * docs(volume_server): record propfind method parity coverage * test(volume_server/grpc): add volume configure success and rollback-path coverage * docs(volume_server): record volume configure branch coverage * test(volume_server/grpc): add volume needle status missing-path coverage * docs(volume_server): record volume needle status error-path coverage * test(volume_server/http): add readDeleted query behavior coverage * docs(volume_server): record readDeleted http behavior coverage * test(volume_server/http): add delete ts override parity coverage * docs(volume_server): record delete ts parity coverage * test(volume_server/grpc): add invalid blob/meta offset coverage * docs(volume_server): record invalid blob/meta offset coverage * test(volume_server/grpc): add read-all mixed volume abort coverage * docs(volume_server): record read-all mixed-volume abort coverage * test(volume_server/http): assert head response body parity * docs(volume_server): record head body parity assertion * test(volume_server/grpc): assert status state and memory payload completeness * docs(volume_server): record volume server status payload coverage * test(volume_server/grpc): add batch delete chunk-manifest rejection coverage * docs(volume_server): record batch delete chunk-manifest coverage * test(volume_server/grpc): add query cookie-mismatch eof parity coverage * docs(volume_server): record query cookie-mismatch parity coverage * test(volume_server/grpc): add ping master success target coverage * docs(volume_server): record ping master success coverage * test(volume_server/http): add head if-none-match conditional parity * docs(volume_server): record head if-none-match parity coverage * test(volume_server/http): add head if-modified-since parity coverage * docs(volume_server): record head if-modified-since parity coverage * test(volume_server/http): add connect unsupported-method parity coverage * docs(volume_server): record connect method parity coverage * test(volume_server/http): assert options allow-headers cors parity * docs(volume_server): record options allow-headers coverage * test(volume_server/framework): add dual volume cluster integration harness * test(volume_server/http): add missing-local read mode proxy redirect local coverage * docs(volume_server): record read mode missing-local matrix coverage * test(volume_server/http): add download over-limit replica proxy fallback coverage * docs(volume_server): record download replica fallback coverage * test(volume_server/http): add missing-local readDeleted proxy redirect parity coverage * docs(volume_server): record missing-local readDeleted mode coverage * test(volume_server/framework): add single-volume cluster with filer harness * test(volume_server/grpc): add ping filer success target coverage * docs(volume_server): record ping filer success coverage * test(volume_server/http): add proxied-loop guard download timeout coverage * docs(volume_server): record proxied-loop download coverage * test(volume_server/http): add disabled upload and download limit coverage * docs(volume_server): record disabled throttling path coverage * test(volume_server/grpc): add idempotent volume server leave coverage * docs(volume_server): record leave idempotence coverage * test(volume_server/http): add redirect collection query preservation coverage * docs(volume_server): record redirect collection query coverage * test(volume_server/http): assert admin server headers on status and health * docs(volume_server): record admin server header coverage * test(volume_server/http): assert healthz request-id echo parity * docs(volume_server): record healthz request-id parity coverage * test(volume_server/http): add over-limit invalid-vid download branch coverage * docs(volume_server): record over-limit invalid-vid branch coverage * test(volume_server/http): add public-port static asset coverage * docs(volume_server): record public static endpoint coverage * test(volume_server/http): add public head method parity coverage * docs(volume_server): record public head parity coverage * test(volume_server/http): add throttling wait-then-proceed path coverage * docs(volume_server): record throttling wait-then-proceed coverage * test(volume_server/http): add read cookie-mismatch not-found coverage * docs(volume_server): record read cookie-mismatch coverage * test(volume_server/http): add throttling timeout-recovery coverage * docs(volume_server): record throttling timeout-recovery coverage * test(volume_server/grpc): add ec generate mount info unmount lifecycle coverage * docs(volume_server): record ec positive lifecycle coverage * test(volume_server/grpc): add ec shard read and blob delete lifecycle coverage * docs(volume_server): record ec shard read/blob delete lifecycle coverage * test(volume_server/grpc): add ec rebuild and to-volume error branch coverage * docs(volume_server): record ec rebuild and to-volume branch coverage * test(volume_server/grpc): add ec shards-to-volume success roundtrip coverage * docs(volume_server): record ec shards-to-volume success coverage * test(volume_server/grpc): add ec receive and copy-file missing-source coverage * docs(volume_server): record ec receive and copy-file coverage * test(volume_server/grpc): add ec last-shard delete cleanup coverage * docs(volume_server): record ec last-shard delete cleanup coverage * test(volume_server/grpc): add volume copy success path coverage * docs(volume_server): record volume copy success coverage * test(volume_server/grpc): add volume copy overwrite-destination coverage * docs(volume_server): record volume copy overwrite coverage * test(volume_server/http): add write error-path variant coverage * docs(volume_server): record http write error-path coverage * test(volume_server/http): add conditional header precedence coverage * docs(volume_server): record conditional header precedence coverage * test(volume_server/http): add oversized combined range guard coverage * docs(volume_server): record oversized range guard coverage * test(volume_server/http): add image resize and crop read coverage * docs(volume_server): record image transform coverage * test(volume_server/http): add chunk-manifest expansion and bypass coverage * docs(volume_server): record chunk-manifest read coverage * test(volume_server/http): add compressed read encoding matrix coverage * docs(volume_server): record compressed read matrix coverage * test(volume_server/grpc): add tail receiver source replication coverage * docs(volume_server): record tail receiver replication coverage * test(volume_server/grpc): add tail sender large-needle chunking coverage * docs(volume_server): record tail sender chunking coverage * test(volume_server/grpc): add ec-backed volume needle status coverage * docs(volume_server): record ec-backed needle status coverage * test(volume_server/grpc): add ec shard copy from peer success coverage * docs(volume_server): record ec shard copy success coverage * test(volume_server/http): add chunk-manifest delete child cleanup coverage * docs(volume_server): record chunk-manifest delete cleanup coverage * test(volume_server/http): add chunk-manifest delete failure-path coverage * docs(volume_server): record chunk-manifest delete failure coverage * test(volume_server/grpc): add ec shard copy source-unavailable coverage * docs(volume_server): record ec shard copy source-unavailable coverage * parallel
1130 lines
54 KiB
Markdown
1130 lines
54 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.
|
|
|
|
## 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`
|