懒人做iOS系列之jenkins+git+fir打包(xCode9)

2017.09.28更新:

关于xcode9 升级后,关于打包报错的修复:

Error Domain=IDEProvisioningErrorDomain Code=9 ""Dandanjia.app" requires a provisioning profile with the Push Notifications feature." UserInfo={NSLocalizedDescription="Dandanjia.app" requires a provisioning profile with the Push Notifications feature., NSLocalizedRecoverySuggestion=Add a profile to the "provisioningProfiles" dictionary in your Export Options property list.}

** EXPORT FAILED **

具体解决在 第四步,新建构建项目  5.构建 中

2017.08.24更新:

有朋友说post build script plugin 链接失效了,贴个网盘吧

链接: https://pan.baidu.com/s/1gfkshSB 密码: pdua


本人处女文章就奉献在这了,我的第一次啊。。。。。。

做人嘛就得懒,只有你想懒的时候才能想出懒人解决问题的方法。最近真是被打包搞烦了,因为本人特别懒,连切个分支打个包这么简单的活都不想干,所以找到了Jenkins这个神器。真是懒人必备神器,妈妈再也不用担心我同时为多人打包了。废话不多说,开始教程。

网上也是先找了一些教程,但多多少少还是遇到了一些坑。所以想把自己整个流程写在这里吧。

第一步,安装Jenkins

两种方法,1.下载安装包,2.命令行

推荐命令行,因为安装包直接运行有可能什么反应都没有,命令行起码还有一些输出信息方便找问题。

方法1:

下载地址:http://jenkins-ci.org/

我的版本是2.60.2


懒人做iOS系列之jenkins+git+fir打包(xCode9)_第1张图片
1


懒人做iOS系列之jenkins+git+fir打包(xCode9)_第2张图片
2
懒人做iOS系列之jenkins+git+fir打包(xCode9)_第3张图片
3

运行Jenkins:

open /Applications/Jenkins/Jenkins.war

ps:我本着省事原则一开始用的方法一,但是后来发现缺少java,就先安装了brew,然后又安装了java

安装Java环境:

brew cask install java

或者:http://www.oracle.com/technetwork/java/javase/downloads/jdk8-downloads-2133151.html

方法2:

安装 home-brew(安装指导)

ruby -e "$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/master/install)"

安装 Jenkins

$ brew install jenkins

运行 Jenkins

$ jenkins

ps:这里可能提示你先安装java,安装完了java,接着安装jenkins

安装总结:这里因为我是本地有其他服务环境所以占用了8080端口,所以运行jenkins的时候提示我端口占用,解决方法在这里:

java -jar 路径 --httpPort=端口号

我这里用的是方法一安装的路径,没用命令行安装的Jenkins,命令行只是确保安装了Jenkins需要的必要环境。

所以我的命令如下:

java -jar /Applications/Jenkins/Jenkins.war --httpPort=8787

具体帖子参考:

http://blog.csdn.net/bosbear/article/details/43307899


第二步,运行并使用Jenkins

1.浏览器输入:http://localhost:8787/(我的是8787,没占用应该是8080)

初始化的图忘截取了。。。反正大概的意思就是输入一个从命令行获取的密码,随时去看一下命令行就对了,然后把这个一长串的密码记在小本本上,以后可能会用。然后就是自定义插件还是系统默认插件,当然选择默认插件,插件后续还能改。然后就进入了下图:


懒人做iOS系列之jenkins+git+fir打包(xCode9)_第4张图片
1

ps:恭喜恭喜,离成功只剩下一大步了。


第三步,安装插件和配置

系统管理->插件管理


懒人做iOS系列之jenkins+git+fir打包(xCode9)_第5张图片
1

我们要用到的插件

1.Xcode integration(xcode打包用)

2.Git plugin(git管理,svn类似)

3.Post-Build Script Plug-in(用来构建ipa后执行脚本传到fir或其它平台的)

4.github plugin(这个github的我应该没用到)

多说一句,在某个版本之后Post-Build Script Plug-in这个插件被下架了,我是废了好大劲找到了

贴个地址:(地址无效可以私信我)

http://www.filewatcher.com/m/postbuildscript.hpi.659688-0.html

