ios-build-test
iOS Build & Test Skill
Build and manage iOS apps using native Xcode CLI tools (xcodebuild, xcrun simctl).
When to Use
- Building iOS/macOS apps with Xcode
- Running apps in iOS simulators
- Managing simulator instances (boot, shutdown, list)
- Taking screenshots or recording video
- Running unit/UI tests
- Resetting app state or onboarding flows
Build Workflow
1. Discover Project Structure
# List available schemes
xcodebuild -list
# For workspaces
xcodebuild -workspace App.xcworkspace -list
2. Find Available Simulators
# List all devices
xcrun simctl list devices
# Get booted simulator UDID
xcrun simctl list devices booted --json | jq -r '.devices[][] | select(.state == "Booted") | .udid'
# Find specific device type
xcrun simctl list devices available --json | jq -r '.devices[][] | select(.name | contains("iPhone 16")) | .udid' | head -1
3. Boot Simulator (if needed)
xcrun simctl boot $UDID
4. Build for Simulator
xcodebuild -workspace App.xcworkspace \
-scheme App \
-destination "platform=iOS Simulator,id=$UDID" \
-derivedDataPath ./DerivedData \
build
5. Install and Launch
# Find .app bundle
APP_PATH=$(find ./DerivedData -name "*.app" -type d | head -1)
# Install
xcrun simctl install $UDID "$APP_PATH"
# Launch (get bundle ID from Info.plist)
BUNDLE_ID=$(defaults read "$APP_PATH/Info.plist" CFBundleIdentifier)
xcrun simctl launch $UDID $BUNDLE_ID
# Launch with console output
xcrun simctl launch --console $UDID $BUNDLE_ID
Reset App State
Useful for testing onboarding flows or clean state:
# Uninstall app
xcrun simctl uninstall $UDID $BUNDLE_ID
# Reinstall and launch
xcrun simctl install $UDID "$APP_PATH"
xcrun simctl launch $UDID $BUNDLE_ID
To fully reset simulator:
xcrun simctl erase $UDID
Video Capture
Record simulator screen:
# Start recording in background
xcrun simctl io $UDID recordVideo output.mp4 &
RECORD_PID=$!
# ... perform actions ...
# Stop recording (SIGINT)
kill -2 $RECORD_PID
Screenshot:
xcrun simctl io $UDID screenshot screenshot.png
Running Tests
# Run all tests
xcodebuild test \
-workspace App.xcworkspace \
-scheme App \
-destination "platform=iOS Simulator,id=$UDID"
# Run specific test class
xcodebuild test \
-workspace App.xcworkspace \
-scheme App \
-destination "platform=iOS Simulator,id=$UDID" \
-only-testing:AppTests/LoginTests
# With code coverage
xcodebuild test \
-workspace App.xcworkspace \
-scheme App \
-destination "platform=iOS Simulator,id=$UDID" \
-enableCodeCoverage YES
Tuist Projects
For projects using Tuist:
# Install dependencies and generate Xcode project
mise exec -- tuist install
mise exec -- tuist generate
# Then use standard xcodebuild commands
XcodeBuildMCP Integration
If XcodeBuildMCP tools are available, prefer those for:
- Project discovery
- Build operations
- Simulator management
Fall back to CLI commands when MCP isn't available or for operations not covered by MCP tools.
Quick Reference
| Task | Command |
|---|---|
| List schemes | xcodebuild -list |
| List simulators | xcrun simctl list devices |
| Boot simulator | xcrun simctl boot $UDID |
| Build | xcodebuild -workspace X -scheme Y -destination "..." build |
| Install app | xcrun simctl install $UDID path/to/App.app |
| Launch app | xcrun simctl launch $UDID com.bundle.id |
| Uninstall | xcrun simctl uninstall $UDID com.bundle.id |
| Screenshot | xcrun simctl io $UDID screenshot file.png |
| Record video | xcrun simctl io $UDID recordVideo file.mp4 |
| Run tests | xcodebuild test -workspace X -scheme Y -destination "..." |
Common Issues
Build fails with "no scheme": Use -list to find available schemes, specify with -scheme.
Simulator not found: Ensure UDID is correct. Use xcrun simctl list devices available to find valid simulators.
App won't launch: Check bundle ID matches what's in Info.plist. Use --console flag to see launch errors.
Video recording won't stop: Use kill -2 (SIGINT), not kill -9. The recording needs graceful termination to finalize the file.
See CLI_REFERENCE.md for complete command documentation.
More from simonlee2/claude-plugins
ffmpeg-toolkit
This skill should be used when the user asks to "convert video", "trim video", "cut video", "extract audio", "compress video", "resize video", "create gif", "merge videos", "combine videos", "add audio to video", or needs help with ffmpeg commands for video and audio processing.
31seedance-video-gen
This skill should be used when the user asks to "generate video", "create video", "make a video", "animate image", "image to video", "video with audio", "talking video", or needs AI-powered video generation with synchronized audio, lip-syncing, and cinematic camera controls.
7ui-skills
This skill should be used when the user asks to "build UI", "create interface", "design components", "implement frontend", or needs guidance on building accessible, performant interfaces with proper animation, typography, and component patterns. Provides opinionated constraints for building better interfaces with agents.
3create-cli
This skill should be used when the user asks to "design a CLI", "create command-line interface", "design CLI parameters", "plan CLI UX", or needs help structuring command-line tool interfaces with proper arguments, flags, subcommands, and user experience patterns.
3nanobanana-image-gen
Generate and edit images using Google's Nanobanana model via Replicate API. Use this skill when users request image generation from text descriptions, image-to-image transformations, style transfers, or any creative image editing tasks. Supports multiple input images, custom aspect ratios, and various output formats.
3marketplace-sync
This skill should be used when the user asks to "update the marketplace", "refresh the github page", "sync plugins.json", "update docs/plugins.json", or mentions keeping the GitHub Pages site in sync with plugin changes.
2