Commit e1e0859
feat(xcode-ide): Persist bridge response artifacts (#396)
* ref(rendering): Finalize output from structured results
Make final tool rendering depend on explicit structured results instead of
streaming fragments. This keeps live progress transient and gives CLI, daemon,
and MCP output paths the same source of truth for final success, errors, and
text rendering.
Add a shared structured error shape and schema coverage so failures can be
rendered consistently without scraping fragment text.
* ref(build-run): Return explicit structured results
Update simulator, device, and macOS build-and-run flows to populate final
structured results directly. This removes the need to infer final status or
artifact paths from progress fragments while preserving live progress for
interactive renderers.
Adjust resource and test helpers around the new result contract.
* fix(filesystem): Prune workspace artifacts safely
Expand workspace filesystem cleanup so transient XcodeBuildMCP-owned files are
removed with ownership checks and bounded retention. This keeps generated
artifacts from accumulating while preserving files that belong to active
processes or other workspaces.
Add regression coverage for cleanup ownership and retention behavior.
* feat(xcode-ide): Persist bridge responses as artifacts
Save raw Xcode IDE bridge call results as transient workspace artifacts and
return concise structured summaries from the public tools. This prevents large
relayed payloads from being embedded in final text output while preserving the
full remote response for callers that need it.
Route Xcode IDE CLI commands through the generic output pipeline so text, JSON,
and JSONL modes share the same behavior as other tool commands.
* test(xcode-ide): Add bridge output snapshots
Add snapshot coverage for Xcode IDE list-tools and documentation-search output
across CLI text, MCP text, and CLI JSON modes. Normalize transient artifact
paths so the fixtures verify the public contract without depending on local
workspace directories.
* docs: Document output and cleanup rules
Update agent guidance for structured output terminology, streaming boundaries,
and workspace filesystem cleanup. Add the corresponding changelog entries for
the Xcode IDE artifact output and fragment-state removal.
* test(swift-package): Allow nonzero run duration
Avoid asserting an exact wall-clock duration for swift_package_run progress.
CI can legitimately report a small nonzero duration even when local runs finish
within the same millisecond.
* fix(rendering): Prevent fragment state from affecting final output
Remove fragment caching from render sessions and test results so streamed
fragments cannot be reused as final response state. Normalize xcode-ide tool
counts in snapshots to avoid environment-specific fixture churn.
Refs GH-360
Co-Authored-By: Codex <noreply@openai.com>
---------
Co-authored-by: Codex <noreply@openai.com>1 parent 839c95f commit e1e0859
72 files changed
Lines changed: 2667 additions & 986 deletions
File tree
- manifests/tools
- schemas/structured-output
- xcodebuildmcp.output.error
- xcodebuildmcp.output.xcode-bridge-call-result
- xcodebuildmcp.output.xcode-bridge-tool-list
- src
- cli
- __tests__
- core
- __tests__
- daemon
- __tests__
- integrations/xcode-tools-bridge
- mcp
- resources
- tools
- device
- __tests__
- macos
- __tests__
- simulator
- __tests__
- swift-package/__tests__
- xcode-ide
- __tests__
- rendering
- __tests__
- runtime
- __tests__
- smoke-tests/__tests__
- snapshot-tests
- __fixtures__
- cli/xcode-ide
- json/xcode-ide
- mcp/xcode-ide
- __tests__
- suites
- test-utils
- types
- utils
- __tests__
- execution
- __tests__
- renderers
Some content is hidden
Large Commits have some content hidden by default. Use the searchbox below for content that may be hidden.
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
54 | 54 | | |
55 | 55 | | |
56 | 56 | | |
| 57 | + | |
| 58 | + | |
| 59 | + | |
| 60 | + | |
| 61 | + | |
| 62 | + | |
57 | 63 | | |
58 | 64 | | |
59 | 65 | | |
| |||
88 | 94 | | |
89 | 95 | | |
90 | 96 | | |
| 97 | + | |
91 | 98 | | |
92 | 99 | | |
93 | 100 | | |
| |||
98 | 105 | | |
99 | 106 | | |
100 | 107 | | |
| 108 | + | |
101 | 109 | | |
102 | 110 | | |
103 | 111 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
14 | 14 | | |
15 | 15 | | |
16 | 16 | | |
| 17 | + | |
17 | 18 | | |
| 19 | + | |
18 | 20 | | |
19 | 21 | | |
20 | 22 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
29 | 29 | | |
30 | 30 | | |
31 | 31 | | |
| 32 | + | |
32 | 33 | | |
33 | 34 | | |
34 | 35 | | |
| |||
39 | 40 | | |
40 | 41 | | |
41 | 42 | | |
| 43 | + | |
42 | 44 | | |
43 | 45 | | |
44 | 46 | | |
| |||
62 | 64 | | |
63 | 65 | | |
64 | 66 | | |
| 67 | + | |
| 68 | + | |
| 69 | + | |
| 70 | + | |
| 71 | + | |
| 72 | + | |
65 | 73 | | |
66 | 74 | | |
67 | 75 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
6 | 6 | | |
7 | 7 | | |
8 | 8 | | |
9 | | - | |
| 9 | + | |
10 | 10 | | |
11 | 11 | | |
12 | 12 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
6 | 6 | | |
7 | 7 | | |
8 | 8 | | |
9 | | - | |
| 9 | + | |
10 | 10 | | |
11 | 11 | | |
12 | 12 | | |
| |||
Lines changed: 41 additions & 0 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
| 1 | + | |
| 2 | + | |
| 3 | + | |
| 4 | + | |
| 5 | + | |
| 6 | + | |
| 7 | + | |
| 8 | + | |
| 9 | + | |
| 10 | + | |
| 11 | + | |
| 12 | + | |
| 13 | + | |
| 14 | + | |
| 15 | + | |
| 16 | + | |
| 17 | + | |
| 18 | + | |
| 19 | + | |
| 20 | + | |
| 21 | + | |
| 22 | + | |
| 23 | + | |
| 24 | + | |
| 25 | + | |
| 26 | + | |
| 27 | + | |
| 28 | + | |
| 29 | + | |
| 30 | + | |
| 31 | + | |
| 32 | + | |
| 33 | + | |
| 34 | + | |
| 35 | + | |
| 36 | + | |
| 37 | + | |
| 38 | + | |
| 39 | + | |
| 40 | + | |
| 41 | + | |
Lines changed: 50 additions & 0 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
| 1 | + | |
| 2 | + | |
| 3 | + | |
| 4 | + | |
| 5 | + | |
| 6 | + | |
| 7 | + | |
| 8 | + | |
| 9 | + | |
| 10 | + | |
| 11 | + | |
| 12 | + | |
| 13 | + | |
| 14 | + | |
| 15 | + | |
| 16 | + | |
| 17 | + | |
| 18 | + | |
| 19 | + | |
| 20 | + | |
| 21 | + | |
| 22 | + | |
| 23 | + | |
| 24 | + | |
| 25 | + | |
| 26 | + | |
| 27 | + | |
| 28 | + | |
| 29 | + | |
| 30 | + | |
| 31 | + | |
| 32 | + | |
| 33 | + | |
| 34 | + | |
| 35 | + | |
| 36 | + | |
| 37 | + | |
| 38 | + | |
| 39 | + | |
| 40 | + | |
| 41 | + | |
| 42 | + | |
| 43 | + | |
| 44 | + | |
| 45 | + | |
| 46 | + | |
| 47 | + | |
| 48 | + | |
| 49 | + | |
| 50 | + | |
Lines changed: 37 additions & 0 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
| 1 | + | |
| 2 | + | |
| 3 | + | |
| 4 | + | |
| 5 | + | |
| 6 | + | |
| 7 | + | |
| 8 | + | |
| 9 | + | |
| 10 | + | |
| 11 | + | |
| 12 | + | |
| 13 | + | |
| 14 | + | |
| 15 | + | |
| 16 | + | |
| 17 | + | |
| 18 | + | |
| 19 | + | |
| 20 | + | |
| 21 | + | |
| 22 | + | |
| 23 | + | |
| 24 | + | |
| 25 | + | |
| 26 | + | |
| 27 | + | |
| 28 | + | |
| 29 | + | |
| 30 | + | |
| 31 | + | |
| 32 | + | |
| 33 | + | |
| 34 | + | |
| 35 | + | |
| 36 | + | |
| 37 | + | |
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
32 | 32 | | |
33 | 33 | | |
34 | 34 | | |
| 35 | + | |
| 36 | + | |
| 37 | + | |
| 38 | + | |
| 39 | + | |
| 40 | + | |
| 41 | + | |
| 42 | + | |
| 43 | + | |
| 44 | + | |
| 45 | + | |
| 46 | + | |
| 47 | + | |
| 48 | + | |
| 49 | + | |
| 50 | + | |
| 51 | + | |
35 | 52 | | |
36 | 53 | | |
37 | 54 | | |
| |||
120 | 137 | | |
121 | 138 | | |
122 | 139 | | |
123 | | - | |
124 | | - | |
125 | | - | |
126 | | - | |
| 140 | + | |
| 141 | + | |
| 142 | + | |
| 143 | + | |
| 144 | + | |
| 145 | + | |
127 | 146 | | |
128 | 147 | | |
129 | 148 | | |
| |||
133 | 152 | | |
134 | 153 | | |
135 | 154 | | |
136 | | - | |
| 155 | + | |
137 | 156 | | |
138 | 157 | | |
139 | 158 | | |
| |||
142 | 161 | | |
143 | 162 | | |
144 | 163 | | |
145 | | - | |
| 164 | + | |
146 | 165 | | |
147 | 166 | | |
148 | 167 | | |
| |||
0 commit comments