java git打包iOS_Jenkins实现iOS项目自动化打包(含踩坑记录)

一、前言

这段时间一直在参与开发前端项目。与iOS工作流程不同的是,前端给QA提测前,只需将feature分支代码合到一个指定的分支。然后QA人员会通过Jenkins工具进行项目的构建部署。之前在探索iOS的自动化打包时,就听过Jenkins的大名,但是一直没去了解。这次借此机会由最擅长的iOS项目为切入点,开始对Jenkins的探索。

二、安装Jenkins

**Jenkins**依赖了Java环境,所以在安装Jenkins前,要确保系统要安装了Java

安装Java

终端输入命令,若不识别。说明没有安装Java JDK

java --version

复制代码

若没有安装或版本过低,可通过以下链接下载。注意要根据自己电脑的系统选择对应的版本

Java JDK下载

安装Jenkins

brew install jenkins

复制代码这里有两个坑要提一下

brew安装jenkins的版本不是最新版本。这会导致有些必要的Jenkins插件不能安装。

解决办法: 卸载重装HomeBrew

brew命令后总是卡在updating处

解决办法: 不要关闭当前终端窗口,新开一个窗口。并再次输入brew命令

开启Jenkins服务

brew services start jenkins

复制代码

第一次服务开启成功后,在浏览器中输入http://localhost:8080,会出现一个让你输入Jenkins初始密码的页面

获取Jenkins初始密码

defaults write com.apple.finder AppleShowAllFiles YES

vi /Users/jackey/.jenkins/secrets/initialAdminPassword

复制代码

将获取到的初始密码输入后,重启Jenkins

brew services restart jenkins

复制代码

重新输入http://localhost:8080,会进入配置界面。点击安装建议的插件,耐心等待插件安装过程(时间较长)

若过程中有插件安装失败,可查看失败日志。我当初遇到的问题就是Jenkins版本过低,所以有些插件不能安装。原因是brew版本过低导致

创建管理员账户

插件安装成功后,进入如下界面

b95e55ed45d34936363aaac68dc1b1ca.png

按要求将所有项目填写成功后,点击保存就可以正常使用Jenkins了

通过url来关闭/重启Jenkins

http://localhost:8080/restart

http://localhost:8080/exit

复制代码

三、Jenkins中配置iOS项目

新建Item,创建一个任务。输入任务名后,选择第一项:Freestyle project

8d6549fdb69b0a98db08aa53debe9f86.png

配置General项

c97ef142ed16c4bda151d290a90ebf4a.png

源码管理项

335c1179f7d2f263c5fc7434725e6255.png

CocoaPods配置项

选择构建->增加构建配置->Execute Shell。将对应的pod命令填进去

05bc5aaf9d5ae2f6a56e25248f580b80.png

这里有两个注意点

直接pod install --verbose --no-repo-update会报错,pod: command not found

解决方法: export 语句将控制台语言环境设置为 UTF-8 格式,避免出现 Podfile 文件打开错误。

在构建中添加 pod install 脚本要用左边的bar托到构建项的第一位

Xcode-General build settings配置

0f9e6b8d8a445a4351bbc989a0836e13.png

Xcode-Code signing配置

66a7893c6b4c81f7d185eb9854f21fd0.png

Xcode-OS X keychain options配置

47132723c6ceb92fdb034167aedd6583.png

Xcode-Advanced Xcode build options配置

08d6ec98acaaf7a475d4b50ec194ba2e.png

添加打包并上传蒲公英脚本

增加构建步骤-Execute Shell。输入以下脚本

# 工程名

APP_NAME="XLLJenkinsDemo"

# 证书,如果自动选择证书,设为“iPhone Developer”即可

CODE_SIGN_DEVELOPER="iPhone Developer"

# info.plist路径

project_infoplist_path="./${APP_NAME}/Info.plist"

#取版本号

bundleShortVersion=$(/usr/libexec/PlistBuddy -c "print CFBundleShortVersionString" "${project_infoplist_path}")

#取build值

bundleVersion=$(/usr/libexec/PlistBuddy -c "print CFBundleVersion" "${project_infoplist_path}")

DATE="$(date +%Y%m%d)"

IPANAME="${APP_NAME}_V${bundleShortVersion}_${DATE}.ipa"

