xcode-workflows
npx machina-cli add skill conorluddy/xclaude-plugin/xcode-workflows --openclawXcode Workflows
Use the execute_xcode_command MCP tool for all iOS build operations
The xclaude-plugin provides the execute_xcode_command MCP tool which consolidates all xcodebuild operations into a single, token-efficient dispatcher.
⚠️ CRITICAL: Always Use MCP Tools First
This is the most important rule: When working with iOS builds, you MUST use the execute_xcode_command MCP tool.
- ✅ DO: Invoke
execute_xcode_commandfor all build/test/clean operations - ✅ DO: If the MCP tool fails, adjust parameters and retry
- ✅ DO: Read error messages and debug the parameters
- ❌ NEVER: Fall back to bash
xcodebuildcommands - ❌ NEVER: Use
xcodebuilddirectly in bash - ❌ NEVER: Run
xcrun xcodebuildin a terminal
Why? The MCP tool provides:
- Structured error handling
- Token efficiency (consolidated into 1 tool vs. verbose bash output)
- Proper integration with the xclaude-plugin architecture
- Consistent response formatting
If execute_xcode_command fails, the issue is with parameters or the project - not that you should use bash.
When to Use Bash (And When NOT to)
❌ NEVER Use Bash For These (Use MCP Tools Instead)
| Task | ❌ WRONG (Bash) | ✅ RIGHT (MCP Tool) |
|---|---|---|
| List schemes | xcodebuild -list | execute_xcode_command op: "list" |
| Build app | xcodebuild -scheme... | execute_xcode_command op: "build" |
| Run tests | xcodebuild -scheme... test | execute_xcode_command op: "test" |
| Clean build | xcodebuild clean | execute_xcode_command op: "clean" |
| Get Xcode info | xcodebuild -version | execute_xcode_command op: "version" |
✅ Bash is Acceptable For (Non-Build Tasks)
- File operations:
mkdir,cp,rm,ls, etc. - Text inspection:
grep,find,cat, etc. - Git operations:
git status,git log, etc. - Environment checks:
which,xcode-select --version, etc. - Project exploration:
find . -name "*.swift", etc.
The Rule: If it's about Xcode building/testing → Use MCP tool, not bash
Quick Reference
| Task | MCP Tool | Operation | Key Parameters |
|---|---|---|---|
| Build for simulator | execute_xcode_command | build | scheme, configuration:Debug |
| Build for device | execute_xcode_command | build | scheme, configuration:Release, destination |
| Run tests | execute_xcode_command | test | scheme, destination |
| Clean build | execute_xcode_command | clean | scheme |
| List schemes | execute_xcode_command | list | - |
| Get Xcode info | execute_xcode_command | version | - |
Standard Workflows
1. Building an App
Step 1: Discover Schemes - Use execute_xcode_command with operation: "list"
Invoke the execute_xcode_command MCP tool:
{
"operation": "list",
"project_path": "/path/to/Project.xcodeproj"
}
Note: project_path is optional - auto-detected from current directory.
Returns:
{
"schemes": ["MyApp", "MyAppTests", "MyAppUITests"],
"targets": ["MyApp", "MyAppKit", "MyAppTests"]
}
Step 2: Build - Use execute_xcode_command with operation: "build"
Invoke the execute_xcode_command MCP tool with build parameters:
{
"operation": "build",
"scheme": "MyApp",
"configuration": "Debug",
"destination": "platform=iOS Simulator,name=iPhone 15"
}
Common Destinations:
- iOS Simulator (explicit - recommended):
"platform=iOS Simulator,name=iPhone 15,OS=18.0" - iOS Simulator (auto-resolve):
"platform=iOS Simulator,name=iPhone 15"(will auto-detect latest OS) - iOS Device:
"platform=iOS,id=<device-udid>" - Any Simulator:
"platform=iOS Simulator,name=Any iOS Simulator Device" - macOS:
"platform=macOS"
Note: The destination parameter now supports auto-resolution! If you omit the OS version, the tool will automatically query available simulators and select the latest OS version for the specified device name. For explicit control, include the OS version in your destination string.
2. Running Tests
Unit Tests:
{
"operation": "test",
"scheme": "MyApp",
"destination": "platform=iOS Simulator,name=iPhone 15"
}
Specific Test Plan:
{
"operation": "test",
"scheme": "MyApp",
"destination": "platform=iOS Simulator,name=iPhone 15",
"options": {
"test_plan": "UnitTests"
}
}
Run Specific Tests:
{
"operation": "test",
"scheme": "MyApp",
"destination": "platform=iOS Simulator,name=iPhone 15",
"options": {
"only_testing": [
"MyAppTests/LoginTests/testSuccessfulLogin",
"MyAppTests/LoginTests/testInvalidCredentials"
]
}
}
Skip Specific Tests:
{
"operation": "test",
"scheme": "MyApp",
"destination": "platform=iOS Simulator,name=iPhone 15",
"options": {
"skip_testing": ["MyAppUITests"]
}
}
3. Clean Build
When to Clean:
- Build artifacts corrupted
- Switching branches significantly
- Mysterious build failures
- Before release builds
{
"operation": "clean",
"scheme": "MyApp"
}
Clean + Build Pattern:
{
"operation": "build",
"scheme": "MyApp",
"configuration": "Debug",
"options": {
"clean_before_build": true
}
}
Configurations
Debug vs Release
Debug (Default):
- Optimizations disabled
- Debug symbols included
- Faster compile time
- Larger binary
- Use for: Development, testing
Release:
- Optimizations enabled
- Debug symbols optional
- Slower compile time
- Smaller binary
- Use for: Production, App Store, performance testing
{
"operation": "build",
"scheme": "MyApp",
"configuration": "Release"
}
Build Options
Common Options
{
"operation": "build",
"scheme": "MyApp",
"options": {
"clean_before_build": true,
"parallel": true,
"sdk": "iphoneos17.0",
"arch": "arm64",
"quiet": false
}
}
Options Explained:
- clean_before_build: Clean before building (ensures fresh build)
- parallel: Enable parallel builds (faster on multi-core)
- sdk: Specific SDK version (usually auto-selected)
- arch: Target architecture (arm64 for devices, x86_64 for old simulators)
- quiet: Reduce build output verbosity
Interpreting Build Results
Success Response
{
"success": true,
"summary": "Build succeeded",
"warnings": 3,
"build_time": "45.2s",
"scheme": "MyApp",
"configuration": "Debug"
}
Failure Response
{
"success": false,
"error": "Build failed",
"errors": 2,
"warnings": 5,
"failure_reason": "Compilation errors in ViewController.swift"
}
Progressive Disclosure
Large build logs use progressive disclosure:
{
"success": true,
"summary": "Build succeeded with 15 warnings",
"cache_id": "build-abc123",
"quick_stats": {
"warnings": 15,
"build_time": "62.3s"
},
"next_steps": [
"Use cache_id to get full build log if needed",
"Review warnings for potential issues"
]
}
Common Build Errors
Error: "No scheme named 'X' found"
Cause: Scheme doesn't exist or isn't shared
Solution:
- Run
listoperation to see available schemes - Check if scheme is shared (Xcode → Product → Scheme → Manage Schemes)
Error: "Code signing identity not found"
Cause: Missing or invalid signing certificate
Solution:
- Check Team ID in project settings
- Verify certificates in Keychain
- Use automatic signing if possible
{
"operation": "build",
"scheme": "MyApp",
"options": {
"code_sign_identity": "Apple Development",
"development_team": "TEAM_ID_HERE"
}
}
Error: "SDK not found"
Cause: Requesting unavailable SDK version
Solution:
- Run
versionoperation to see available SDKs - Update
sdkoption or remove to use latest
Error: "Destination not found"
Cause: Invalid destination specifier
Solution:
- Use
execute_simulator_commandwith operation "list" to see available devices - Check device name spelling
- Ensure device/simulator is available
Testing Workflows
Complete Test Suite
1. list → Get test scheme
2. clean → Ensure fresh state
3. test → Run all tests
4. Analyze results → Check for failures
Flaky Test Detection
Run tests multiple times:
{
"operation": "test",
"scheme": "MyApp",
"options": {
"test_iterations": 5,
"retry_on_failure": true
}
}
Note: Test iteration support depends on Xcode version.
Test Result Analysis
Tests return:
{
"success": false,
"tests_run": 45,
"tests_passed": 43,
"tests_failed": 2,
"failures": [
{
"test": "MyAppTests.LoginTests.testInvalidPassword",
"message": "XCTAssertEqual failed: (\"error\") is not equal to (\"invalid\")"
}
]
}
Project Auto-Detection
xcodebuild operations auto-detect project files:
- Searches current directory for
.xcworkspace - Falls back to
.xcodeproj - Returns error if multiple or none found
Explicit Path:
{
"operation": "build",
"project_path": "/path/to/specific/Project.xcodeproj",
"scheme": "MyApp"
}
Build Performance Tips
1. Enable Parallel Builds
{
"options": {
"parallel": true
}
}
2. Incremental Builds
Don't clean unless necessary - incremental builds are much faster.
3. Reduce Verbosity
For CI/automated builds:
{
"options": {
"quiet": true
}
}
4. Use Derived Data Caching
Default behavior - xcodebuild uses DerivedData for caching.
CI/CD Integration
GitHub Actions Pattern
1. version → Verify Xcode installation
2. list → Validate scheme exists
3. clean → Ensure fresh build
4. build → Compile project
5. test → Run test suite
6. Analyze results → Fail pipeline if tests fail
Build Artifacts
Build produces:
.appbundle in DerivedData.xcresulttest results bundle- Build logs (via progressive disclosure)
Advanced: Build Settings
Query build settings:
{
"operation": "list",
"project_path": "/path/to/Project.xcodeproj"
}
Returns scheme/target info. For detailed build settings, use Resource:
xc://reference/build-settings
Scheme Management
Shared vs User Schemes
Shared Schemes:
- Checked into source control
- Available to all users
- Recommended for team projects
User Schemes:
- Local to your machine
- Not visible to xcodebuild by default
Best Practice: Share schemes used for CI/CD.
Integration with MCP Tools
This Skill works with execute_xcode_command tool:
- All operations use the
execute_xcode_commandtool - Tool handles xcodebuild execution and output parsing
- Tool provides progressive disclosure for large outputs
- This Skill teaches WHEN and HOW to use operations
Related Skills
- ios-testing-patterns: Advanced test strategies and analysis
- simulator-workflows: Device management for testing
- crash-debugging: Analyzing build crashes
Related Resources
xc://operations/xcode: Complete xcodebuild operations referencexc://reference/build-settings: Build settings dictionaryxc://reference/error-codes: Common error codes and solutions
Tip: Use list to discover, build to compile, test to validate. Clean only when needed.
Source
git clone https://github.com/conorluddy/xclaude-plugin/blob/main/skills/xcode-workflows/SKILL.mdView on GitHub Overview
This skill guides iOS build, test, and clean operations using the execute_xcode_command MCP tool. It emphasizes avoiding direct xcodebuild calls in bash and provides a structured, token-efficient way to interact with Xcode projects, including error handling and scheme configuration.
How This Skill Works
All xcodebuild tasks are dispatched through the execute_xcode_command MCP tool. It accepts operations like build, test, clean, list, and version, along with parameters such as scheme, configuration, destination, and project_path, returning structured results that simplify troubleshooting.
When to Use It
- To perform iOS builds (simulator or device) through the MCP dispatcher for consistency and error handling
- When running unit/UI tests for a scheme and destination
- To clean a project’s build to resolve stale artifacts
- To discover available schemes and targets with list
- To check Xcode version/info using the version operation
Quick Start
- Step 1: Discover Schemes - Use execute_xcode_command with operation: 'list' and optional project_path
- Step 2: Build - Use execute_xcode_command with operation: 'build' including scheme and configuration
- Step 3: Run tests - Use execute_xcode_command with operation: 'test' including scheme and destination
Best Practices
- Always use the execute_xcode_command MCP tool for build/test/clean tasks
- Read error messages carefully and adjust parameters or project settings
- Supply a project_path when needed to ensure the correct Xcode project is targeted
- Verify the scheme, configuration, and destination before running a command
- Avoid running bash xcodebuild commands; use MCP tool for consistency and integration
Example Use Cases
- Build for simulator: op 'build', scheme: 'MyApp', configuration: 'Debug'
- List schemes to discover targets: op 'list', project_path: '/path/to/MyApp.xcodeproj'
- Run tests: op 'test', scheme: 'MyAppTests', destination: 'platform=iOS Simulator,OS=14.5,name=iPhone 12'
- Clean build: op 'clean', scheme: 'MyApp', configuration: 'Release'
- Get Xcode version: op 'version' with no extra parameters