使用Automator自动化iOS打包流程

1、新建Automator文件

一、在其余中找到Automator

1.png

二、配置所须要的内容

2.png

选择没有输入和指定Xcodeios

3.png

4.png

添加变量Destination Path,双击红圈指定到工程所在的目录api

5.png

添加AppleScriptxcode

6.png

三、script中的内容

on run {input, parameters}
	
	tell application "Terminal"
		activate
		do script "cd " & input & " && . BuildScript-AppStore/xcodeArchive.sh"
	end tell
	
	return input
end run
复制代码

到这Automator的配置就结束了。bash

2、iOS脚本自动化打包

在上一篇文章中说过动态环境的配置 传送门app

将BuildScript-AppStore文件夹放在xcodeproj平级的文件夹下curl

一、客官先看脚本

#!/bin/sh
#

#rvm system

function failed() {
    echo "Failed: $@" >&2
    exit 1
}

archiveName="XXXX"
projectName="XXXX"
scheme="XXXXX"
configuration="XXXX"
exportOptionsPlist="BuildScript-AppStore/exportOptions.plist"
ipaPath="$PWD/build/${archiveName}/${scheme}.ipa"
appleid="XXX"
applepassword="XXX"

#build clean
xcodebuild clean -project ${projectName} \
				 -configuration ${configuration} \
				 -alltargets || failed "clean error"



#archive
xcodebuild archive -project ${projectName} \
					-configuration ${configuration} \
					-scheme ${scheme} \
					-destination generic/platform=iOS \
					-archivePath $PWD/build/${archiveName}.xcarchive || failed "archive error"




#Export Complete
xcodebuild -exportArchive -archivePath $PWD/build/${archiveName}.xcarchive \
		 	-exportOptionsPlist ${exportOptionsPlist} \
		 	-exportPath ${buildPath}/appStorebuild/${archiveName} \
		 	-verbose || failed "export error"

#发布到iTunesConnect
altoolPath="/Applications/Xcode.app/Contents/Applications/Application Loader.app/Contents/Frameworks/ITunesSoftwareService.framework/Versions/A/Support/altool"

#validate
"${altoolPath}" --validate-app -f ${ipaPath} -u "$appleid" -p "$applepassword" -t ios --output-format xml || failed "validate error"

#upload
"${altoolPath}" --upload-app -f ${ipaPath} -u "$appleid" -p "$applepassword" -t ios --output-format xml || failed "upload error"

复制代码

二、参数说明

archiveName 看你心情写一个名字测试

projectName 你的xcodeproj名字ui

在工程根目录下执行 xcodebuild -list能够看到你能够设置的 scheme和 configuration 这两个参数就是上次动态环境配置的scheme 和 Build Configurationurl

exportOptionsPlist 是配置在打包中的参数,method根据你的须要能够设置为app-store, package, ad-hoc, enterprise, development, and developer-idspa

<?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>app-store</string>
	<key>teamID</key>
	<string>XXXX</string>
</dict>
</plist>
复制代码

这里plist文件和脚本文件都在BuildScript-AppStore文件内

3.上述脚本是在提交到App Store中的日常在测试中通常放在fir或者蒲公英上

上传蒲公英 【蒲公英官方文档】

curl -F "file=@${ipaPath}" \
	 -F "uKey=XXXX" \
	 -F "_api_key=XXXXXX" \
	 -F "updateDescription=版本描述" \
   	https://www.pgyer.com/apiv1/app/upload || failed "提交蒲公英失败"
复制代码

谢谢观赏

相关文章
相关标签/搜索