Commit bf98dc9
authored
feat(python-sdk): record_usage() accepts **kwargs and handles 204 (#13)
record_usage() / async_record_usage() now match the 1.4c API contract:
- accept arbitrary **kwargs; recognised keys (output_tokens, cost,
provider, tool_id, correlation_id, metadata) map to camelCase payload
fields, unknown keys pass through unchanged
- unify sync/async payload construction via _build_usage_payload
- error message now points the caller at actionable next steps
Adds unit coverage:
- 204 No Content success path (sync + async) — SDK must not raise or
parse body
- kwargs-forwarding test verifies recognised-key mapping and
pass-through semantics
Refs: GOV-5761 parent 78f52d0 commit bf98dc9
2 files changed
Lines changed: 98 additions & 23 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
192 | 192 | | |
193 | 193 | | |
194 | 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 | + | |
| 221 | + | |
| 222 | + | |
| 223 | + | |
| 224 | + | |
| 225 | + | |
| 226 | + | |
| 227 | + | |
| 228 | + | |
195 | 229 | | |
196 | 230 | | |
197 | 231 | | |
198 | 232 | | |
199 | 233 | | |
200 | 234 | | |
201 | | - | |
202 | | - | |
| 235 | + | |
203 | 236 | | |
204 | 237 | | |
205 | 238 | | |
| 239 | + | |
| 240 | + | |
| 241 | + | |
| 242 | + | |
| 243 | + | |
| 244 | + | |
| 245 | + | |
| 246 | + | |
| 247 | + | |
| 248 | + | |
206 | 249 | | |
207 | 250 | | |
208 | 251 | | |
209 | 252 | | |
210 | 253 | | |
| 254 | + | |
211 | 255 | | |
212 | 256 | | |
213 | | - | |
214 | | - | |
215 | | - | |
216 | | - | |
217 | | - | |
218 | | - | |
219 | | - | |
220 | | - | |
| 257 | + | |
221 | 258 | | |
222 | 259 | | |
223 | 260 | | |
| |||
226 | 263 | | |
227 | 264 | | |
228 | 265 | | |
229 | | - | |
| 266 | + | |
| 267 | + | |
230 | 268 | | |
231 | 269 | | |
232 | 270 | | |
| |||
236 | 274 | | |
237 | 275 | | |
238 | 276 | | |
239 | | - | |
240 | | - | |
| 277 | + | |
241 | 278 | | |
242 | | - | |
243 | | - | |
244 | | - | |
245 | | - | |
246 | | - | |
247 | | - | |
248 | | - | |
249 | | - | |
250 | | - | |
| 279 | + | |
| 280 | + | |
| 281 | + | |
| 282 | + | |
| 283 | + | |
251 | 284 | | |
252 | 285 | | |
253 | 286 | | |
| |||
256 | 289 | | |
257 | 290 | | |
258 | 291 | | |
259 | | - | |
| 292 | + | |
| 293 | + | |
260 | 294 | | |
261 | 295 | | |
262 | 296 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
41 | 41 | | |
42 | 42 | | |
43 | 43 | | |
| 44 | + | |
| 45 | + | |
| 46 | + | |
| 47 | + | |
| 48 | + | |
| 49 | + | |
| 50 | + | |
| 51 | + | |
| 52 | + | |
| 53 | + | |
| 54 | + | |
| 55 | + | |
| 56 | + | |
| 57 | + | |
| 58 | + | |
| 59 | + | |
| 60 | + | |
| 61 | + | |
| 62 | + | |
| 63 | + | |
| 64 | + | |
| 65 | + | |
| 66 | + | |
| 67 | + | |
| 68 | + | |
| 69 | + | |
| 70 | + | |
| 71 | + | |
| 72 | + | |
| 73 | + | |
| 74 | + | |
| 75 | + | |
| 76 | + | |
| 77 | + | |
| 78 | + | |
| 79 | + | |
| 80 | + | |
| 81 | + | |
| 82 | + | |
| 83 | + | |
| 84 | + | |
44 | 85 | | |
45 | 86 | | |
46 | 87 | | |
| |||
0 commit comments