Xcodebuild命令

1、 Xcodebuild简介

Xcodebuild是命令行工具包的其中一项。

命令行工具包(Command Line Tools)是一个轻量的、可以与XCode分开的、在Mac上单独下载的命令行工具包。

它有两部分组成:Mac OS SDK和用户系统库目录/usr/bin下的诸多命令工具。例如:gcc/g++编译器,make、git、nase、xcodebuild、xcrun等等。

2、命令行工具包(Command Line Tools)的安装

Xcode-select命令

xcode-select是Mac系统自带的命令行工具,属于用户系统内/usr/bin。当电脑上安装多个Xcode时,xcode-select用来选择命令行工具为哪一个版本的Xcode服务。

命令行工具安装指令:xcode-select --install

选择指定的Xcode路径:xcode-select --switch

3、常见命令

man命令

man可以进行命令用法的在线文档查询,包括使用例子。比如:man xcodebuild。

xcpretty命令

命令行输出美化小工具,可以对错误,警告给予高亮显示。使用方式:xcodebuild | xcpretty

xcrun命令

xcrun用于调用其他命令执行,如:xcrun xcodebuild。

xcrun的调用是基于xcode-select选择的工具链,当电脑中存在多个版本的xcode时,使用xcrun调用可以保证命令的环境一致性。

xcodebuild命令

下面重点介绍xcodebuild如何使用。

在使用xcodebuild时,从终端进入到projectname .xcodeproj 目录下。

有workspace时,参数中要带-workspace和-scheme。

只有project时,则参数中要带 -project和-scheme选项。

xcodebuild在Xcode中存在的默认配置在路径project/info页面中

4、xcodebuild的常见使用场景

简单命令行build

(1)xcodebuild

单写一个xcodebuild,工程编译使用默认的scheme和编译配置。

scheme、targets、配置、目标设备、SDK和导出数据位置可以在后面自定义配置

(2)archive打包操作

xcodebuild archive  -workspace PROJECT_NAME.xcworkspace  -scheme SCHEME_NAME -configuration release -archivePath 

EXPORT_ARCHIVE_PATH -archivePath:设置项目的归档路径

(3)导出ipa文件

xcodebuild -exportArchive -archivePath EXPORT_ARCHIVE_PATH    -exportPath EXPORT_IPA_PATH -exportOptionsPlist ExportOptionsPlistPath-allowProvisioningUpdates-exportArchive:导出ipa-exportPath:导出ipa文件的路径-exportOptionsPlist:文件导出时的配置信息-allowProvisioningUpdates:允许xcodebuild与苹果网站通讯,进行自动签名,证书自动更新,生成。

(4)单元测试

xcodebuild test -project PROJECT_NAME.xcodeproj -scheme SCHEME_NAME -destination'platform=iOS Simulator,name=iPhone 6s,OS=11.2'-configuration Debug -derivedDataPath output-derivedDataPath:产生的缓存文件放在./output目录下

configuration:编译环境,选择Debug/Release

-destination :选择test时的目标设备和系统版本号

(5) UI测试/单元测试,针对某个方法进行测试

xcodebuild test -workspace PROJECT_NAME.xcodeproj -scheme SCHEME_NAME -destination'platform=iOS Simulator,name=iPhone 6s,OS=11.2'-only-testing:TARGET_NAME/CLASS_NAME/FUNC_NAME -quiet-only-testing: 只测试某一个方法,target名/类名/方法名-quiet : 除了错误和警告不打印任何信息

(6)使用上次编译成功的测试用例进行测试

注意:app创建时需要指定app的bundle名

self.app = [[XCUIApplication alloc] initWithBundleIdentifier:@"com.xxx.id"];

[self.app launch];

1.UI测试/单元测试,不进行代码编译,利用上次编译的缓存(包括工程编译+测试用例编译),进行重新跑测试。

xcodebuild test-without-building -workspace PROJECT_NAME.xcworkspace -scheme doctor -destination'platform=iOS Simulator,name=iPhone 6s,OS=12.0'-only-testing:TARGET_NAME/CLASS_NAME/FUNC_NAME

2.UI测试,使用选项-xctestrun生产测试文件,进行测试调试

//1.产生xctestrun文件xcodebuild build-for-testing -project PROJECT_NAME.xcodeproj -scheme SCHEME_NAME -destination'platform=iOS Simulator,name=iPhone 6s,OS=11.2'-configuration Debug -derivedDataPath output-derivedDataPath: derivedDataPath/Build/Products目录下生成一个.xctestrun文件,包含测试信息

//2.使用xctestrun文件(不带-workspace/-project/-scheme参数)xcodebuild test-without-building -destination'platform=iOS Simulator,name=iPhone 6s,OS=12.0'-xctestrun DerivedDataPath.xctestrun -only-testing:TARGET_NAME/CLASS_NAME/FUNC_NAME-xctestrun:有这个选项就从指定的路径下寻找bundle,没有这个选项在derivedDataPath下寻找bundle-only-testing:TARGET_NAME/CLASS_NAME/FUNC_NAME

 5、xcodebuild常见action

6、另外一些常见的命令

genstrings 命令

本地化命令,根据指定的C/Object-C源文件生成.strings文件。

genstrings -a /path/to/source/files/*.m

ibtool 命令

本地化命令,作用于xib文件。

ibtool --generate-strings-file Localizable.strings en.lpoj/Interface.xib

你可能感兴趣的:(Xcodebuild命令)