Commit 614576c
The multimodal and approval-flow E2E specs intermittently failed with empty
assistant responses (surfaced as `chatStream fatal`). Root cause was a
test-harness race, not aimock or the library — every request the harness
actually sent succeeded.
Multimodal: `sendMessageWithImage` typed into a controlled React input and then
attached the image, which auto-sends using that input's value. Under CPU load
`pressSequentially` dropped leading characters, so the prompt reached aimock
truncated (e.g. "cribe this image") and 404'd as "No fixture matched"; and React
state could lag the committed DOM value so the auto-send fired with empty text
and dispatched no request at all.
- helpers: type until the full prompt is committed, then retry the typing +
attach until the send actually fires (user bubble renders).
- ChatUI: the image auto-send reads the live input DOM value instead of
possibly-stale React state.
Approval-flow: `runTest` treated the optimistic user-message bump as "run
started", returning before any real stream activity — a stalled run then timed
out waiting for an approval that never appeared.
- runTest: require real stream activity (loading on, a tool call, completion, or
an assistant message) before returning, and retry the click otherwise.
Verified: multimodal 200/200 with 0 flaky at 20x (4 workers, retries=2) and at
6 workers/retries=0; approval-flow 450/450 at 25x/8 workers/retries=0; full E2E
suite green.
Co-authored-by: Claude Opus 4.8 (1M context) <noreply@anthropic.com>
1 parent df40512 commit 614576c
3 files changed
Lines changed: 74 additions & 23 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
40 | 40 | | |
41 | 41 | | |
42 | 42 | | |
| 43 | + | |
43 | 44 | | |
44 | 45 | | |
45 | 46 | | |
| |||
203 | 204 | | |
204 | 205 | | |
205 | 206 | | |
206 | | - | |
207 | | - | |
| 207 | + | |
| 208 | + | |
| 209 | + | |
| 210 | + | |
| 211 | + | |
| 212 | + | |
| 213 | + | |
208 | 214 | | |
209 | 215 | | |
210 | 216 | | |
211 | 217 | | |
212 | 218 | | |
213 | 219 | | |
| 220 | + | |
214 | 221 | | |
215 | 222 | | |
216 | 223 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
37 | 37 | | |
38 | 38 | | |
39 | 39 | | |
40 | | - | |
41 | | - | |
42 | | - | |
43 | | - | |
44 | | - | |
| 40 | + | |
| 41 | + | |
| 42 | + | |
| 43 | + | |
| 44 | + | |
| 45 | + | |
| 46 | + | |
| 47 | + | |
| 48 | + | |
| 49 | + | |
| 50 | + | |
| 51 | + | |
| 52 | + | |
| 53 | + | |
| 54 | + | |
| 55 | + | |
| 56 | + | |
| 57 | + | |
| 58 | + | |
| 59 | + | |
| 60 | + | |
| 61 | + | |
| 62 | + | |
| 63 | + | |
| 64 | + | |
45 | 65 | | |
46 | 66 | | |
47 | 67 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
108 | 108 | | |
109 | 109 | | |
110 | 110 | | |
111 | | - | |
112 | 111 | | |
113 | | - | |
114 | | - | |
115 | | - | |
116 | | - | |
117 | | - | |
118 | | - | |
119 | | - | |
120 | | - | |
121 | | - | |
122 | | - | |
123 | | - | |
124 | | - | |
125 | | - | |
126 | | - | |
127 | | - | |
| 112 | + | |
| 113 | + | |
| 114 | + | |
| 115 | + | |
| 116 | + | |
| 117 | + | |
| 118 | + | |
| 119 | + | |
| 120 | + | |
| 121 | + | |
| 122 | + | |
| 123 | + | |
| 124 | + | |
| 125 | + | |
| 126 | + | |
| 127 | + | |
| 128 | + | |
| 129 | + | |
| 130 | + | |
| 131 | + | |
| 132 | + | |
| 133 | + | |
| 134 | + | |
| 135 | + | |
| 136 | + | |
| 137 | + | |
| 138 | + | |
| 139 | + | |
| 140 | + | |
| 141 | + | |
| 142 | + | |
| 143 | + | |
| 144 | + | |
| 145 | + | |
| 146 | + | |
| 147 | + | |
| 148 | + | |
| 149 | + | |
| 150 | + | |
| 151 | + | |
128 | 152 | | |
129 | 153 | | |
130 | 154 | | |
| |||
0 commit comments