skills/skills/compare-cache-runs/SKILL.md
You'll typically receive two cache run identifiers. Follow these steps:
tuist cache-run list --json to find cache runs on each branch.tuist cache-run show <id> --json for both base and head cache runs.Fetch each directly:
tuist cache-run show <base-id> --json
tuist cache-run show <head-id> --json
List recent cache runs on each branch:
tuist cache-run list --git-branch <base-branch> --json --page-size 1
tuist cache-run list --git-branch <head-branch> --json --page-size 1
Then fetch full details with tuist cache-run show <id> --json.
main).After fetching both cache runs, compare:
| Metric | What to check |
|---|---|
duration | Flag if head is >10% slower |
status | Flag if base succeeded but head failed |
cacheable_targets | Note if target count changed |
local_cache_target_hits | Compare local hit counts |
remote_cache_target_hits | Compare remote hit counts |
is_ci | Note if one is CI and the other local |
Compute cache hit rates:
(local_hits + remote_hits) / cacheable_targets * 100head_rate - base_rateIf cache hit rate dropped, the key question is: which target(s) caused the invalidation cascade?
Cache invalidation in tuist cache works the same way as in tuist generate:
dependencies hash changes.Without the module cache target detail endpoint (available via MCP), use these heuristics:
git diff between the base and head commits to see which files changed.| Cause | Description |
|---|---|
| Source changes | Files in the target's source directory were modified |
| Resource changes | Assets, XIBs, storyboards, or other resources changed |
| Build settings | Target or project build settings were modified |
| Dependency changes | An external dependency version changed |
| Info.plist changes | The target's Info.plist was modified |
| Entitlements changes | The entitlements file was modified |
| Deployment target | The minimum deployment target changed |
| Headers | Public or project headers changed |
| Project settings | Shared project-level settings changed |
Categorize the cache invalidation:
For tuist cache specifically, also consider:
command_arguments field can reveal if different flags were used.Produce a summary with:
Example:
Cache Run Comparison: base (run-123 on main) vs head (run-456 on feature-x)
Duration: 95.2s -> 142.8s (+50%) -- REGRESSION
Cache hit rate: 88% (44/50) -> 60% (30/50) (-28%) -- REGRESSION
Status: success -> success
Root cause: CoreModule had source changes (5 files modified).
This cascaded to 14 downstream targets that depend on CoreModule.
Cache invalidation breakdown:
- Direct changes: CoreModule (sources changed)
- Cascade: UIKit, Networking, Analytics, + 11 others (dependency hash changed)
Recommendations:
- Consider splitting CoreModule into smaller, more focused modules
- Use interface/implementation module pattern for frequently-changed modules
- Run `tuist cache` on the feature branch after rebasing to warm caches