Commit 48f5037
fix: don't block StatusMessageWatcher exit with 6s sleep on exception (#753)
## Summary
`StatusMessageWatcher` sleeps 6 seconds on exit to let the final
status/status-message propagate. Two issues with the current placement:
- **API asymmetry**: the sync `stop()` does the sleep itself, while the
async twin does it in `__aexit__`. So manual sync `stop()` paid the 6s
even though manual `await stop()` did not.
- **Exceptional exits were delayed**: both `__exit__` and `__aexit__`
ignored the `exc_type` they receive, so a `Ctrl+C` or any exception
bubbling out of `with`/`async with` was held up 6 seconds.
This change:
- Moves `time.sleep(self._final_sleep_time_s)` out of sync `stop()` into
`__exit__` (matches async shape).
- Gates the sleep in both `__exit__` and `__aexit__` on `exc_type is
None` so exceptional exits propagate immediately.
Normal-exit behavior (the final-message capture window) is preserved.
Co-authored-by: Claude Opus 4.7 (1M context) <noreply@anthropic.com>1 parent 69dde64 commit 48f5037
2 files changed
Lines changed: 69 additions & 2 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
115 | 115 | | |
116 | 116 | | |
117 | 117 | | |
118 | | - | |
| 118 | + | |
| 119 | + | |
119 | 120 | | |
120 | 121 | | |
121 | 122 | | |
| |||
169 | 170 | | |
170 | 171 | | |
171 | 172 | | |
172 | | - | |
173 | 173 | | |
174 | 174 | | |
175 | 175 | | |
| |||
184 | 184 | | |
185 | 185 | | |
186 | 186 | | |
| 187 | + | |
| 188 | + | |
187 | 189 | | |
188 | 190 | | |
189 | 191 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
44 | 44 | | |
45 | 45 | | |
46 | 46 | | |
| 47 | + | |
| 48 | + | |
| 49 | + | |
| 50 | + | |
47 | 51 | | |
48 | 52 | | |
49 | 53 | | |
| |||
652 | 656 | | |
653 | 657 | | |
654 | 658 | | |
| 659 | + | |
| 660 | + | |
| 661 | + | |
| 662 | + | |
| 663 | + | |
| 664 | + | |
| 665 | + | |
| 666 | + | |
| 667 | + | |
| 668 | + | |
| 669 | + | |
| 670 | + | |
| 671 | + | |
| 672 | + | |
| 673 | + | |
| 674 | + | |
| 675 | + | |
| 676 | + | |
| 677 | + | |
| 678 | + | |
| 679 | + | |
| 680 | + | |
| 681 | + | |
| 682 | + | |
| 683 | + | |
| 684 | + | |
| 685 | + | |
| 686 | + | |
| 687 | + | |
| 688 | + | |
| 689 | + | |
| 690 | + | |
| 691 | + | |
| 692 | + | |
| 693 | + | |
| 694 | + | |
| 695 | + | |
| 696 | + | |
| 697 | + | |
| 698 | + | |
| 699 | + | |
| 700 | + | |
| 701 | + | |
| 702 | + | |
| 703 | + | |
| 704 | + | |
| 705 | + | |
| 706 | + | |
| 707 | + | |
| 708 | + | |
| 709 | + | |
| 710 | + | |
| 711 | + | |
| 712 | + | |
| 713 | + | |
| 714 | + | |
| 715 | + | |
| 716 | + | |
| 717 | + | |
| 718 | + | |
| 719 | + | |
0 commit comments