Commit 7c04444
fix(devserver): honor evaluator.project_id when request omits it (#372)
## Summary
The dev-server's `run_eval` builds `EvalAsync(...)` kwargs with:
```python
{**eval_kwargs, ..., "project_id": eval_data.get("project_id")}
```
The trailing key always wins in dict-spread merging, so a request body
that omits `project_id` silently overrides the registered evaluator's
`project_id` to `None`. `EvalAsync(name=..., project_id=None)` then
falls back to using the eval name as the project name (per `Eval(...)`
docstring: *"If specified, uses the given project ID instead of the
evaluator's name to identify the project."*), so experiments route into
a per-evaluator-name auto-created project instead of the project the
evaluator was registered against.
This bites consumers who mount the dev-server behind a custom auth layer
and trigger evals from anything other than the Braintrust playground UI:
every triggered run lands in a fresh eval-name-keyed project rather than
the canonical project the registered `Evaluator(project_id=...)` named.
## Fix
Fall back to `evaluator.project_id` when the request omits it. An
explicit request-level `project_id` still takes precedence (no behavior
change for the playground UI flow).
```python
project_id = eval_data.get("project_id") or evaluator.project_id
```
## Test plan
- [x]
`test_eval_falls_back_to_evaluator_project_id_when_request_omits_it` —
registers an evaluator with a known `project_id`, POSTs `/eval` without
`project_id`, asserts `EvalAsync` receives the registered id. (Fails on
`main`, passes with this fix.)
- [x] `test_eval_request_project_id_overrides_evaluator` — confirms an
explicit request-level `project_id` still wins.
- [x] Full `py/src/braintrust/devserver/` test suite green (21 passed, 2
pre-existing skips).
- [x] `nox -s pylint` passes.
- [x] Pre-commit hooks (ruff format, ruff check, codespell) pass.
---------
Co-authored-by: Abhijeet Prasad <abhijeet@braintrustdata.com>1 parent 25ec266 commit 7c04444
2 files changed
Lines changed: 139 additions & 1 deletion
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
225 | 225 | | |
226 | 226 | | |
227 | 227 | | |
| 228 | + | |
| 229 | + | |
| 230 | + | |
| 231 | + | |
| 232 | + | |
| 233 | + | |
| 234 | + | |
| 235 | + | |
228 | 236 | | |
229 | 237 | | |
230 | 238 | | |
| |||
243 | 251 | | |
244 | 252 | | |
245 | 253 | | |
246 | | - | |
| 254 | + | |
247 | 255 | | |
248 | 256 | | |
249 | 257 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
298 | 298 | | |
299 | 299 | | |
300 | 300 | | |
| 301 | + | |
| 302 | + | |
| 303 | + | |
| 304 | + | |
| 305 | + | |
| 306 | + | |
| 307 | + | |
| 308 | + | |
| 309 | + | |
| 310 | + | |
| 311 | + | |
| 312 | + | |
| 313 | + | |
| 314 | + | |
| 315 | + | |
| 316 | + | |
| 317 | + | |
| 318 | + | |
| 319 | + | |
| 320 | + | |
| 321 | + | |
| 322 | + | |
| 323 | + | |
| 324 | + | |
| 325 | + | |
| 326 | + | |
| 327 | + | |
| 328 | + | |
| 329 | + | |
| 330 | + | |
| 331 | + | |
| 332 | + | |
| 333 | + | |
| 334 | + | |
| 335 | + | |
| 336 | + | |
| 337 | + | |
| 338 | + | |
| 339 | + | |
| 340 | + | |
| 341 | + | |
| 342 | + | |
| 343 | + | |
| 344 | + | |
| 345 | + | |
| 346 | + | |
| 347 | + | |
| 348 | + | |
| 349 | + | |
| 350 | + | |
| 351 | + | |
| 352 | + | |
| 353 | + | |
| 354 | + | |
| 355 | + | |
| 356 | + | |
| 357 | + | |
| 358 | + | |
| 359 | + | |
| 360 | + | |
| 361 | + | |
| 362 | + | |
| 363 | + | |
| 364 | + | |
| 365 | + | |
| 366 | + | |
| 367 | + | |
| 368 | + | |
| 369 | + | |
| 370 | + | |
| 371 | + | |
| 372 | + | |
| 373 | + | |
| 374 | + | |
| 375 | + | |
| 376 | + | |
| 377 | + | |
| 378 | + | |
| 379 | + | |
| 380 | + | |
| 381 | + | |
| 382 | + | |
| 383 | + | |
| 384 | + | |
| 385 | + | |
| 386 | + | |
| 387 | + | |
| 388 | + | |
| 389 | + | |
| 390 | + | |
| 391 | + | |
| 392 | + | |
| 393 | + | |
| 394 | + | |
| 395 | + | |
| 396 | + | |
| 397 | + | |
| 398 | + | |
| 399 | + | |
| 400 | + | |
| 401 | + | |
| 402 | + | |
| 403 | + | |
| 404 | + | |
| 405 | + | |
| 406 | + | |
| 407 | + | |
| 408 | + | |
| 409 | + | |
| 410 | + | |
| 411 | + | |
| 412 | + | |
| 413 | + | |
| 414 | + | |
| 415 | + | |
| 416 | + | |
| 417 | + | |
| 418 | + | |
| 419 | + | |
| 420 | + | |
| 421 | + | |
| 422 | + | |
| 423 | + | |
| 424 | + | |
| 425 | + | |
| 426 | + | |
| 427 | + | |
| 428 | + | |
| 429 | + | |
| 430 | + | |
0 commit comments