这个安装方式比较特殊:系统管理-》插件管理 里面的高级选项卡 下的上传插件,选择hpi即可。


第四步,新建构建项目

前戏刚刚结束,这才是真正的开始,慢慢享受。

构建分6个块:

1.General

这部分主要就是对一些基本信息填写,项目名称,描述基本选择,我这里选项都没选,直接上图,


懒人做iOS系列之jenkins+git+fir打包(xCode9)_第6张图片
1


2.源码管理

这部分主要是从哪获取代码,SVN或者GIT,这里我是GIT

输入GIT仓库地址,

然后选择一个认证(credentials),

然后选择分支

懒人做iOS系列之jenkins+git+fir打包(xCode9)_第7张图片
2

这里划重点:(看文字和下图3)

这里重点说一下credentials,这个不是随便建个用户名就行的,是要和当初配置GIT一样,正常应该是SSH的,

下面图里选择SSH Username with privatekey

Username应该不是随便添的,反正我是GIT的账号名字

PrivateKey就是在ssh目录下获取的,目录是~/.ssh/id_rsa,把中间一段复制进来

Passphprase就是当时生成PrivateKey时的密码,如果不填,稍后拉分支代码时会在命令行提示Enter passphrase for key。


懒人做iOS系列之jenkins+git+fir打包(xCode9)_第8张图片
3

PS:到这里保存完了,构建项目正常应该可以拉到代码了。(保存返回上个页面点击立即构建)

但这里肯能会有个小问题,就是10分钟超时,如果项目过大,10分钟拉不下来就超时失败了,看下错误信息如果timeout,那么可以这么改,在图2,源码管理选项卡中,点击“add”,点击 "Advanced clone behaviours",然后设置Timeout (in minutes) for clone and fetch operation单位分钟。


3.构建触发器

说明:这个可以根据需求来设置或不设置

这里在网上粘了一段关于pull scm时间设置的:

This field followsthesyntaxofcron (withminor differences). Specifically,eachlineconsistsof5fields separatedbyTABorwhitespace:

MINUTE HOUR DOM MONTH DOW

MINUTE Minuteswithinthehour (0-59)

HOUR The houroftheday (0-23)

DOM The dayofthemonth (1-31)

MONTH The month (1-12)

DOW The dayoftheweek (0-7) where0and7are Sunday.

To specify multiple valuesforonefield,thefollowing operators are available. Intheorderofprecedence,

*'*'can be usedtospecify all valid values.

*'M-N'can be usedtospecifyarange, suchas"1-5"*'M-N/X'or'*/X'can be usedtospecify skipsofX''svaluethroughtherange, suchas"*/15"intheMINUTE fieldfor"0,15,30,45"and"1-6/2"for"1,3,5"*'A,B,...,Z'can be usedtospecify multiple values, suchas"0,30"or"1,3,5"Emptylinesandlinesthat startwith'#'will be ignoredascomments.

In addition, @yearly, @annually, @monthly, @weekly, @daily, @midnight, @hourly are supported.

举两个例子:

// every minute** ** *

// every 5 mins past the hour5* ** *

懒人做iOS系列之jenkins+git+fir打包(xCode9)_第9张图片
4


4.构建环境

我没做什么配置。。。


5.构建

如果是xcode9 请看一 否则 请看二

一 :xcode9版本

构建点增加构建步骤,选excute shell

然后增加一段打包脚本:

#!/bin/bash -l

SHCEME=xxxxxxx

CONFIGURATION=Debug

WORKSPACE_PATH=${WORKSPACE}/xxxx.xcworkspace

#PROFILE_NAME="xxxx adhoc"

#CODE_SIGN="iPhone Distribution: xxx xxx (xxxxxxxx)"

EXPORT_OPTIONS=${WORKSPACE}/ExportOptions.plist

ArchivePath=${WORKSPACE}/build/xxxxx.xcarchive

PacktName=${WORKSPACE}/build/xxxxx.ipa

#CODE_SIGN_IDENTITY="$CODE_SIGN" PROVISIONING_PROFILE_SPECIFIER="$PROFILE_NAME"

#xcodebuild clean -project xxxxx.xcodeproj -scheme $SHCEME -configuration $CONFIGURATION -alltargets

