Commit a35fa75
committed
Fix CI flakiness: MSB4216 task host failures, dotnet-watch hangs, and noisy NuGet errors
Root cause 1 - MSB4216 task host failures on macOS:
Tasks from NuGet packages (ComputeWasmBuildAssets, ComputeManagedAssemblies) that use
TaskHostFactory need DOTNET_HOST_PATH to locate the dotnet executable for creating task
host processes. The Helix test setup scripts did not export this variable, causing
intermittent MSB4216 errors on macOS (both arm64 and x64). Added DOTNET_HOST_PATH
export to both RunTestsOnHelix.sh and RunTestsOnHelix.cmd.
Root cause 2 - dotnet-watch Aspire_BuildError_ManualRestart test hang:
The test hangs for 60+ minutes on Helix because:
(a) AwaitableProcess.DisposeAsync() did not close stdin before killing the process tree.
PhysicalConsole.ListenToStandardInputAsync() reads with CancellationToken.None,
so the stdin reader blocks indefinitely if the pipe isn't closed first.
(b) AwaitableProcess.DisposeAsync() awaited _processExitAwaiter without a timeout,
so if Kill() failed to terminate the process, disposal would hang forever.
Added a 30-second timeout for the exit wait.
(c) DCP timeouts were set to 100,000 seconds (~27 hours), effectively disabling all
timeouts. When a DCP operation deadlocked, the test would wait until the Helix
work item timeout (~2 hours). Reduced to 300 seconds (5 minutes) per operation.
Root cause 3 - Noisy NuGet source removal errors on Helix:
The Helix test setup scripts try to remove NuGet sources (dotnet6-internal-transport,
dotnet7-internal-transport) that only exist in internal builds. On public CI, these
sources are absent, causing error messages that confuse log analysis. Added error
suppression (|| true for bash, 2>nul for cmd) to all source removal commands.
Files changed:
- build/RunTestsOnHelix.sh: Export DOTNET_HOST_PATH, suppress NuGet removal errors
- build/RunTestsOnHelix.cmd: Set DOTNET_HOST_PATH, suppress NuGet removal errors
- test/Microsoft.DotNet.HotReload.Test.Utilities/AwaitableProcess.cs: Close stdin,
add exit timeout in DisposeAsync
- test/Microsoft.DotNet.HotReload.Test.Utilities/WatchableApp.cs: Reduce DCP timeouts1 parent b98e0dd commit a35fa75
File tree
6 files changed
+109
-38
lines changed- build
- src/BlazorWasmSdk/Tasks
- test
- Microsoft.DotNet.HotReload.Test.Utilities
- TestAssets
6 files changed
+109
-38
lines changed| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
9 | 9 | | |
10 | 10 | | |
11 | 11 | | |
| 12 | + | |
| 13 | + | |
| 14 | + | |
| 15 | + | |
12 | 16 | | |
13 | 17 | | |
14 | 18 | | |
| |||
35 | 39 | | |
36 | 40 | | |
37 | 41 | | |
38 | | - | |
39 | | - | |
40 | | - | |
41 | | - | |
42 | | - | |
43 | | - | |
44 | | - | |
45 | | - | |
46 | | - | |
47 | | - | |
| 42 | + | |
| 43 | + | |
| 44 | + | |
| 45 | + | |
| 46 | + | |
| 47 | + | |
| 48 | + | |
| 49 | + | |
| 50 | + | |
| 51 | + | |
| 52 | + | |
| 53 | + | |
48 | 54 | | |
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
9 | 9 | | |
10 | 10 | | |
11 | 11 | | |
| 12 | + | |
| 13 | + | |
| 14 | + | |
| 15 | + | |
| 16 | + | |
| 17 | + | |
12 | 18 | | |
13 | 19 | | |
14 | 20 | | |
| |||
22 | 28 | | |
23 | 29 | | |
24 | 30 | | |
25 | | - | |
26 | | - | |
27 | | - | |
28 | | - | |
29 | | - | |
30 | | - | |
31 | | - | |
32 | | - | |
33 | | - | |
34 | | - | |
35 | | - | |
| 31 | + | |
| 32 | + | |
| 33 | + | |
| 34 | + | |
| 35 | + | |
| 36 | + | |
| 37 | + | |
| 38 | + | |
| 39 | + | |
| 40 | + | |
| 41 | + | |
| 42 | + | |
36 | 43 | | |
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
20 | 20 | | |
21 | 21 | | |
22 | 22 | | |
| 23 | + | |
| 24 | + | |
| 25 | + | |
| 26 | + | |
23 | 27 | | |
24 | 28 | | |
25 | 29 | | |
| |||
56 | 60 | | |
57 | 61 | | |
58 | 62 | | |
59 | | - | |
| 63 | + | |
| 64 | + | |
| 65 | + | |
60 | 66 | | |
61 | | - | |
62 | | - | |
63 | | - | |
| 67 | + | |
| 68 | + | |
| 69 | + | |
| 70 | + | |
| 71 | + | |
64 | 72 | | |
65 | | - | |
66 | | - | |
67 | | - | |
68 | | - | |
69 | | - | |
70 | | - | |
| 73 | + | |
| 74 | + | |
| 75 | + | |
| 76 | + | |
| 77 | + | |
| 78 | + | |
| 79 | + | |
| 80 | + | |
| 81 | + | |
| 82 | + | |
| 83 | + | |
| 84 | + | |
| 85 | + | |
| 86 | + | |
| 87 | + | |
71 | 88 | | |
72 | 89 | | |
73 | 90 | | |
| |||
Lines changed: 22 additions & 2 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
226 | 226 | | |
227 | 227 | | |
228 | 228 | | |
| 229 | + | |
| 230 | + | |
| 231 | + | |
| 232 | + | |
| 233 | + | |
| 234 | + | |
| 235 | + | |
| 236 | + | |
| 237 | + | |
| 238 | + | |
| 239 | + | |
229 | 240 | | |
230 | 241 | | |
231 | 242 | | |
| |||
234 | 245 | | |
235 | 246 | | |
236 | 247 | | |
237 | | - | |
238 | | - | |
| 248 | + | |
| 249 | + | |
| 250 | + | |
| 251 | + | |
| 252 | + | |
| 253 | + | |
| 254 | + | |
| 255 | + | |
| 256 | + | |
| 257 | + | |
| 258 | + | |
239 | 259 | | |
240 | 260 | | |
241 | 261 | | |
| |||
Lines changed: 9 additions & 5 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
204 | 204 | | |
205 | 205 | | |
206 | 206 | | |
207 | | - | |
208 | | - | |
209 | | - | |
210 | | - | |
| 207 | + | |
| 208 | + | |
| 209 | + | |
| 210 | + | |
| 211 | + | |
| 212 | + | |
| 213 | + | |
| 214 | + | |
211 | 215 | | |
212 | | - | |
| 216 | + | |
213 | 217 | | |
214 | 218 | | |
215 | 219 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
1 | 1 | | |
2 | 2 | | |
3 | 3 | | |
| 4 | + | |
| 5 | + | |
| 6 | + | |
| 7 | + | |
| 8 | + | |
| 9 | + | |
| 10 | + | |
| 11 | + | |
| 12 | + | |
| 13 | + | |
| 14 | + | |
| 15 | + | |
| 16 | + | |
| 17 | + | |
| 18 | + | |
| 19 | + | |
| 20 | + | |
4 | 21 | | |
0 commit comments