Commit 385227a
committed
Address PR #69 review: validate timeout + gather all workers
drain() now validates `timeout` is non-negative (and not NaN) at the
API boundary. Negative values previously fell through to asyncio.wait
as an immediate cancel; surface as ValueError with a clear message.
Restructured the post-wait branch to gather all workers (both _done
and pending) with return_exceptions=True after cancellation. Previous
shape only awaited pending in the timeout-fired branch and skipped
the gather entirely on the clean path, so any exception escaping a
delivery worker would surface as a "Task exception was never
retrieved" warning. Defensive — deliver_loop catches observer
exceptions internally — but cheap and prevents the silent-failure
mode.
Two new unit tests cover the validation behavior (negative + NaN
inputs raise ValueError with the expected message).1 parent 9b56c44 commit 385227a
2 files changed
Lines changed: 54 additions & 16 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
719 | 719 | | |
720 | 720 | | |
721 | 721 | | |
| 722 | + | |
| 723 | + | |
| 724 | + | |
722 | 725 | | |
| 726 | + | |
| 727 | + | |
| 728 | + | |
| 729 | + | |
| 730 | + | |
| 731 | + | |
| 732 | + | |
| 733 | + | |
723 | 734 | | |
724 | 735 | | |
725 | 736 | | |
| |||
734 | 745 | | |
735 | 746 | | |
736 | 747 | | |
737 | | - | |
738 | | - | |
739 | | - | |
740 | | - | |
741 | | - | |
742 | | - | |
743 | | - | |
744 | | - | |
745 | | - | |
746 | | - | |
747 | | - | |
748 | | - | |
749 | | - | |
750 | | - | |
751 | | - | |
752 | | - | |
| 748 | + | |
| 749 | + | |
| 750 | + | |
| 751 | + | |
| 752 | + | |
| 753 | + | |
| 754 | + | |
| 755 | + | |
| 756 | + | |
| 757 | + | |
| 758 | + | |
| 759 | + | |
| 760 | + | |
| 761 | + | |
| 762 | + | |
| 763 | + | |
| 764 | + | |
| 765 | + | |
| 766 | + | |
| 767 | + | |
| 768 | + | |
| 769 | + | |
| 770 | + | |
| 771 | + | |
753 | 772 | | |
754 | 773 | | |
755 | 774 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
215 | 215 | | |
216 | 216 | | |
217 | 217 | | |
| 218 | + | |
| 219 | + | |
| 220 | + | |
| 221 | + | |
| 222 | + | |
| 223 | + | |
| 224 | + | |
| 225 | + | |
| 226 | + | |
| 227 | + | |
| 228 | + | |
| 229 | + | |
| 230 | + | |
| 231 | + | |
| 232 | + | |
| 233 | + | |
| 234 | + | |
| 235 | + | |
| 236 | + | |
0 commit comments