xcodebuild archive -workspace ${WORKSPACE_PATH} -scheme ${SHCEME} -configuration ${CONFIGURATION} -sdk iphoneos -archivePath ${ArchivePath}

xcodebuild -exportArchive -archivePath ${ArchivePath} -exportPath ${PacktName} -exportOptionsPlist ${EXPORT_OPTIONS}

重点在于ExportOptions.plist是要自己放在指定目录里的,否则就会报错。

这个文件可以自己archive 然后export一个,也可以照着下面图做一个

懒人做iOS系列之jenkins+git+fir打包(xCode9)_第10张图片
1

二:xcode8.3.3及以下

Target与Xcode项目中Target名字对应

Clean before build 设置为YES

Configuration Release的时候Archive

.ipa filename pattern 随便起个名字不带后缀

Outout directory 为ipa的输出路径,我这里是${WORKSPACE}/build/

这里说下${WORKSPACE}这个环境变量:

我这里代表的是:/Users/用户名/.jenkins/workspace


懒人做iOS系列之jenkins+git+fir打包(xCode9)_第11张图片
5
懒人做iOS系列之jenkins+git+fir打包(xCode9)_第12张图片
6

上图的Team ID在下图这里找到

7

PS:如果使用了cocoapods,需要配置Advanced Xcode build options

Workspace File(不用加.xcworkspace)

xcode workspace file的路径:

我这里的绝对路径是:/Users/用户名/.jenkins/workspace/build_ipa/test.workspace

build_ipa是上面填写的项目名称,所以我这里填写test就可以了

懒人做iOS系列之jenkins+git+fir打包(xCode9)_第13张图片
8

以上保存,然后构建正常应该可以生成ipa了。现在还差最后一步,传fir或者做别的事情。


6.构建后操作

上传fir:

1)fir插件

这个我用了,但是一直报错:Can not found mapping or dysm file,谁成功了,说下咋弄的,谢啦。

但也说下我的步骤吧,安装插件:http://blog.fir.im/jenkins/

安装完了,构建后操作会有upload to fir:

懒人做iOS系列之jenkins+git+fir打包(xCode9)_第14张图片
9

2)执行脚本上传

执行脚本之前需要安装fir上传用的命令:

sudo gem install -n /usr/local/bin fir-cli --no-ri --no-rdoc

上面的命令来自 fir.im 的工具 fir-cli,这是他们的官方使用说明官方工具 fir-cli 使用说明

还记得上面装的Post-Build Script Plug-in插件么,这次派上用场了,

点击add generic script,然后content里输入

#!/bin/sh

fir p ipa路径 -T fir的token -Q

我这里的ipa路径是./Build/xxx.ipa

懒人做iOS系列之jenkins+git+fir打包(xCode9)_第15张图片
10


到这里应该就可以完美的构建并上传到fir上了。


参考文章:

http://www.jianshu.com/p/13e34671788f



2017.09.01更新:

用了一段时间发现,虽然根据教程弄完方便多了,但是因为懒嘛,总想着更自动化,所以发现了参数化构建,让我们变得更懒吧!下面说说参数构建:

懒人做iOS系列之jenkins+git+fir打包(xCode9)_第16张图片
参数构建1

1.配置工程:

General下选中 参数化构建过程,然后点击下面添加参数,里面有很多选项,我这里选的是String Parameter,更多的等我研究一下,目标是没有copy 和 paste。但有参数构建已经很方便了目前。

这里说个题外话,如果有朋友关心如何通过Develop和Release来控制测试服务器和线上服务器的话,请先参考一篇文章www.jianshu.com/p/51a2bbe877aa

其实就是通过类似ifdef(DEBUG)或者ifdef(RELEASE)来控制的,而Develop和Release和就是环境参数,不懂的在来问我吧。

懒人做iOS系列之jenkins+git+fir打包(xCode9)_第17张图片
参数构建2

2.使用添加的变量:

就是在要用到的地方写 ${branch}

branch是变量名,定义了什么就用什么

3.用参数构建:

懒人做iOS系列之jenkins+git+fir打包(xCode9)_第18张图片
参数构建3


懒人做iOS系列之jenkins+git+fir打包(xCode9)_第19张图片
参数构建4

你可能感兴趣的:(懒人做iOS系列之jenkins+git+fir打包(xCode9))