Commit 8711255
committed
Add event-loop responsiveness test for sync resource handlers
Proves the behavioral fix directly: the handler blocks on a
threading.Event in a worker thread while the async side awaits an
anyio.Event. The handler signals back into the event loop via
anyio.from_thread.run_sync, so the async side's await resolves
without polling or sleeps.
On regression (sync runs inline), anyio.from_thread.run_sync raises
RuntimeError immediately since there is no worker-thread context,
failing fast rather than waiting out the fail_after timeout.1 parent 904dc9f commit 8711255
1 file changed
+32
-0
lines changedLines changed: 32 additions & 0 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
1 | 1 | | |
2 | 2 | | |
| 3 | + | |
| 4 | + | |
3 | 5 | | |
4 | 6 | | |
5 | 7 | | |
| |||
210 | 212 | | |
211 | 213 | | |
212 | 214 | | |
| 215 | + | |
| 216 | + | |
| 217 | + | |
| 218 | + | |
| 219 | + | |
| 220 | + | |
| 221 | + | |
| 222 | + | |
| 223 | + | |
| 224 | + | |
| 225 | + | |
| 226 | + | |
| 227 | + | |
| 228 | + | |
| 229 | + | |
| 230 | + | |
| 231 | + | |
| 232 | + | |
| 233 | + | |
| 234 | + | |
| 235 | + | |
| 236 | + | |
| 237 | + | |
| 238 | + | |
| 239 | + | |
| 240 | + | |
| 241 | + | |
| 242 | + | |
| 243 | + | |
| 244 | + | |
0 commit comments