Commit 56ac1c8
committed
fix(a2a): guarantee artifact streams accurately propagate completion chunks and multi-turn handoffs
- Fixed `lastChunk` flag assignment in `ARTIFACT_PER_RUN` mode to dynamically adhere to `partial` state, instead of remaining `false` indefinitely.
- Fixed `append` initialization in `EventProcessor` to ensure the first streamed chunk signals `append=false`.
- Leaves the `Message` payload in the terminal `TaskStatusUpdateEvent` completion event as `null` by default, aligning identically with the reference Go implementation.
- Refactored `EventConverter.findUserFunctionCall` to ignore `transfer_to_agent` function responses, ensuring remote A2A handoffs dispatch full conversational histories instead of terminating the prompt context.
- Modified `RemoteA2AAgent.StreamHandler` to reliably enforce task progression via standard ADK Payload `TaskState.COMPLETED`, preventing premature stream cancellations by non-gRPC servers executing `!streaming` validations.
- Added unit tests to `AgentExecutorTest` confirming `lastChunk` signals flip properly and affirming the `null` expectation for `Message`.1 parent 7407e37 commit 56ac1c8
File tree
4 files changed
+76
-6
lines changed- a2a/src
- main/java/com/google/adk/a2a
- agent
- converters
- executor
- test/java/com/google/adk/a2a/executor
4 files changed
+76
-6
lines changedLines changed: 3 additions & 3 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
328 | 328 | | |
329 | 329 | | |
330 | 330 | | |
331 | | - | |
332 | | - | |
333 | | - | |
| 331 | + | |
| 332 | + | |
| 333 | + | |
334 | 334 | | |
335 | 335 | | |
336 | 336 | | |
| |||
Lines changed: 3 additions & 1 deletion
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
74 | 74 | | |
75 | 75 | | |
76 | 76 | | |
77 | | - | |
| 77 | + | |
| 78 | + | |
| 79 | + | |
78 | 80 | | |
79 | 81 | | |
80 | 82 | | |
| |||
Lines changed: 4 additions & 2 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
299 | 299 | | |
300 | 300 | | |
301 | 301 | | |
| 302 | + | |
302 | 303 | | |
303 | 304 | | |
304 | 305 | | |
| |||
329 | 330 | | |
330 | 331 | | |
331 | 332 | | |
332 | | - | |
333 | | - | |
| 333 | + | |
| 334 | + | |
| 335 | + | |
334 | 336 | | |
335 | 337 | | |
336 | 338 | | |
| |||
Lines changed: 66 additions & 0 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
439 | 439 | | |
440 | 440 | | |
441 | 441 | | |
| 442 | + | |
| 443 | + | |
| 444 | + | |
| 445 | + | |
| 446 | + | |
| 447 | + | |
| 448 | + | |
| 449 | + | |
| 450 | + | |
| 451 | + | |
| 452 | + | |
| 453 | + | |
| 454 | + | |
| 455 | + | |
| 456 | + | |
| 457 | + | |
| 458 | + | |
| 459 | + | |
| 460 | + | |
| 461 | + | |
| 462 | + | |
| 463 | + | |
| 464 | + | |
| 465 | + | |
| 466 | + | |
| 467 | + | |
| 468 | + | |
| 469 | + | |
| 470 | + | |
| 471 | + | |
| 472 | + | |
| 473 | + | |
| 474 | + | |
| 475 | + | |
| 476 | + | |
| 477 | + | |
| 478 | + | |
| 479 | + | |
| 480 | + | |
| 481 | + | |
| 482 | + | |
| 483 | + | |
| 484 | + | |
| 485 | + | |
| 486 | + | |
| 487 | + | |
| 488 | + | |
| 489 | + | |
| 490 | + | |
| 491 | + | |
| 492 | + | |
| 493 | + | |
| 494 | + | |
| 495 | + | |
| 496 | + | |
| 497 | + | |
| 498 | + | |
| 499 | + | |
| 500 | + | |
| 501 | + | |
| 502 | + | |
| 503 | + | |
| 504 | + | |
| 505 | + | |
| 506 | + | |
| 507 | + | |
442 | 508 | | |
443 | 509 | | |
444 | 510 | | |
| |||
0 commit comments