Xcode
Инструменты командной строки
Поиск…
Запуск тестов
Для запуска модульных тестов в симуляторе с использованием использования xcodebuild
Если у вас есть рабочее пространство (например, при использовании CocoaPods )
xcodebuild \
-workspace MyApp.xcworkspace \
-scheme "MyScheme" \
-sdk iphonesimulator \
-destination 'platform=iOS Simulator,name=iPhone 6,OS=9.1' \
test
Если у вас есть файл проекта
xcodebuild \
-project MyApp.xcproj \
-scheme "MyScheme" \
-sdk iphonesimulator \
-destination 'platform=iOS Simulator,name=iPhone 6,OS=9.1' \
test
Альтернативными значениями destination
являются
-destination 'platform=iOS,id=REAL_DEVICE_UDID'
-destination 'platform=iOS,name=IPHONE NAME'
Список доступных целей, схем и конфигураций сборки
Чтобы просмотреть все доступные схемы для проекта в текущем каталоге
xcodebuild -list
При желании вы можете передать путь к файлу проекта или рабочей области
xcodebuild -list -workspace ./MyApp.xcworkspace
xcodebuild -list -project ./MyApp.xcodeproj
Пример вывода
Information about project "Themoji":
Targets:
Themoji
ThemojiUITests
Unit
Build Configurations:
Debug
Release
If no build configuration is specified and -scheme is not passed then "Release" is used.
Schemes:
Themoji
ThemojiUITests
Units
Компилировать и подписывать схему
Очистка и компиляция кода для iPhone, в проекте MyProject для схемы Qa:
xcrun xcodebuild clean \
-workspace "MyProject.xcworkspace" \
-scheme "YourScheme" \
-sdk iphoneos \
-configuration Debug \
archive \
-archivePath builds/MyProject.xcarchive
Конфигурация может быть Debug
или Release
.
Подписание ранее скомпилированного кода:
xcrun xcodebuild -exportArchive \
-archivePath builds/MyProject-Qa.xcarchive \
-exportOptionsPlist config.plist \
-exportPath builds
config.plist
содержит информацию о том, как упаковать и подписать приложение, для разработки:
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">
<plist version="1.0">
<dict>
<key>method</key>
<string>development</string>
<key>uploadSymbols</key>
<true/>
</dict>
</plist>
Плагин релиза App Store должен содержать что-то вроде:
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">
<plist version="1.0">
<dict>
<key>teamID</key>
<string>xxxxxxxxxxx</string>
<key>method</key>
<string>app-store</string>
<key>uploadSymbols</key>
<true/>
</dict>
</plist>
Если идентификатор команды можно получить из вашей брелка.
Все доступные параметры
-
compileBitcode
-
embedOnDemandResourcesAssetPacksInBundle
-
iCloudContainerEnvironment
-
manifest
-
method
-
onDemandResourcesAssetPacksBaseURL
-
teamID
-
thinning
-
uploadBitcode
-
uploadSymbols
Чтобы получить дополнительную информацию о каждом из параметров, запустите xcodebuild --help
Доступ к любому инструменту командной строки в комплекте приложений Xcode (xcrun)
xcrun
использует стандартную версию Xcode по умолчанию (устанавливается через xcode-select
) для поиска и выполнения инструментов командной строки из пакета приложений Xcode, например llvm-cov.
# Generate code coverage reports via llvm-cov
# /Applications/Xcode.app/Contents/Developer/Toolchains/XcodeDefault.xctoolchain/usr/bin
xcrun llvm-cov [parameters]
# Execute xcodebuild
# /Applications/Xcode.app/Contents/Developer/usr/bin
xcrun xcodebuild [parameters]
# Use Xcode's version of git, e.g., if you have installed a newer version
# /Applications/Xcode.app/Contents/Developer/usr/bin
xcrun git [parameters]
Переключение инструментов командной строки с помощью xcode-select
Распечатайте путь к каталогу активного разработчика (выбранному Xcode)
xcode-select -p
Выберите другую версию Xcode, например Beta
sudo xcode-select -s /Applications/Xcode-beta.app
Сброс к стандартной версии Xcode
sudo xcode-select -r
Это эквивалентно запуску sudo xcode-select -s /Applications/Xcode.app
Для получения дополнительной информации: man xcode-select