Commit 8807e95
Suppress ExecutionContext flow in BeginErrorReadLine
Process.BeginErrorReadLine() captures the caller's ExecutionContext,
causing AsyncLocal values to leak to the background stderr reader
thread. This is undesirable—the stderr handler is a long-lived
background I/O callback that shouldn't inherit ambient state from
whichever call site happened to create the transport.
Wrap BeginErrorReadLine() in ExecutionContext.SuppressFlow() so the
stderr reader gets a clean context.
Add a test that sets an AsyncLocal before creating the transport and
verifies the stderr callback does NOT see the value.
Co-authored-by: Copilot <223556219+Copilot@users.noreply.github.com>1 parent d4c588b commit 8807e95
2 files changed
Lines changed: 49 additions & 1 deletion
File tree
- src/ModelContextProtocol.Core/Client
- tests/ModelContextProtocol.Tests/Transport
Lines changed: 7 additions & 1 deletion
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
191 | 191 | | |
192 | 192 | | |
193 | 193 | | |
194 | | - | |
| 194 | + | |
| 195 | + | |
| 196 | + | |
| 197 | + | |
| 198 | + | |
| 199 | + | |
| 200 | + | |
195 | 201 | | |
196 | 202 | | |
197 | 203 | | |
| |||
Lines changed: 42 additions & 0 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
5 | 5 | | |
6 | 6 | | |
7 | 7 | | |
| 8 | + | |
8 | 9 | | |
9 | 10 | | |
10 | 11 | | |
| |||
59 | 60 | | |
60 | 61 | | |
61 | 62 | | |
| 63 | + | |
| 64 | + | |
| 65 | + | |
| 66 | + | |
| 67 | + | |
| 68 | + | |
| 69 | + | |
| 70 | + | |
| 71 | + | |
| 72 | + | |
| 73 | + | |
| 74 | + | |
| 75 | + | |
| 76 | + | |
| 77 | + | |
| 78 | + | |
| 79 | + | |
| 80 | + | |
| 81 | + | |
| 82 | + | |
| 83 | + | |
| 84 | + | |
| 85 | + | |
| 86 | + | |
| 87 | + | |
| 88 | + | |
| 89 | + | |
| 90 | + | |
| 91 | + | |
| 92 | + | |
| 93 | + | |
| 94 | + | |
| 95 | + | |
| 96 | + | |
| 97 | + | |
| 98 | + | |
| 99 | + | |
| 100 | + | |
| 101 | + | |
| 102 | + | |
| 103 | + | |
62 | 104 | | |
63 | 105 | | |
64 | 106 | | |
| |||
0 commit comments