Commit c1a9802
committed
fix(usage): Normalize None token details on Usage initialization
Some providers don't populate optional token detail fields, resulting
in None values that bypass Pydantic validation. This fix adds a
__post_init__ method to normalize None to 0 for cached_tokens and
reasoning_tokens on any Usage object creation.
This defensive approach handles the issue at the boundary we control,
regardless of how providers construct their response objects.
Signed-off-by: Adrian Cole <[email protected]>1 parent 0c4f2b9 commit c1a9802
2 files changed
+29
-0
lines changed| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
60 | 60 | | |
61 | 61 | | |
62 | 62 | | |
| 63 | + | |
| 64 | + | |
| 65 | + | |
| 66 | + | |
| 67 | + | |
| 68 | + | |
| 69 | + | |
63 | 70 | | |
64 | 71 | | |
65 | 72 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
267 | 267 | | |
268 | 268 | | |
269 | 269 | | |
| 270 | + | |
| 271 | + | |
| 272 | + | |
| 273 | + | |
| 274 | + | |
| 275 | + | |
| 276 | + | |
| 277 | + | |
| 278 | + | |
| 279 | + | |
| 280 | + | |
| 281 | + | |
| 282 | + | |
| 283 | + | |
| 284 | + | |
| 285 | + | |
| 286 | + | |
| 287 | + | |
| 288 | + | |
| 289 | + | |
| 290 | + | |
| 291 | + | |
0 commit comments