Commit 30bc0af
committed
Add shared round-trip corpus + wire-fidelity fixes (Swift/Rust/Kotlin)
Introduce a language-agnostic round-trip test corpus under
types/test-cases/round-trips/ (24 fixtures) and wire each client up to
decode → re-encode every fixture through its real generated types. The
corpus pins forward-compatibility and exact-bit fidelity across clients.
Fidelity fixes driven by the corpus:
- Rust: SessionStatus becomes a u32 bitset newtype (was a #[repr(u32)]
enum) so combined flags and unknown forward-compat bits round-trip
instead of being dropped or rejected. Generated via generate-rust.ts.
- Kotlin: SessionStatus.rawValue widens Int → Long so an unknown bit at
or above 2^31 round-trips as a plain JSON integer instead of throwing.
Generated via generate-kotlin.ts.
- Swift: open unions (StateAction, Customization, ResponsePart,
ToolCallState, TerminalClaim, …) decode an unknown discriminant to a
raw passthrough and re-encode it verbatim instead of throwing or
emitting {}; ChangesetOperation*Target now encode their kind
discriminant. Generated via generate-swift.ts; hand-written
NativeReducer / ToolCallStateExtensions handle the .unknown variant.
Tests: round-trip corpus runners for Go, Kotlin, Swift, and TypeScript,
plus Kotlin bitset tests covering the Long high-bit case. CHANGELOG
entries for the Swift, Rust, and Kotlin clients.1 parent 0dfdcf8 commit 30bc0af
49 files changed
Lines changed: 3987 additions & 71 deletions
File tree
- clients
- go/ahptypes
- kotlin
- src
- main/kotlin/com/microsoft/agenthostprotocol
- generated
- test/kotlin/com/microsoft/agenthostprotocol
- rust
- crates
- ahp-types/src
- ahp
- src
- tests
- swift
- AgentHostProtocol
- Sources/AgentHostProtocol
- Generated
- Tests/AgentHostProtocolClientTests
- typescript/test
- scripts
- types/test-cases/round-trips
Some content is hidden
Large Commits have some content hidden by default. Use the searchbox below for content that may be hidden.
Large diffs are not rendered by default.
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
79 | 79 | | |
80 | 80 | | |
81 | 81 | | |
| 82 | + | |
| 83 | + | |
| 84 | + | |
| 85 | + | |
| 86 | + | |
| 87 | + | |
| 88 | + | |
| 89 | + | |
| 90 | + | |
| 91 | + | |
| 92 | + | |
| 93 | + | |
| 94 | + | |
82 | 95 | | |
83 | 96 | | |
84 | 97 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
56 | 56 | | |
57 | 57 | | |
58 | 58 | | |
| 59 | + | |
| 60 | + | |
| 61 | + | |
| 62 | + | |
| 63 | + | |
| 64 | + | |
| 65 | + | |
| 66 | + | |
| 67 | + | |
59 | 68 | | |
60 | 69 | | |
61 | 70 | | |
| |||
Lines changed: 1 addition & 1 deletion
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
213 | 213 | | |
214 | 214 | | |
215 | 215 | | |
216 | | - | |
| 216 | + | |
217 | 217 | | |
218 | 218 | | |
219 | 219 | | |
| |||
Lines changed: 10 additions & 10 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
123 | 123 | | |
124 | 124 | | |
125 | 125 | | |
126 | | - | |
| 126 | + | |
127 | 127 | | |
128 | 128 | | |
129 | 129 | | |
| |||
134 | 134 | | |
135 | 135 | | |
136 | 136 | | |
137 | | - | |
| 137 | + | |
138 | 138 | | |
139 | 139 | | |
140 | 140 | | |
141 | | - | |
| 141 | + | |
142 | 142 | | |
143 | 143 | | |
144 | 144 | | |
145 | | - | |
| 145 | + | |
146 | 146 | | |
147 | 147 | | |
148 | 148 | | |
149 | | - | |
| 149 | + | |
150 | 150 | | |
151 | 151 | | |
152 | 152 | | |
153 | | - | |
| 153 | + | |
154 | 154 | | |
155 | 155 | | |
156 | 156 | | |
157 | | - | |
| 157 | + | |
158 | 158 | | |
159 | 159 | | |
160 | 160 | | |
161 | 161 | | |
162 | 162 | | |
163 | | - | |
| 163 | + | |
164 | 164 | | |
165 | | - | |
| 165 | + | |
166 | 166 | | |
167 | 167 | | |
168 | | - | |
| 168 | + | |
169 | 169 | | |
170 | 170 | | |
171 | 171 | | |
| |||
Lines changed: 19 additions & 1 deletion
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
52 | 52 | | |
53 | 53 | | |
54 | 54 | | |
55 | | - | |
| 55 | + | |
56 | 56 | | |
57 | 57 | | |
58 | 58 | | |
59 | 59 | | |
60 | 60 | | |
61 | 61 | | |
| 62 | + | |
| 63 | + | |
| 64 | + | |
| 65 | + | |
| 66 | + | |
| 67 | + | |
| 68 | + | |
| 69 | + | |
| 70 | + | |
| 71 | + | |
| 72 | + | |
| 73 | + | |
| 74 | + | |
| 75 | + | |
| 76 | + | |
| 77 | + | |
| 78 | + | |
| 79 | + | |
62 | 80 | | |
63 | 81 | | |
64 | 82 | | |
| |||
Lines changed: 1 addition & 1 deletion
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
139 | 139 | | |
140 | 140 | | |
141 | 141 | | |
142 | | - | |
| 142 | + | |
143 | 143 | | |
144 | 144 | | |
145 | 145 | | |
| |||
0 commit comments