Commit d650450
committed
admin: address Claude review on PR #644
Four findings on the follower-side forward client + handler
integration:
- High: PBAdminForwardClient declared opts as `...interface{}`
via `type grpcCallOption = interface{}`, which is incompatible
with the proto-generated *adminForwardClient's
`...grpc.CallOption`. Go interface satisfaction requires exact
variadic element match, so the production bridge would have
failed to compile when assigning pb.NewAdminForwardClient(conn)
to PBAdminForwardClient. Switch to grpc.CallOption (already a
transitive dependency, no new import surface).
- Medium: writeForwardResult re-emitted Content-Type and
Cache-Control but dropped X-Content-Type-Options: nosniff that
writeAdminJSONStatus sets on the leader-direct path. Added
parity. New test
TestDynamoHandler_ForwarderForwardsLeaderResponseSetsNosniff
pins the header.
- Low: missing test for "forwarder configured AND source returns
non-ErrTablesNotLeader". Added
TestDynamoHandler_ForwarderNotInvokedForNonNotLeaderError —
table-driven sweep over already-exists, validation, and
generic error, each confirming the forwarder is never invoked
and the appropriate non-503 status is returned.
- Nit: WithLeaderForwarder's nil semantics differ from
WithLogger's. Added a doc comment explaining the intentional
asymmetry — nil forwarder is a meaningful "disable" state, nil
logger preserves the slog.Default() seed.1 parent a4982a8 commit d650450
4 files changed
Lines changed: 81 additions & 6 deletions
File tree
- internal/admin
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
213 | 213 | | |
214 | 214 | | |
215 | 215 | | |
| 216 | + | |
| 217 | + | |
| 218 | + | |
| 219 | + | |
| 220 | + | |
| 221 | + | |
216 | 222 | | |
217 | 223 | | |
218 | 224 | | |
| |||
468 | 474 | | |
469 | 475 | | |
470 | 476 | | |
| 477 | + | |
| 478 | + | |
| 479 | + | |
| 480 | + | |
| 481 | + | |
| 482 | + | |
471 | 483 | | |
472 | 484 | | |
473 | 485 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
8 | 8 | | |
9 | 9 | | |
10 | 10 | | |
| 11 | + | |
11 | 12 | | |
12 | 13 | | |
13 | 14 | | |
| |||
71 | 72 | | |
72 | 73 | | |
73 | 74 | | |
| 75 | + | |
| 76 | + | |
| 77 | + | |
| 78 | + | |
| 79 | + | |
| 80 | + | |
| 81 | + | |
74 | 82 | | |
75 | | - | |
| 83 | + | |
76 | 84 | | |
77 | 85 | | |
78 | | - | |
79 | | - | |
80 | | - | |
81 | | - | |
82 | 86 | | |
83 | 87 | | |
84 | 88 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
9 | 9 | | |
10 | 10 | | |
11 | 11 | | |
| 12 | + | |
12 | 13 | | |
13 | 14 | | |
14 | 15 | | |
| |||
20 | 21 | | |
21 | 22 | | |
22 | 23 | | |
23 | | - | |
| 24 | + | |
24 | 25 | | |
25 | 26 | | |
26 | 27 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
160 | 160 | | |
161 | 161 | | |
162 | 162 | | |
| 163 | + | |
| 164 | + | |
| 165 | + | |
| 166 | + | |
| 167 | + | |
| 168 | + | |
| 169 | + | |
| 170 | + | |
| 171 | + | |
| 172 | + | |
| 173 | + | |
| 174 | + | |
| 175 | + | |
| 176 | + | |
| 177 | + | |
| 178 | + | |
| 179 | + | |
| 180 | + | |
| 181 | + | |
| 182 | + | |
| 183 | + | |
| 184 | + | |
| 185 | + | |
| 186 | + | |
| 187 | + | |
| 188 | + | |
| 189 | + | |
| 190 | + | |
| 191 | + | |
| 192 | + | |
| 193 | + | |
| 194 | + | |
| 195 | + | |
| 196 | + | |
| 197 | + | |
| 198 | + | |
| 199 | + | |
| 200 | + | |
| 201 | + | |
| 202 | + | |
| 203 | + | |
| 204 | + | |
| 205 | + | |
| 206 | + | |
| 207 | + | |
| 208 | + | |
| 209 | + | |
| 210 | + | |
| 211 | + | |
| 212 | + | |
| 213 | + | |
| 214 | + | |
| 215 | + | |
| 216 | + | |
| 217 | + | |
| 218 | + | |
| 219 | + | |
| 220 | + | |
163 | 221 | | |
164 | 222 | | |
165 | 223 | | |
| |||
0 commit comments