#要上传的ipa文件路径

IPA_PATH="$HOME/${IPANAME}"

echo ${IPA_PATH}

#echo "${IPA_PATH}">> text.txt

#集成有Cocopods的用法

echo "=================clean================="

xcodebuild -workspace "${APP_NAME}.xcworkspace" -scheme "${APP_NAME}" -configuration 'Release' clean

echo "+++++++++++++++++build+++++++++++++++++"

xcodebuild -workspace "${APP_NAME}.xcworkspace" -scheme "${APP_NAME}" -sdk iphoneos -configuration 'Release' CODE_SIGN_IDENTITY="${CODE_SIGN_DEVELOPER}" SYMROOT='$(PWD)'

xcrun -sdk iphoneos PackageApplication "./Release-iphoneos/${APP_NAME}.app" -o ~/"${IPANAME}"

#上传到蒲公英

#蒲公英上的user Key

uKey="..."

#蒲公英上的API Key

apiKey="..."

#蒲公英版本更新描述,这里取git最后一条提交记录作为描述

MSG=`git log -1 --pretty=%B`

#要上传的ipa文件路径

echo $IPA_PATH

#执行上传至蒲公英的命令

echo "++++++++++++++upload+++++++++++++"

curl -F "file=@${IPA_PATH}" -F "uKey=${uKey}" -F "_api_key=${apiKey}" -F "buildUpdateDescription=${MSG}" http://www.pgyer.com/apiv2/app/upload

复制代码

四、项目构建

点击Build Now,可在Build History中看到构建进度。我们可以点击进度条进入构建实时详情

158927f3b26a35526ab752d5ede263e2.png

在详情中,点击控制台输出,可以查看构建日志

007cd0e855a863a2baeba26fb928611f.png

在日志最后前几行发现Build Success,说明项目构建成功。

b8007803b8db1daf6d594d30963b4bf6.png

在日志最后发现如下信息,说明上传蒲公英成功

d8810b88a546a6166514e31cb6147a66.png

这里构建时,一开始不出意外必然会出现各种各样导致构建失败的错误。根据日志报错信息的提示对症去解决问题即可。

不要担心日志密密麻麻的信息,一般全局搜索error或者仅仅查看最后十几二十行的日志,就可以读到关键信息。

一般是项目配置或者签名文件和配置证书的问题

######这里我只将自己遇到的一个特殊的报错总结出来

运行xcrun脚本后报错:xcrun: error: unable to find utility "PackageApplication", not a developer tool or in PATH

可以看出在执行最后的脚本配置出现报错,最后在网上找到了原因和解决办法

原因: 新版的Xcode少了这个PackageApplication(转注:PackageApplication在前几个版本已被标识为废弃,在8.3版本彻底移除了)

解决办法:

找个旧版的Xcode里面copy到以下目录

/Applications/Xcode.app/Contents/Developer/Platforms/iPhoneOS.platform/Developer/usr/bin/

复制代码执行以下两个命令

sudo xcode-select -switch /Applications/Xcode.app/Contents/Developer/

chmod +x > /Applications/Xcode.app/Contents/Developer/Platforms/iPhoneOS.platform/Developer/usr/bin/PackageApplication

复制代码

附上PackageApplication下载地址:

pan.baidu.com/s/1jHJF2Lo

来源:www.jianshu.com/p/c83483289…

五、其他注意点

项目中如果有使用Pod、Carthage对三方库进行管理依赖,一定要确保安装了Carthage、Pod。并且执行了pod setup,否则构建也会失败。

目前iOS项目使用的是gitlab自身的runner进行自动化打包。后面打算将项目也使用Jenkins配置起来,这样iOS项目也可以像前端项目一样交给QA人员统一去构建处理打包。

接下来再研究一波前端Jenkins配置流程及原理,敬请期待。。。

b739ec46bb5c46d9c0aa4ce35ba1ea56.png

关于找一找教程网

本站文章仅代表作者观点,不代表本站立场,所有文章非营利性免费分享。

本站提供了软件编程、网站开发技术、服务器运维、人工智能等等IT技术文章,希望广大程序员努力学习,让我们用科技改变世界。

[Jenkins实现iOS项目自动化打包(含踩坑记录)]http://www.zyiz.net/tech/detail-129201.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值